@sockethub/server 5.0.0-alpha.3 → 5.0.0-alpha.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/README.md +54 -60
  2. package/bin/sockethub +4 -3
  3. package/package.json +42 -60
  4. package/res/socket.io.js +4908 -0
  5. package/res/sockethub-client.js +602 -0
  6. package/res/sockethub-client.min.js +19 -0
  7. package/sockethub.config.example.json +2 -3
  8. package/src/bootstrap/init.d.ts +20 -7
  9. package/src/bootstrap/init.test.ts +211 -0
  10. package/src/bootstrap/init.ts +152 -75
  11. package/src/bootstrap/load-platforms.ts +151 -0
  12. package/src/config.test.ts +27 -22
  13. package/src/config.ts +82 -78
  14. package/src/defaults.json +24 -16
  15. package/src/index.ts +67 -27
  16. package/src/janitor.test.ts +211 -0
  17. package/src/janitor.ts +145 -77
  18. package/src/listener.ts +151 -57
  19. package/src/middleware/create-activity-object.test.ts +28 -8
  20. package/src/middleware/create-activity-object.ts +17 -8
  21. package/src/middleware/expand-activity-stream.test.data.ts +332 -346
  22. package/src/middleware/expand-activity-stream.test.ts +65 -66
  23. package/src/middleware/expand-activity-stream.ts +29 -19
  24. package/src/middleware/store-credentials.test.ts +74 -62
  25. package/src/middleware/store-credentials.ts +15 -15
  26. package/src/middleware/validate.test.data.ts +240 -242
  27. package/src/middleware/validate.test.ts +39 -78
  28. package/src/middleware/validate.ts +63 -39
  29. package/src/middleware.test.ts +168 -138
  30. package/src/middleware.ts +62 -43
  31. package/src/platform-instance.test.ts +507 -213
  32. package/src/platform-instance.ts +337 -219
  33. package/src/platform.test.ts +375 -0
  34. package/src/platform.ts +306 -139
  35. package/src/process-manager.ts +75 -51
  36. package/src/routes.test.ts +43 -89
  37. package/src/routes.ts +40 -77
  38. package/src/sentry.test.ts +106 -0
  39. package/src/sentry.ts +19 -0
  40. package/src/sockethub.ts +186 -153
  41. package/src/util.ts +5 -0
  42. package/coverage/tmp/coverage-93126-1649152190997-0.json +0 -1
  43. package/dist/bootstrap/init.d.ts +0 -18
  44. package/dist/bootstrap/init.js +0 -63
  45. package/dist/bootstrap/init.js.map +0 -1
  46. package/dist/bootstrap/platforms.js +0 -75
  47. package/dist/common.d.ts +0 -3
  48. package/dist/common.js +0 -20
  49. package/dist/common.js.map +0 -1
  50. package/dist/config.d.ts +0 -6
  51. package/dist/config.js +0 -102
  52. package/dist/config.js.map +0 -1
  53. package/dist/crypto.d.ts +0 -10
  54. package/dist/crypto.js +0 -38
  55. package/dist/crypto.js.map +0 -1
  56. package/dist/defaults.json +0 -28
  57. package/dist/index.d.ts +0 -2
  58. package/dist/index.js +0 -25
  59. package/dist/index.js.map +0 -1
  60. package/dist/janitor.d.ts +0 -15
  61. package/dist/janitor.js +0 -89
  62. package/dist/janitor.js.map +0 -1
  63. package/dist/listener.d.ts +0 -28
  64. package/dist/listener.js +0 -91
  65. package/dist/listener.js.map +0 -1
  66. package/dist/middleware/create-activity-object.d.ts +0 -6
  67. package/dist/middleware/create-activity-object.js +0 -19
  68. package/dist/middleware/create-activity-object.js.map +0 -1
  69. package/dist/middleware/expand-activity-stream.d.ts +0 -2
  70. package/dist/middleware/expand-activity-stream.js +0 -33
  71. package/dist/middleware/expand-activity-stream.js.map +0 -1
  72. package/dist/middleware/expand-activity-stream.test.data.d.ts +0 -480
  73. package/dist/middleware/expand-activity-stream.test.data.js +0 -360
  74. package/dist/middleware/expand-activity-stream.test.data.js.map +0 -1
  75. package/dist/middleware/store-credentials.d.ts +0 -3
  76. package/dist/middleware/store-credentials.js +0 -19
  77. package/dist/middleware/store-credentials.js.map +0 -1
  78. package/dist/middleware/validate.d.ts +0 -2
  79. package/dist/middleware/validate.js +0 -58
  80. package/dist/middleware/validate.js.map +0 -1
  81. package/dist/middleware/validate.test.data.d.ts +0 -532
  82. package/dist/middleware/validate.test.data.js +0 -263
  83. package/dist/middleware/validate.test.data.js.map +0 -1
  84. package/dist/middleware.d.ts +0 -10
  85. package/dist/middleware.js +0 -54
  86. package/dist/middleware.js.map +0 -1
  87. package/dist/platform-instance.d.ts +0 -77
  88. package/dist/platform-instance.js +0 -211
  89. package/dist/platform-instance.js.map +0 -1
  90. package/dist/platform.d.ts +0 -6
  91. package/dist/platform.js +0 -187
  92. package/dist/platform.js.map +0 -1
  93. package/dist/process-manager.d.ts +0 -11
  94. package/dist/process-manager.js +0 -78
  95. package/dist/process-manager.js.map +0 -1
  96. package/dist/routes.d.ts +0 -13
  97. package/dist/routes.js +0 -83
  98. package/dist/routes.js.map +0 -1
  99. package/dist/sockethub.d.ts +0 -39
  100. package/dist/sockethub.js +0 -119
  101. package/dist/sockethub.js.map +0 -1
  102. package/dist/store.d.ts +0 -5
  103. package/dist/store.js +0 -17
  104. package/dist/store.js.map +0 -1
  105. package/src/bootstrap/platforms.js +0 -75
  106. package/src/common.test.ts +0 -54
  107. package/src/common.ts +0 -14
  108. package/src/config.d.ts +0 -2
  109. package/src/crypto.d.ts +0 -5
  110. package/src/crypto.test.ts +0 -41
  111. package/src/crypto.ts +0 -41
  112. package/src/janitor.d.ts +0 -8
  113. package/src/middleware/validate.d.ts +0 -1
  114. package/src/middleware.d.ts +0 -21
  115. package/src/sockethub.d.ts +0 -1
  116. package/src/store.test.ts +0 -28
  117. package/src/store.ts +0 -17
  118. package/test/init-suite.js +0 -41
  119. package/test/queue.functional.test.js +0 -0
  120. package/test/sockethub-suite.js +0 -25
  121. package/tsconfig.json +0 -18
  122. package/views/examples/dummy.ejs +0 -93
  123. package/views/examples/feeds.ejs +0 -90
  124. package/views/examples/irc.ejs +0 -239
  125. package/views/examples/shared.js +0 -72
  126. package/views/examples/xmpp.ejs +0 -191
  127. package/views/index.ejs +0 -17
@@ -1,239 +0,0 @@
1
- <!doctype html>
2
- <html>
3
- <head>
4
- <title>Sockethub Example IRC Chat</title>
5
- <style>
6
- * { margin: 0; padding: 0; box-sizing: border-box; }
7
- body { font: 0.8em Helvetica, Arial; }
8
- h3 { color: #6B6767; font-size: 0.8em; margin-bottom: 1em; }
9
- form#chat { background: #000; padding: 0.3em; position: fixed; bottom: 0; width: 100%; }
10
- input { border: 0; padding: 5%; }
11
- button { width: 20%; background: rgb(130, 224, 255); border: none; padding: 5%; }
12
- button.invis { background-color: rgba(0, 0, 0, 0); color: rgba(0, 0, 0, 0);}
13
- button:hover { cursor: pointer; }
14
- .messageInput { width: 80%; }
15
- #messages { list-style-type: none; margin: 0; padding: 0; }
16
- #messages li { padding: 0.1em 1%; }
17
- #messages li:nth-child(odd) { background: #eee; }
18
- .modal { position: fixed; top: 15%; left: 5%; width: 90%;
19
- line-height: 1em; padding: 3% 0 3%;
20
- background-color: #f1c40f; text-align: center;
21
- z-index: 10; outline: 9999px solid rgba(0,0,0,0.5); }
22
- @media only screen and (max-width: 1050px) {
23
- body { font: 1em Helvetica, Arial; }
24
- h3 { color: #6B6767; font-size: 1em; margin-bottom: 1.5em; }
25
- input { border: 0; padding: 3%; width: 70%; font-size: 1em; }
26
- button { width: 20%; border: none; padding: 3%; font-size: 1em; }
27
- }
28
- @media only screen and (max-width: 5000px) {
29
- body { font: 0.9em Helvetica, Arial; }
30
- h3 { color: #6B6767; font-size: 1.2em; margin-bottom: 1.5em; }
31
- .modal input { border: 0; padding: 2%; width: 80%; font-size: 0.8em; }
32
- .modal button { width: 10%; border: none; padding: 2%; font-size: 0.8em; }
33
- input { padding: 1%; }
34
- button { padding: 1%; width: 10%; }
35
- .messageInput { width: 90%; }
36
- }
37
- </style>
38
- </head>
39
- <body>
40
- <div class="modal">
41
- <h3>Click `Join` to connect and join the IRC channel.</h3>
42
- <form id="intro" action="">
43
- <!-- <input id="n" autocomplete="off" value="sh-"><button class="invis" disabled>nick</button>-->
44
- <input id="j" autocomplete="off" value=""><button id="join">Join</button>
45
- </form>
46
- </div>
47
- <ul id="messages"></ul>
48
- <form id="chat" action="">
49
- <input id="m" autocomplete="off" class="messageInput" disabled><button id="send" disabled>Send</button>
50
- </form>
51
-
52
- <script src="<%= address %>jquery.js"></script>
53
- <script src="<%= address %>socket.io.js"></script>
54
- <script src="<%= address %>sockethub-client.js"></script>
55
- <script src="<%= address %>examples/shared.js"></script>
56
- <script>
57
- debug = function (msg, obj) { console.log(msg, obj); };
58
- const examplesShared = new ExamplesShared();
59
- const ircServer = 'irc.libera.chat';
60
- localStorage.debug = 'sockethub:*';
61
- const sc = new SockethubClient(io('<%= address %>', { path: '/sockethub' }));
62
- let channel = 'sockethub-test';
63
- let nick = `sh-${Math.random().toString(36).substr(2)}`;
64
- console.log('nick: ' + nick);
65
-
66
- $('#j').val('#' + channel);
67
-
68
- function __normalizeMessage(msg) {
69
- function __normalizeTargetFromContent(string) {
70
- const postCMD = msg.object.content.substr(string.length + 1) + ' ';
71
- const target = postCMD.substr(0, postCMD.indexOf(' '));
72
- if (target.indexOf('#') === 0) {
73
- msg.target = ircServer + '/' + target;
74
- sc.ActivityStreams.Object.create({
75
- 'id': ircServer + '/' + target,
76
- 'type': "room",
77
- name: target
78
- });
79
- } else {
80
- msg.target = target + '@' + ircServer;
81
- sc.ActivityStreams.Object.create({
82
- 'id': target + '@' + ircServer,
83
- 'type': "person",
84
- name: target
85
- });
86
- }
87
- }
88
-
89
- if ((typeof msg.object === 'object') &&
90
- (typeof msg.object.content === 'string')) {
91
-
92
- if (msg.object.content.indexOf('/me') === 0) {
93
- // show completed emotes from us
94
- // rewrite as object to what the incoming objects should look like
95
- msg.object['type'] = 'me';
96
- msg.object.content = msg.object.content.substr(4);
97
- } else if (msg.object.content.indexOf('/nick') === 0) {
98
- msg.object['type'] = 'address';
99
- msg['type'] = 'update';
100
- __normalizeTargetFromContent('/nick');
101
- delete msg.object.content;
102
- } else if (msg.object.content.indexOf('/notice') === 0) {
103
- // show completed emotes from us
104
- // rewrite as object to what the incoming objects should look like
105
- msg.object['type'] = 'notice';
106
- __normalizeTargetFromContent('/notice');
107
- msg.object.content = msg.object.content.substr(8 + object.target.name.length + 1);
108
- }
109
- }
110
- return msg;
111
- }
112
-
113
- // creates an ActivityStreams object for our actor (us)
114
- function __updateActor(_nick) {
115
- debug(`update nick ${nick} to ${_nick}`);
116
- // our irc user info
117
- nick = _nick; // set global nick
118
- sc.ActivityStreams.Object.create({
119
- id: nick,
120
- type: "person",
121
- name: nick,
122
- url: "http://sockethub.org",
123
- image: {
124
- url: "http://example.org/image.jpg",
125
- mediaType: "image/jpeg",
126
- width: 250,
127
- height: 250
128
- }
129
- });
130
- __updateCredentials();
131
- }
132
-
133
- function __updateCredentials() {
134
- // sending irc credentials to Sockethub server
135
- const credentials = {
136
- actor: nick,
137
- context: 'irc',
138
- type: 'credentials',
139
- object: {
140
- type: 'credentials',
141
- nick: nick,
142
- server: ircServer,
143
- secure: true
144
- }
145
- };
146
- debug('sending credentials: ', credentials);
147
- sc.socket.emit('credentials', credentials, (err) => {
148
- if (err) { console.log('failed to set credentials ', err); }
149
- else { console.log('credentials set'); }
150
- });
151
- }
152
-
153
- function handleMessage(msg) {
154
- msg = sc.ActivityStreams.Stream(msg);
155
- msg = __normalizeMessage(msg);
156
- if (msg.error) {
157
- debug('error', msg);
158
- $('#messages').append($('<li>').text(msg.error));
159
- // } else if (msg.type === 'connect') {
160
- // __updateActor(nick);
161
- } else if ((typeof msg.object === 'object') &&
162
- (typeof msg.object.content === 'string')) {
163
- examplesShared.processIncomingMessage(msg);
164
- } else if ((msg.type === 'update') &&
165
- (msg.object.type === 'address') &&
166
- (msg.actor.name === nick)) {
167
- // our nick has been updated
168
- __updateActor(msg.target.name);
169
- examplesShared.processIncomingMessage(msg);
170
- } else if (msg.type === 'join') {
171
- $('.modal').css('display', 'none');
172
- $('input#m').prop('disabled', false);
173
- $('button#send').prop('disabled', false);
174
- } else {
175
- debug('nothing to do for message ', msg);
176
- examplesShared.processIncomingMessage(msg);
177
- }
178
- }
179
-
180
- // handle incoming messages from the Sockethub server
181
- sc.socket.on('message', handleMessage);
182
-
183
- // handler for user input, emit messages to Sockethub server
184
- $('#chat').submit(function () {
185
- let msg = {
186
- type: 'send',
187
- context: 'irc',
188
- actor: nick,
189
- object: {
190
- type: 'message',
191
- content: $('#m').val()
192
- },
193
- target: channel
194
- };
195
-
196
- msg = __normalizeMessage(msg);
197
- debug('sending message: ', msg);
198
- sc.socket.emit('message', msg, handleMessage);
199
- $('#m').val('');
200
- return false;
201
- });
202
-
203
- // handler for user input, emit messages to Sockethub server
204
- $('#join').click(function () {
205
- channel = $('#j').val();
206
-
207
- __updateActor(nick);
208
- // the irc chatroom we're connecting to
209
- sc.ActivityStreams.Object.create({
210
- id: channel,
211
- type: "room",
212
- name: channel
213
- });
214
- debug('socket id: ', sc.socket.id);
215
-
216
- const connect = {
217
- type: 'connect',
218
- context: 'irc',
219
- actor: nick,
220
- }
221
-
222
- const join = {
223
- type: 'join',
224
- context: 'irc',
225
- actor: nick,
226
- target: channel
227
- };
228
-
229
- debug('sending connect: ', connect);
230
- sc.socket.emit('message', connect, (msg) => {
231
- handleMessage(msg);
232
- debug('sending join: ', join);
233
- sc.socket.emit('message', join, handleMessage);
234
- });
235
- return false;
236
- });
237
- </script>
238
- </body>
239
- </html>
@@ -1,72 +0,0 @@
1
-
2
- function ExamplesShared() {}
3
-
4
- ExamplesShared.prototype.__displayPresenceUpdate = function (msg) {
5
- const status = (msg.object.status) ? ': ' + msg.object.status : '';
6
- let actor = msg.actor.id;
7
- if (msg.object.presence !== 'offline') {
8
- actor = document.createElement('a');
9
- actor.appendChild(document.createTextNode(msg.actor.id));
10
- actor.title = msg.actor.id;
11
- actor.href = msg.actor.id;
12
- $('#messages').append(actor);
13
- // actor = '<a class="actor" href="' + msg.actor.id + '>' + msg.actor.id + '</a>';
14
- }
15
- $('#messages')
16
- .append($('<li>').text(
17
- '[ ' + msg.actor.id + ' is ' + msg.object.presence + ']' + status));
18
- };
19
-
20
- ExamplesShared.prototype.__displayMessageContent = function (msg) {
21
- const name = (typeof msg.actor === 'object') ?
22
- msg.actor.name || msg.actor.id : msg.type;
23
- $('#messages').append($('<li>').text(name + ': ' + msg.object.content));
24
- };
25
-
26
- ExamplesShared.prototype.__displayUnknownContent = function (msg) {
27
- debug('unknown message, applying default display rule ', msg);
28
- $('#messages').append($('<li>').text(': ' + JSON.stringify(msg)));
29
- };
30
-
31
- ExamplesShared.prototype.processIncomingMessage = function (msg) {
32
- console.log('incoming message: ', msg);
33
- if (msg.type === 'query') {
34
- if (msg.object.members) {
35
- $('#messages').append($('<li>').text(` users in ${msg.actor.name}`))
36
- .append($('<li>').text(` [ ${msg.object.members.join(', ')} ]`));
37
- }
38
- } else if ((msg.type === 'pong') || (msg.type === 'ping')) {
39
- $('#messages').append($('<li>').text(
40
- `${msg.type} received from ${msg.actor.id} at ${msg.published}`));
41
- } else if ((msg.type === 'update') && (msg.object.type === 'address')) {
42
- $('#messages').append($('<li>').text(
43
- `${msg.actor.name} is now known as ${msg.target.name}`));
44
- } else if ((msg.type === 'update') && (msg.object.type === 'presence')) {
45
- this.__displayPresenceUpdate(msg);
46
- } else if ((msg.type === 'add' || msg.type === 'remove') &&
47
- (msg.object.type === 'relationship')) {
48
- const action = msg.type === 'add' ? 'set' : 'removed';
49
- $('#messages').append($('<li>').text(
50
- `${msg.actor.name} ${action} ${msg.object.relationship} of
51
- ${msg.object.subject.role}`));
52
- } else if (msg.type === 'join') {
53
- $('#messages').append($('<li>').text(
54
- `${msg.actor.name} has joined ${msg.target.name}`));
55
- } else if ((msg.type === 'announce') && (msg.actor.type === 'service')) {
56
- $('#messages').append($('<li>').text(`connected to ${msg.actor.id}`));
57
- } else if (msg.type === 'error') {
58
- console.log('error received: ', msg);
59
- } else if (msg.type === 'close') {
60
- console.log('close event received... offline.');
61
- } else if (msg.object && msg.object.type === 'me') {
62
- $('#messages').append($('<li>').text(
63
- `* ${msg.actor.name} ${msg.object.content}`));
64
- } else if (msg.object && msg.object.type === 'notice') {
65
- $('#messages').append($(
66
- '<li>').text(`NOTICE from ${msg.actor.name}: ${msg.object.content}`));
67
- } else if (msg.object && msg.object.content) {
68
- this.__displayMessageContent(msg);
69
- } else {
70
- this.__displayUnknownContent(msg);
71
- }
72
- };
@@ -1,191 +0,0 @@
1
- <!doctype html>
2
- <html>
3
- <head>
4
- <title>Sockethub Example XMPP Chat</title>
5
- <style>
6
- * { margin: 0; padding: 0; box-sizing: border-box; }
7
- body { font: 0.8em Helvetica, Arial; }
8
- h3 { color: #6B6767; font-size: 0.8em; margin-bottom: 1em; }
9
- form#chat { background: #000; padding: 0.3em; position: fixed; bottom: 0; width: 100%; }
10
- input { border: 0; padding: 5%; }
11
- button { width: 20%; background: rgb(130, 224, 255); border: none; padding: 5%; }
12
- button.invis { background-color: rgba(0, 0, 0, 0); color: rgba(0, 0, 0, 0);}
13
- button:hover { cursor: pointer; }
14
- .messageInput { width: 80%; }
15
- #messages { list-style-type: none; margin: 0; padding: 0; }
16
- #messages li { padding: 0.1em 1%; }
17
- #messages li:nth-child(odd) { background: #eee; }
18
- .modal { position: fixed; top: 15%; left: 5%; width: 90%;
19
- line-height: 1em; padding: 3% 0 3%;
20
- background-color: #f1c40f; text-align: center;
21
- z-index: 10; outline: 9999px solid rgba(0,0,0,0.5); }
22
- @media only screen and (max-width: 1050px) {
23
- body { font: 1em Helvetica, Arial; }
24
- h3 { color: #6B6767; font-size: 1em; margin-bottom: 1.5em; }
25
- input { border: 0; padding: 3%; width: 70%; font-size: 1em; }
26
- button { width: 20%; border: none; padding: 3%; font-size: 1em; }
27
- }
28
- @media only screen and (max-width: 5000px) {
29
- body { font: 0.9em Helvetica, Arial; }
30
- h3 { color: #6B6767; font-size: 1.2em; margin-bottom: 1.5em; }
31
- .modal input { border: 0; padding: 2%; width: 80%; font-size: 0.8em; }
32
- .modal button { width: 10%; border: none; padding: 2%; font-size: 0.8em; }
33
- input { padding: 1%; }
34
- button { padding: 1%; width: 10%; }
35
- .messageInput { width: 90%; }
36
- }
37
- </style>
38
- </head>
39
- <body>
40
- <div class="modal">
41
- <h3>Click `Join` to connect to the XMPP server.</h3>
42
- <form id="intro" action="">
43
- <input id="userAddress" autocomplete="off" value="username@jabber.org"><button class="invis" disabled>&nbsp;</button>
44
- <input id="password" type="password" autocomplete="off" value="password"><button class="invis" disabled>&nbsp;</button>
45
- <input id="resource" autocomplete="off" value="SockethubExample" disabled><button id="join">Join</button>
46
- </form>
47
- </div>
48
-
49
- <ul id="messages"></ul>
50
- <form id="chat" action="">
51
- <input id="m" autocomplete="off" class="messageInput" disabled><button id="send" disabled>Send</button>
52
- </form>
53
-
54
- <script src="<%= address %>jquery.js"></script>
55
- <script src="<%= address %>socket.io.js"></script>
56
- <script src="<%= address %>sockethub-client.js"></script>
57
- <script src="<%= address %>examples/shared.js"></script>
58
-
59
- <script>
60
- debug = function (msg, obj) { console.log(msg, obj); };
61
- const examplesShared = new ExamplesShared();
62
- localStorage.debug = 'sockethub:*';
63
- let config = {
64
- type: 'credentials',
65
- userAddress: 'username@jabber.org',
66
- password: '123456',
67
- resource: 'Home'
68
- };
69
- let actorString = '';
70
-
71
- const sc = new SockethubClient(io('<%= address %>', { path: '/sockethub' }));
72
-
73
- // creates an ActivityStreams object for our actor (us)
74
- function __updateActor(username) {
75
- console.log('updating actor object for: ' + username);
76
- // our xmpp user info
77
- config.userAddress = username; // set global userAddress
78
- actorString = config.userAddress + '/' + config.resource;
79
- const asObject = {
80
- id: actorString,
81
- type: "person",
82
- name: new URL('http://' + username).username,
83
- url: "http://sockethub.org",
84
- image: {
85
- url: "http://example.org/image.jpg",
86
- mediaType: "image/jpeg",
87
- width: 250,
88
- height: 250
89
- }
90
- };
91
- console.log('creating activity stream object ', asObject);
92
- sc.ActivityStreams.Object.create(asObject);
93
- }
94
-
95
- function handleMessage(msg) {
96
- if (msg.error) {
97
- debug('received error: ', msg);
98
- console.error(msg.error);
99
- } else if (msg['type'] === 'connect') {
100
- $('.modal').css('display', 'none');
101
- } else if (msg['type'] === 'join') {
102
- $('input#m').prop('disabled', false);
103
- $('button#send').prop('disabled', false);
104
- } else {
105
- examplesShared.processIncomingMessage(msg);
106
- }
107
- }
108
- // handle incoming messages from the Sockethub server
109
- sc.socket.on('message', handleMessage);
110
-
111
- $('.actor').click(function (e) {
112
- e.preventDefault();
113
- console.log('e: ', e);
114
- });
115
-
116
- // handler for user input, emit messages to Sockethub server
117
- $('#chat').submit(function (e) {
118
- e.preventDefault();
119
- const input = $('#m').val();
120
- const [target, text_message] = input.split(':');
121
-
122
- if ((!target || !text_message)) {
123
- console.log(
124
- 'unable to send message without target specified ' +
125
- '[room@server.org: hello world]: ',
126
- target, text_message, input);
127
- return false;
128
- }
129
- const msg = {
130
- type: 'send',
131
- context: 'xmpp',
132
- actor: actorString,
133
- object: {
134
- type: 'message',
135
- content: text_message
136
- },
137
- target: target
138
- };
139
-
140
- console.log('[normalize?] sending ', msg);
141
- debug('sending message: ', msg);
142
- sc.socket.emit('message', msg, handleMessage);
143
- $('#m').val('');
144
- return false;
145
- });
146
-
147
- // handler for user input, emit messages to Sockethub server
148
- $('#join').click(function (e) {
149
- e.preventDefault();
150
- config.userAddress = $('#userAddress').val();
151
- config.password = $('#password').val();
152
- config.resource = $('#resource').val();
153
-
154
- __updateActor(config.userAddress);
155
-
156
- setTimeout(function () {
157
- // sending irc credentials to Sockethub server
158
- const credentials = {
159
- actor: actorString,
160
- type: 'credentials',
161
- context: 'xmpp',
162
- object: config
163
- };
164
- debug('sending credentials: ', credentials);
165
- sc.socket.emit('credentials', credentials, (err) => {
166
- if (err) {
167
- console.error('failed to create credentials: ', err);
168
- }
169
- });
170
-
171
- const msg = {
172
- type: 'connect',
173
- context: 'xmpp',
174
- actor: actorString
175
- };
176
-
177
- debug('sending message: ', msg);
178
- sc.socket.emit('message', msg, handleMessage);
179
- msg.type = 'join';
180
- msg.target = {
181
- type: 'room',
182
- id: 'kosmos-random@kosmos.chat'
183
- };
184
- debug('sending message: ', msg);
185
- sc.socket.emit('message', msg, handleMessage);
186
- }, 100);
187
- return false;
188
- });
189
- </script>
190
- </body>
191
- </html>
package/views/index.ejs DELETED
@@ -1,17 +0,0 @@
1
- <!doctype html>
2
- <html>
3
- <head>
4
- <title>Sockethub</title>
5
- </head>
6
- <body>
7
- <h1>Welcome to Sockethub</h1>
8
- <div>
9
- <ul class="examples">
10
- <li class="example"><a href="/examples/dummy">Dummy Example</a></li>
11
- <li class="example"><a href="/examples/feeds">Atom/RSS Feeds Example</a></li>
12
- <li class="example"><a href="/examples/irc">IRC Example</a></li>
13
- <li class="example"><a href="/examples/xmpp">XMPP Example</a></li>
14
- </ul>
15
- </div>
16
- </body>
17
- </html>