-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
189 lines (174 loc) · 19.8 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
// Generated by CoffeeScript 1.12.6
(function() {
var debug, domready, invariate, observable, pkg, request, riot, socketio, zappa,
hasProp = {}.hasOwnProperty;
pkg = {
name: 'zappajs-client'
};
debug = (require('debug'))(pkg.name);
request = require('superagent');
socketio = require('socket.io-client');
domready = require('domready');
observable = (riot = require('riot')).observable;
invariate = require('invariate');
riot.route = require('riot-route');
zappa = function(options, f) {
var build_ctx, context, ev, io, ref, ref1, share;
if (typeof options === 'function') {
ref = [{}, options], options = ref[0], f = ref[1];
}
if (options == null) {
options = {};
}
context = {};
ev = context.ev = observable();
if (options.io !== false) {
io = context.io = socketio((ref1 = options.io) != null ? ref1 : {});
}
context.request = request;
context.riot = riot;
context.include = function(m) {
var ref2;
return (ref2 = m.include) != null ? ref2.call(context, context) : void 0;
};
build_ctx = function(o) {
var ctx, k, v;
ctx = {
ev: context.ev,
io: context.io,
request: context.request,
riot: context.riot,
emit: context.emit,
on: context.on
};
for (k in o) {
if (!hasProp.call(o, k)) continue;
v = o[k];
ctx[k] = v;
}
return ctx;
};
context.ready = function(f) {
return context.ev.on('ready', function() {
var ctx;
ctx = build_ctx({
include: context.include,
settings: context.settings,
get: context.get,
route: context.route,
start: context.start,
share: share
});
return f.apply(ctx);
});
};
context.start = function() {
riot.route.start();
return riot.route.exec();
};
context.get = context.route = invariate(function(k, v) {
return riot.route(k, function() {
var ctx;
ctx = build_ctx({
params: arguments,
query: riot.route.query()
});
return v.apply(ctx, arguments);
});
});
context.on = invariate(function(event, action) {
return io.on(event, function(data, ack) {
var ctx;
ctx = build_ctx({
event: event,
data: data,
ack: ack
});
return action.apply(ctx, arguments);
});
});
context.emit = invariate.acked(function(event, data, ack) {
return io.emit.call(io, event, data, function(ack_data) {
var ctx;
ctx = build_ctx({
event: event,
data: ack_data
});
return ack.apply(ctx, arguments);
});
});
if (options.io === false) {
context.on = function() {
return debug('Socket.IO is disabled');
};
context.emit = function() {
return debug('Socket.IO is disabled');
};
}
if (f != null) {
f.call(context, context);
}
if (options.io === false) {
domready(function() {
debug('DOM is ready');
return ev.trigger('ready');
});
return context;
}
share = function(next) {
var channel_name, ref2, ref3, ref4, uri, zappa_prefix, zappa_server;
zappa_prefix = (ref2 = context.settings.zappa_prefix) != null ? ref2 : '/zappa';
channel_name = (ref3 = context.settings.zappa_channel) != null ? ref3 : '__local';
zappa_server = (ref4 = options.zappa_server) != null ? ref4 : '';
uri = "" + zappa_server + zappa_prefix + "/socket/" + channel_name + "/" + io.id;
debug("Requesting " + uri);
return request.get(uri).accept('json')["catch"](function(error) {
return {
body: {
key: null
}
};
}).then(function(arg) {
var key;
key = arg.body.key;
if (key != null) {
debug("Sending __zappa_key to server", {
key: key
});
return io.emit('__zappa_key', {
key: key
}, next);
} else {
return typeof next === "function" ? next({
key: null
}) : void 0;
}
});
};
io.on('connect', function() {
debug("Connect");
io.emit('__zappa_settings', null, function(settings) {
debug('Received settings', settings);
context.settings = settings;
return share(function(arg) {
var key;
key = arg.key;
debug('Received key', key);
context.key = key;
return domready(function() {
debug('DOM is ready');
return ev.trigger('ready');
});
});
});
return debug("Waiting for Zappa settings");
});
return context;
};
module.exports = zappa;
module.exports.request = request;
module.exports.io = socketio;
module.exports.riot = riot;
}).call(this);
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["index.coffee.md"],"names":[],"mappings":"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","sourcesContent":["    pkg = name: 'zappajs-client'\n    debug = (require 'debug') pkg.name\n    request = require 'superagent'\n    socketio = require 'socket.io-client'\n    domready = require 'domready'\n    {observable} = riot = require 'riot'\n    invariate = require 'invariate'\n    riot.route = require 'riot-route'\n\n    zappa = (options,f) ->\n      if typeof options is 'function'\n        [options,f] = [{},options]\n      options ?= {}\n\n      context = {}\n\nContext\n=======\n\nThe ZappaJS-Client context contains the following objects:\n* `@io`, the Socket.IO client.\n* `@request`, a Promisified `superagent` REST client.\n* `@riot`, the riotjs module.\n* `@ev`, a [riot-observable](https://github.com/riot/observable/tree/master/doc) -- basically you can run `.on` and `.trigger` on it.\n\n      ev = context.ev = observable()\n      unless options.io is false\n        io = context.io = socketio options.io ? {}\n      context.request = request\n      context.riot = riot\n      context.include = (m) ->\n        m.include?.call context, context\n\nThese objects are always available inside handlers as well!\n\n      build_ctx = (o) ->\n        ctx =\n          ev: context.ev\n          io: context.io\n          request: context.request\n          riot: context.riot\n          emit: context.emit\n          on: context.on\n        ctx[k] = v for own k,v of o\n        ctx\n\nThe ZappaJS-Client context also contains:\n* `@include m` executes `m.include` within the ZappaJS context itself.\n\nReady\n=====\n\nWhen all the ZappaJS-Client handshake is done, and once the DOM is ready, the callback of `@ready` is called with its context set to the ZappaJS-Client context.\n\n```\n@ready ->\n  @emit 'ready'\n  @request.get '/data.json'\n  .then (data) -> alert data\n  # etc.\n```\n\n      context.ready = (f) ->\n        context.ev.on 'ready', ->\n          ctx = build_ctx\n            include: context.include\n            settings: context.settings\n            get: context.get\n            route: context.route\n            start: context.start\n            share: share\n          f.apply ctx\n\nRouter\n======\n\nThe router is [riot's router](https://github.com/riot/route/tree/master/doc). However it is not started until you explicitely call `@start()`, so feel free to use your own router instead if you'd like.\n\n* `@start()` is required to start the Riot router.\n\n      context.start = ->\n        riot.route.start()\n        riot.route.exec()\n\n* `@get` can be used the same way as ZappaJS' `@get`; except it works on the hash-path, not the URI path.\n  You can use `@route` if you prefer to use the riotjs name instead of `@get`.\n\n      context.get = context.route = invariate (k,v) ->\n        riot.route k, ->\n\nRoute context\n-------------\n\n* `params` contains the (positional) parameters in an array.\n* `query` contains the optional query parameters as an object.\n\nUse '..' at the end of a path to match query arguments.\n\nFor example to capture `/foo?bar=3`\n```\n@get '/foo..': -> @query.bar\n```\n\n          ctx = build_ctx\n            params: arguments\n            query: riot.route.query()\n          v.apply ctx, arguments\n\nSocket.IO\n=========\n\nA socket.io client is included, you can handle incoming messages from the server using `@on` and send messages back using `@emit`.\n\n      context.on = invariate (event,action) ->\n        io.on event, (data,ack) ->\n\nMessage handler context\n-----------------------\n\nThe same context is provided for `@on` handler as in server-side ZappaJS:\n* `@event` contains the event's name;\n* `@data` contains the optional event's data;\n* `@ack` is provided if the sender requested acknowledgment.\n\nAdditionally, `@data` and `@ack` are provided as regular arguments if you'd rather use that.\n\n          ctx = build_ctx\n            event: event\n            data: data\n            ack: ack\n          action.apply ctx, arguments\n\n      context.emit = invariate.acked (event,data,ack) ->\n        io.emit.call io, event, data, (ack_data) ->\n\nAck context\n-----------\n\nWhen emitting event, you might provide a `ack` callback.\n\n* `@event` contains the event's name;\n* `@data` contains the optional ack data.\n\n          ctx = build_ctx\n            event: event\n            data: ack_data\n          ack.apply ctx, arguments\n\nDisable Socket.io on options\n----------------------------\n\n      if options.io is false\n        context.on = ->\n          debug 'Socket.IO is disabled'\n        context.emit = ->\n          debug 'Socket.IO is disabled'\n\nApply User Function\n===================\n\n      if f?\n        f.call context, context\n\nLocal-only\n----------\n\nIf the `io` option is false, do not wait for IO connect.\n\n      if options.io is false\n        domready ->\n          debug 'DOM is ready'\n          ev.trigger 'ready'\n        return context\n\nAutomatically binding ExpressJS and Socket.IO\n=============================================\n\nThe main purpose of ZappaJS-Client is to automatically bind the ExpressJs and the Socket.IO `@session` objects on the server side, so that all code on the server gains access to the same session object.\nThis works even if the ExpressJS and the Socket.IO code are running on different servers.\n\nShare\n-----\n\nThe goal of the `share` function is to bind the socket ID with the ExpressJS session, then provide the session ID back to the socket.IO server.\n\n      share = (next) ->\n        zappa_prefix = context.settings.zappa_prefix ? '/zappa'\n        channel_name = context.settings.zappa_channel ? '__local'\n        zappa_server = options.zappa_server ? ''\n\nLet the Express server save its session.id and bind it to the key.\n\n        uri = \"#{zappa_server}#{zappa_prefix}/socket/#{channel_name}/#{io.id}\"\n        debug \"Requesting #{uri}\"\n        request\n        .get uri\n        .accept 'json'\n        .catch (error) ->\n          body: key: null\n        .then ({body:{key}}) ->\n\nLet the socket.io server know how to retrieve the session.id by providing it the key.\n\n          if key?\n            debug \"Sending __zappa_key to server\", {key}\n            io.emit '__zappa_key', {key}, next\n          else\n            next? key: null\n\nOn IO connect\n-------------\n\nWhen the IO socket is connected,\n\n      io.on 'connect', ->\n        debug \"Connect\"\n\nretrieve the Zappa application settings,\n\n        io.emit '__zappa_settings', null, (settings) ->\n\n          debug 'Received settings', settings\n          context.settings = settings\n\nthen bind the socket in the ExpressJS session, and provides the ExpressJS session ID to the Socket.IO server.\n\n          share ({key}) ->\n            debug 'Received key', key\n\nWe do not save the key inside the context until all the steps are completed.\nNote: The key is normally not needed.\n\n            context.key = key\n\nFinally, once the DOM is ready, trigger a `ready` event so that our client-side application may start.\n\n            domready ->\n              debug 'DOM is ready'\n              ev.trigger 'ready'\n\n        debug \"Waiting for Zappa settings\"\n\n      context\n\n    module.exports = zappa\n    module.exports.request = request\n    module.exports.io = socketio\n    module.exports.riot = riot\n"]}
//# sourceURL=/srv/home/stephane/Artisan/Managed/Node/zappajs-client/index.coffee.md