src/cm/media/js/lib/yui/yui_3.0.0b1/build/datasource/datasource-cache.js
author raph
Mon, 23 Nov 2009 15:14:29 +0100
changeset 0 40c8f766c9b8
permissions -rw-r--r--
import from internal svn r 4007
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     1
/*
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     2
Copyright (c) 2009, Yahoo! Inc. All rights reserved.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     3
Code licensed under the BSD License:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     4
http://developer.yahoo.net/yui/license.txt
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     5
version: 3.0.0b1
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     6
build: 1163
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     7
*/
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     8
YUI.add('datasource-cache', function(Y) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
     9
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    10
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    11
 * Extends DataSource with caching functionality.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    12
 *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    13
 * @module datasource
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    14
 * @submodule datasource-cache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    15
 */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    16
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    17
/**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    18
 * Adds cacheability to the DataSource Utility.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    19
 * @class DataSourceCache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    20
 * @extends Cache
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    21
 */    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    22
var DataSourceCache = function() {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    23
    DataSourceCache.superclass.constructor.apply(this, arguments);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    24
};
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    25
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    26
Y.mix(DataSourceCache, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    27
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    28
     * The namespace for the plugin. This will be the property on the host which
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    29
     * references the plugin instance.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    30
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    31
     * @property NS
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    32
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    33
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    34
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    35
     * @value "cache"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    36
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    37
    NS: "cache",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    38
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    39
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    40
     * Class name.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    41
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    42
     * @property NAME
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    43
     * @type String
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    44
     * @static
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    45
     * @final
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    46
     * @value "dataSourceCache"
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    47
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    48
    NAME: "dataSourceCache",
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    49
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    50
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    51
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    52
    // DataSourceCache Attributes
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    53
    //
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    54
    /////////////////////////////////////////////////////////////////////////////
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    55
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    56
    ATTRS: {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    57
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    58
    }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    59
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    60
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    61
Y.extend(DataSourceCache, Y.Cache, {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    62
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    63
    * Internal init() handler.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    64
    *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    65
    * @method initializer
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    66
    * @param config {Object} Config object.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    67
    * @private
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    68
    */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    69
    initializer: function(config) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    70
        this.doBefore("_defRequestFn", this._beforeDefRequestFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    71
        this.doBefore("_defResponseFn", this._beforeDefResponseFn);
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    72
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    73
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    74
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    75
     * First look for cached response, then send request to live data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    76
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    77
     * @method _beforeDefRequestFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    78
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    79
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    80
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    81
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    82
     * <dt>callback (Object)</dt> <dd>The callback object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    83
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    84
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    85
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    86
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    87
    _beforeDefRequestFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    88
        // Is response already in the Cache?
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    89
        var entry = (this.retrieve(e.request)) || null;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    90
        if(entry && entry.response) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    91
            this.get("host").fire("response", Y.mix({response: entry.response}, e));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    92
            return new Y.Do.Halt("DataSourceCache plugin halted _defRequestFn");
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    93
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    94
    },
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    95
    
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    96
    /**
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    97
     * Adds data to cache before returning data.
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    98
     *
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
    99
     * @method _beforeDefResponseFn
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   100
     * @param e {Event.Facade} Event Facade with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   101
     * <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   102
     * <dt>tId (Number)</dt> <dd>Unique transaction ID.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   103
     * <dt>request (Object)</dt> <dd>The request.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   104
     * <dt>callback (Object)</dt> <dd>The callback object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   105
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   106
     *         <dt>success (Function)</dt> <dd>Success handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   107
     *         <dt>failure (Function)</dt> <dd>Failure handler.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   108
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   109
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   110
     * <dt>data (Object)</dt> <dd>Raw data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   111
     * <dt>response (Object)</dt> <dd>Normalized response object with the following properties:
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   112
     *     <dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   113
     *         <dt>cached (Object)</dt> <dd>True when response is cached.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   114
     *         <dt>results (Object)</dt> <dd>Parsed results.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   115
     *         <dt>meta (Object)</dt> <dd>Parsed meta data.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   116
     *         <dt>error (Object)</dt> <dd>Error object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   117
     *     </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   118
     * </dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   119
     * <dt>cfg (Object)</dt> <dd>Configuration object.</dd>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   120
     * </dl>
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   121
     * @protected
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   122
     */
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   123
     _beforeDefResponseFn: function(e) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   124
        // Add to Cache before returning
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   125
        if(e.response && !e.response.cached) {
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   126
            e.response.cached = true;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   127
            this.add(e.request, e.response, (e.callback && e.callback.argument));
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   128
        }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   129
     }
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   130
});
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   131
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   132
Y.namespace('Plugin').DataSourceCache = DataSourceCache;
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   133
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   134
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   135
40c8f766c9b8 import from internal svn r 4007
raph
parents:
diff changeset
   136
}, '3.0.0b1' ,{requires:['datasource-local', 'cache']});