@sassoftware/viya-serverjs 0.2.4 → 0.4.0

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 (81) hide show
  1. package/.babelrc +6 -6
  2. package/.dockerignore +2 -2
  3. package/.env +29 -29
  4. package/.env.proxy +32 -32
  5. package/.env.server +30 -30
  6. package/.eslintignore +3 -3
  7. package/.eslintrc.json +42 -42
  8. package/Dockerfile +44 -44
  9. package/README.md +99 -99
  10. package/cli.js +9 -9
  11. package/lib/config.js +16 -16
  12. package/lib/handlers/appCallback.js +23 -24
  13. package/lib/handlers/codeAuth.js +17 -18
  14. package/lib/handlers/decodeJwt.js +3 -3
  15. package/lib/handlers/favicon.js +22 -25
  16. package/lib/handlers/getApp.js +20 -21
  17. package/lib/handlers/getApp2.js +22 -25
  18. package/lib/handlers/getUser.js +14 -17
  19. package/lib/handlers/index.js +3 -3
  20. package/lib/handlers/keepAlive.js +28 -31
  21. package/lib/handlers/keepAlive2.js +9 -12
  22. package/lib/handlers/logon.js +12 -15
  23. package/lib/handlers/logout.js +24 -28
  24. package/lib/handlers/proxyMapUri.js +6 -11
  25. package/lib/handlers/proxyOnResponse.js +6 -7
  26. package/lib/handlers/reactDev.js +22 -25
  27. package/lib/handlers/setCookies.js +52 -53
  28. package/lib/iService.js +106 -104
  29. package/lib/index.js +23 -21
  30. package/lib/parseDocker.js +3 -3
  31. package/lib/plugins/SASauth.js +30 -32
  32. package/lib/plugins/appCookie.js +36 -38
  33. package/lib/plugins/setContext.js +22 -25
  34. package/lib/plugins/setDefaultRoutes.js +61 -58
  35. package/lib/plugins/setupAuth.js +35 -38
  36. package/lib/plugins/setupUserRoutes.js +16 -16
  37. package/lib/plugins/token.js +9 -10
  38. package/lib/schemes/SASTokenScheme.js +24 -27
  39. package/package.json +85 -79
  40. package/public/data/Cluster_SDOH1.sas +181 -181
  41. package/public/data/Cluster_SDOH6.sas +179 -179
  42. package/public/data/NeuralNetwork_High_med.sas +2408 -2408
  43. package/public/data/NeuralNetwork_high_med1.sas +2408 -2408
  44. package/public/data/cars.csv +429 -429
  45. package/public/data/cmdList.txt +15 -15
  46. package/public/data/iris.csv +151 -151
  47. package/public/index.html +355 -360
  48. package/public/indexProxy.html +351 -351
  49. package/public/simplesubmit.html +233 -0
  50. package/server.js +362 -362
  51. package/src/config.js +90 -90
  52. package/src/handlers/appCallback.js +40 -40
  53. package/src/handlers/codeAuth.js +31 -31
  54. package/src/handlers/decodeJwt.js +10 -10
  55. package/src/handlers/favicon.js +23 -23
  56. package/src/handlers/getApp.js +52 -52
  57. package/src/handlers/getApp2.js +25 -25
  58. package/src/handlers/getUser.js +20 -20
  59. package/src/handlers/index.js +36 -36
  60. package/src/handlers/keepAlive.js +53 -53
  61. package/src/handlers/keepAlive2.js +12 -12
  62. package/src/handlers/logon.js +23 -23
  63. package/src/handlers/logout.js +42 -42
  64. package/src/handlers/proxyMapUri.js +25 -25
  65. package/src/handlers/proxyOnResponse.js +11 -11
  66. package/src/handlers/reactDev.js +29 -29
  67. package/src/handlers/setCookies.js +81 -79
  68. package/src/iService.js +346 -347
  69. package/src/index.js +251 -249
  70. package/src/parseDocker.js +32 -32
  71. package/src/plugins/SASauth.js +78 -78
  72. package/src/plugins/appCookie.js +51 -49
  73. package/src/plugins/setContext.js +33 -33
  74. package/src/plugins/setDefaultRoutes.js +256 -253
  75. package/src/plugins/setupAuth.js +49 -49
  76. package/src/plugins/setupUserRoutes.js +47 -47
  77. package/src/plugins/token.js +10 -10
  78. package/src/schemes/SASTokenScheme.js +43 -43
  79. package/src/visionIndex.html +23 -23
  80. package/start.sh +14 -14
  81. package/tls/viyatls.sh +2 -2
package/public/index.html CHANGED
@@ -1,360 +1,355 @@
1
- <!DOCTYPE html>
2
- <!--
3
- ~ /* ------------------------------------------------------------------------------------
4
- ~ * Copyright (c) SAS Institute Inc.
5
- ~ * Licensed under the Apache License, Version 2.0 (the "License");
6
- ~ * you may not use this file except in compliance with the License.
7
- ~ * You may obtain a copy of the License at
8
- ~ *
9
- ~ * http://www.apache.org/licenses/LICENSE-2.0
10
- ~ *
11
- ~ * Unless required by applicable law or agreed to in writing, software
12
- ~ * distributed under the License is distributed on an "AS IS" BASIS,
13
- ~ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
- ~ * See the License for the specific language governing permissions and
15
- ~ * limitations under the License.
16
- ~ ----------------------------------------------------------------------------------------*/
17
- ~
18
- -->
19
-
20
- <html lang="en">
21
- <head>
22
- <meta charset="UTF-8" />
23
- <title>index.html</title>
24
-
25
- <script
26
- crossorigin
27
- src="https://unpkg.com/react@16/umd/react.production.min.js"
28
- ></script>
29
- <script
30
- crossorigin
31
- src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"
32
- ></script>
33
- <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-standalone/6.26.0/babel.min.js"></script>
34
- <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-polyfill/6.26.0/polyfill.min.js"></script>
35
- <script src="https://unpkg.com/@sassoftware/restaf@5.2.4/dist/restaf.js"></script>
36
- <script src="https://unpkg.com/@sassoftware/restaflib@5.2.4/dist/restaflib.js"></script>
37
- <script src="/appenv"></script>
38
-
39
- <style>
40
- .container {
41
- display: flex;
42
- flex-direction: column;
43
- flex-wrap: nowrap;
44
- min-height: 800px;
45
- }
46
- .elabel {
47
- display: inline-block;
48
-
49
- clear: left;
50
- width: 250px;
51
- text-align: right;
52
- }
53
- .einput {
54
- display: inline-block;
55
- }
56
- .div1 {
57
- border: 1px solid black;
58
- background: lightskyblue;
59
- }
60
- .div2 {
61
- border: 1px solid black;
62
- background: lightskyblue;
63
- height: 200px;
64
- }
65
- </style>
66
-
67
- <script>
68
- debugger;
69
- console.log(JSON.stringify(APPENV, null, 4));
70
- let store = restaf.initStore({
71
- casProxy: true,
72
- options: {
73
- proxyServer: APPENV.PROXYSERVER,
74
- }
75
- });
76
- debugger; console.log(store.config);
77
-
78
- let session = null;
79
- let servers = null;
80
- let services = null;
81
- let files = null;
82
- let reports = null;
83
- let compute = null;
84
-
85
- function setup() {
86
- debugger;
87
- document.getElementById('output').innerHTML = '...initializing';
88
-
89
- initSession()
90
- .then(r => {
91
- document.getElementById('output').innerHTML = 'ready';
92
- keepAlive();
93
- })
94
- .catch(e => {
95
-
96
- console.log(e);
97
- });
98
- }
99
- function keepAlive() {
100
- if (LOGONPAYLOAD.keepAlive != null) {
101
- let interval = 120;
102
- let timeout = 14400;
103
- if (LOGONPAYLOAD.timers != null) {
104
- let opts = LOGONPAYLOAD.timers.split(',');
105
- interval = parseInt(opts[ 0 ]);
106
- timeout = parseInt(opts[ 1 ]);
107
- }
108
- console.log(`Keepalive is active`);
109
- store.keepViyaAlive(LOGONPAYLOAD.keepAlive, interval, timeout, () => {
110
- console.log('timed out at', Date());
111
- let params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,width=0,height=0,left=-1000,top=-1000`;
112
- window.open(`${appOptions.logonPayload.host}/SASLogon/timedout`, 'Timed Out', params);
113
- return true;
114
- });
115
- }
116
-
117
- }
118
- function logoff() {
119
- let url = `${window.location.protocol}//${window.location.host}/${LOGONPAYLOAD.appName}/logout?callbackUrl=onlogoff.html`;
120
- window.location.replace(url);
121
-
122
-
123
- }
124
- async function initSession() {
125
-
126
- console.log(APPENV);
127
- console.log(LOGONPAYLOAD);
128
- debugger;
129
- if (LOGONPAYLOAD.host == null) {
130
-
131
- return 'done';
132
- }
133
- let msg = await store.logon(LOGONPAYLOAD);
134
- console.log(store.connection());
135
- console.log(msg);
136
-
137
- // let { identities } = await store.addServices('identities');
138
- let name = 'user';
139
- // if (identities.links('currentUser') != null) {
140
- // let c = await store.apiCall(identities.links('currentUser'));
141
- // name = c.items('id');
142
- // }
143
- console.log(name);
144
- debugger;
145
- /*
146
- services = await store.addServices(
147
- 'files', 'compute', 'casManagement'
148
- );
149
- console.log(services.casManagement.links().toJS())
150
- */
151
- debugger;
152
- return 'done';
153
- }
154
- function runit(type) {
155
-
156
-
157
- document.getElementById('output').innerHTML = '...running';
158
- let testcase;
159
- switch (type) {
160
- case 'files': {
161
- testcase = SASfileService;
162
- break;
163
- }
164
- case 'compute': {
165
- testcase = dsCompute;
166
- break;
167
- }
168
- case 'cas': {
169
- testcase = runCas;
170
- break;
171
- }
172
- case 'timedout': {
173
- testcase = timedout;
174
- break;
175
- }
176
- case 'redir': {
177
- testcase= noaction;
178
-
179
- break;
180
- }
181
- case 'spre': {
182
- testcase= spre;
183
-
184
- break;
185
- }
186
- default: {
187
- testcase = SASfileService;
188
- break;
189
- }
190
- }
191
-
192
- testcase(store)
193
- .then(r => {
194
- document.getElementById(
195
- 'output'
196
- ).innerHTML = JSON.stringify(r, null, 4);
197
- })
198
- .catch(err => {
199
-
200
- document.getElementById(
201
- 'output'
202
- ).innerHTML = JSON.stringify(err, null, 4);
203
- });
204
- }
205
- async function noaction() {
206
- r = {msg: 'redirects completed'};
207
- return r;
208
- }
209
- async function spre(store) {
210
- let p = {
211
- method: 'GET',
212
- url : 'http://localhost:3000/api/test',
213
- withCredentials: true
214
- }
215
- let r = await store.request(p);
216
- return r.data;
217
- }
218
- async function timedout(store) {
219
- console.log('timed out at', Date() );
220
- let params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,width=0,height=0,left=-1000,top=-1000`;
221
- window.open(`${LOGONPAYLOAD.host}/SASLogon/timedout`,'Timed Out', params);
222
- return true;
223
- }
224
- async function runCas(store) {
225
- debugger;
226
- let {casManagement} = await store.addServices('casManagement');
227
- let servers = await store.apiCall(
228
- casManagement.links('servers')
229
- );
230
- let serverName = servers.itemsList(0);
231
- let session = await store.apiCall(
232
- servers.itemsCmd(serverName, 'createSession')
233
- );
234
- let payload = {
235
- action: 'builtins.echo',
236
- data: { code: { x: 1 } }
237
- };
238
- console.log(JSON.stringify(session.links("execute"), null, 4));
239
- let r = await store.runAction(session, payload);
240
- console.log('echo completed');
241
- await store.apiCall(session.links('delete'));
242
- return r.items();
243
- }
244
-
245
- async function SASfileService(store) {
246
- debugger;
247
- let content;
248
- try {
249
- debugger;
250
- let {files} = await store.addServices('files');
251
- debugger;
252
- console.log(JSON.stringify(files.links(), null, 4));
253
- //console.log('items - should be an array of files(empty array is ok)')
254
- // console.log(files.items().toJS());
255
- let payload = {
256
- data: { x: 1, y: 'This was saved earlier in the step' },
257
- headers: { 'content-type': 'application/json' }
258
- };
259
- let createCmd = files.links('create');
260
- let newFile = await store.apiCall(createCmd, payload);
261
- debugger;
262
- console.log(JSON.stringify(newFile.links('content'), null, 4));
263
- content = await store.apiCall(newFile.links('content'));
264
-
265
- } catch(err) {
266
- console.log(JSON.stringify(err, null, 4));
267
- debugger;
268
- }
269
- console.log(content);
270
- return content.items();
271
- }
272
- async function dsCompute(store) {
273
- let log = null;
274
- debugger;
275
- let {compute} = await store.addServices('compute');
276
- let servers = await store.apiCall(compute.links('servers'));
277
-
278
- let contexts = await store.apiCall(compute.links('contexts'));
279
-
280
- // lookup the name of the first context and then use it to get the associated createSession restafLink
281
- let createSession = contexts.itemsCmd(
282
- contexts.itemsList(0),
283
- 'createSession'
284
- );
285
- let session = await store.apiCall(createSession);
286
-
287
- // Now run a simple data step in that session
288
- let payload = {
289
- data: {
290
- code: [`data _null_; do i = 1 to 100; x=1; end; run; `]
291
- }
292
- };
293
-
294
- // Now execute the data step and wait for completion
295
- let job = await store.apiCall(
296
- session.links('execute'),
297
- payload
298
- );
299
- let status = await store.jobState(job, null, 5, 2);
300
-
301
- if (status.data === 'running') {
302
- throw `ERROR: Job did not complete in allotted time`;
303
- } else {
304
- switch (status.data) {
305
- case 'warning':
306
- console.log(`Warning: check your log for warnings`);
307
- break;
308
- case 'error':
309
- throw `Please correct errors and rerun program`;
310
- default:
311
- log = await store.apiCall(status.job.links('log'));
312
- break;
313
- }
314
- }
315
- return log === null ? status : log.items();
316
- }
317
- </script>
318
- </head>
319
- <body onload="setup()">
320
- <h1 id="head">Hi</h1>
321
- <div>
322
- <button onclick="runit('redir')">
323
- Press to do some redirs
324
- </button>
325
- <button onclick="runit('files')">
326
- Press to make a call to file service
327
- </button>
328
- <br />
329
- <br />
330
- <button onclick="runit('compute')">
331
- Press to make a call compute service
332
- </button>
333
- <br />
334
- <br />
335
- <button onclick="runit('cas')">
336
- Press to make a call to cas echo
337
- </button>
338
- <br />
339
- <br />
340
- <button onclick="runit('spre')">
341
- REST call
342
- </button>
343
- <br />
344
- <br />
345
- <input id='filename'> </input>
346
- <button onclick="runit('timedout')">
347
- Press to test timedout
348
- </button>
349
- <br />
350
- <br />
351
- <button onclick="logoff()">
352
- logoff
353
- </button>
354
- <br />
355
- </div>
356
- <div>
357
- <pre id="output"></pre>
358
- </div>
359
- </body>
360
- </html>
1
+ <!DOCTYPE html>
2
+ <!--
3
+ ~ /* ------------------------------------------------------------------------------------
4
+ ~ * Copyright (c) SAS Institute Inc.
5
+ ~ * Licensed under the Apache License, Version 2.0 (the "License");
6
+ ~ * you may not use this file except in compliance with the License.
7
+ ~ * You may obtain a copy of the License at
8
+ ~ *
9
+ ~ * http://www.apache.org/licenses/LICENSE-2.0
10
+ ~ *
11
+ ~ * Unless required by applicable law or agreed to in writing, software
12
+ ~ * distributed under the License is distributed on an "AS IS" BASIS,
13
+ ~ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
+ ~ * See the License for the specific language governing permissions and
15
+ ~ * limitations under the License.
16
+ ~ ----------------------------------------------------------------------------------------*/
17
+ ~
18
+ -->
19
+
20
+ <html lang="en">
21
+
22
+ <head>
23
+ <meta charset="UTF-8" />
24
+ <title>index.html</title>
25
+
26
+ <script crossorigin src="https://unpkg.com/react@16/umd/react.production.min.js"></script>
27
+ <script crossorigin src="https://unpkg.com/react-dom@16/umd/react-dom.production.min.js"></script>
28
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-standalone/6.26.0/babel.min.js"></script>
29
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/babel-polyfill/6.26.0/polyfill.min.js"></script>
30
+ <script src="https://unpkg.com/@sassoftware/restaf@5.2.4"></script>
31
+ <script src="https://unpkg.com/@sassoftware/restaflib@5.2.4"></script>
32
+ <script src="/appenv"></script>
33
+
34
+ <style>
35
+ .container {
36
+ display: flex;
37
+ flex-direction: column;
38
+ flex-wrap: nowrap;
39
+ min-height: 800px;
40
+ }
41
+
42
+ .elabel {
43
+ display: inline-block;
44
+
45
+ clear: left;
46
+ width: 250px;
47
+ text-align: right;
48
+ }
49
+
50
+ .einput {
51
+ display: inline-block;
52
+ }
53
+
54
+ .div1 {
55
+ border: 1px solid black;
56
+ background: lightskyblue;
57
+ }
58
+
59
+ .div2 {
60
+ border: 1px solid black;
61
+ background: lightskyblue;
62
+ height: 200px;
63
+ }
64
+ </style>
65
+
66
+ <script>
67
+ debugger;
68
+ console.log(JSON.stringify(APPENV, null, 4));
69
+ let store = restaf.initStore({
70
+ casProxy: true,
71
+ options: {
72
+ proxyServer: APPENV.PROXYSERVER,
73
+ httpOptions: null
74
+ }
75
+ });
76
+ debugger; console.log(store.config);
77
+
78
+ let session = null;
79
+ let servers = null;
80
+ let services = null;
81
+ let files = null;
82
+ let reports = null;
83
+ let compute = null;
84
+
85
+ function setup() {
86
+ debugger;
87
+ document.getElementById('output').innerHTML = '...initializing';
88
+
89
+ initSession()
90
+ .then(r => {
91
+ document.getElementById('output').innerHTML = 'ready';
92
+ keepAlive();
93
+ })
94
+ .catch(e => {
95
+
96
+ console.log(e);
97
+ });
98
+ }
99
+ function keepAlive() {
100
+ if (LOGONPAYLOAD.keepAlive != null) {
101
+ let interval = 120;
102
+ let timeout = 14400;
103
+ if (LOGONPAYLOAD.timers != null) {
104
+ let opts = LOGONPAYLOAD.timers.split(',');
105
+ interval = parseInt(opts[0]);
106
+ timeout = parseInt(opts[1]);
107
+ }
108
+ console.log(`Keepalive is active`);
109
+ store.keepViyaAlive(LOGONPAYLOAD.keepAlive, interval, timeout, () => {
110
+ console.log('timed out at', Date());
111
+ let params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,width=0,height=0,left=-1000,top=-1000`;
112
+ window.open(`${appOptions.logonPayload.host}/SASLogon/timedout`, 'Timed Out', params);
113
+ return true;
114
+ });
115
+ }
116
+
117
+ }
118
+ function logoff() {
119
+ let url = `${window.location.protocol}//${window.location.host}/${LOGONPAYLOAD.appName}/logout?callbackUrl=onlogoff.html`;
120
+ window.location.replace(url);
121
+
122
+
123
+ }
124
+ async function initSession() {
125
+ debugger;
126
+ console.log(APPENV);
127
+ console.log(LOGONPAYLOAD);
128
+ debugger;
129
+ if (LOGONPAYLOAD.host == null) {
130
+ return 'done';
131
+ }
132
+ try {
133
+ let msg = await store.logon(LOGONPAYLOAD);
134
+ console.log(store.connection());
135
+ console.log(msg);
136
+ } catch (err) {
137
+ console.log('Error logging in', JSON.stringify(err, null, 4));
138
+ throw err;
139
+ }
140
+ let name = 'user';
141
+
142
+
143
+ //document.getElementById('output').innerHTML = '...running';
144
+ return 'done';
145
+ }
146
+ function runit(type) {
147
+ let testcase;
148
+ switch (type) {
149
+ case 'files': {
150
+ testcase = SASfileService;
151
+ break;
152
+ }
153
+ case 'compute': {
154
+ testcase = dsCompute;
155
+ break;
156
+ }
157
+ case 'cas': {
158
+ testcase = runCas;
159
+ break;
160
+ }
161
+ case 'timedout': {
162
+ testcase = timedout;
163
+ break;
164
+ }
165
+ case 'redir': {
166
+ testcase = noaction;
167
+
168
+ break;
169
+ }
170
+ case 'spre': {
171
+ testcase = spre;
172
+
173
+ break;
174
+ }
175
+ default: {
176
+ testcase = SASfileService;
177
+ break;
178
+ }
179
+ }
180
+
181
+ testcase(store)
182
+ .then(r => {
183
+ document.getElementById(
184
+ 'output'
185
+ ).innerHTML = JSON.stringify(r, null, 4);
186
+ })
187
+ .catch(err => {
188
+
189
+ document.getElementById(
190
+ 'output'
191
+ ).innerHTML = JSON.stringify(err, null, 4);
192
+ });
193
+ }
194
+ async function noaction() {
195
+ r = { msg: 'redirects completed' };
196
+ return r;
197
+ }
198
+ async function spre(store) {
199
+ let p = {
200
+ method: 'GET',
201
+ url: 'http://localhost:3000/api/test',
202
+ withCredentials: true
203
+ }
204
+ let r = await store.request(p);
205
+ return r.data;
206
+ }
207
+ async function timedout(store) {
208
+ console.log('timed out at', Date());
209
+ let params = `scrollbars=no,resizable=no,status=no,location=no,toolbar=no,menubar=no,width=0,height=0,left=-1000,top=-1000`;
210
+ window.open(`${LOGONPAYLOAD.host}/SASLogon/timedout`, 'Timed Out', params);
211
+ return true;
212
+ }
213
+ async function runCas(store) {
214
+ debugger;
215
+ let { casManagement } = await store.addServices('casManagement');
216
+ let servers = await store.apiCall(
217
+ casManagement.links('servers')
218
+ );
219
+ let serverName = servers.itemsList(0);
220
+ let session = await store.apiCall(
221
+ servers.itemsCmd(serverName, 'createSession')
222
+ );
223
+ let payload = {
224
+ action: 'builtins.echo',
225
+ data: { code: { x: 1 } }
226
+ };
227
+ console.log(JSON.stringify(session.links("execute"), null, 4));
228
+ let r = await store.runAction(session, payload);
229
+ console.log('echo completed');
230
+ await store.apiCall(session.links('delete'));
231
+ return r.items();
232
+ }
233
+
234
+ async function SASfileService(store) {
235
+ debugger;
236
+ let content;
237
+ try {
238
+ debugger;
239
+ let { files } = await store.addServices('files');
240
+ debugger;
241
+ console.log(JSON.stringify(files.links(), null, 4));
242
+ //console.log('items - should be an array of files(empty array is ok)')
243
+ // console.log(files.items().toJS());
244
+ let payload = {
245
+ data: { x: 1, y: 'This was saved earlier in the step' },
246
+ headers: { 'content-type': 'application/json' }
247
+ };
248
+ let createCmd = files.links('create');
249
+ let newFile = await store.apiCall(createCmd, payload);
250
+ debugger;
251
+ console.log(JSON.stringify(newFile.links('content'), null, 4));
252
+ content = await store.apiCall(newFile.links('content'));
253
+
254
+ } catch (err) {
255
+ console.log(JSON.stringify(err, null, 4));
256
+ debugger;
257
+ }
258
+ console.log(content);
259
+ return content.items();
260
+ }
261
+ async function dsCompute(store) {
262
+ let log = null;
263
+ debugger;
264
+ let { compute } = await store.addServices('compute');
265
+ let servers = await store.apiCall(compute.links('servers'));
266
+
267
+ let contexts = await store.apiCall(compute.links('contexts'));
268
+
269
+ // lookup the name of the first context and then use it to get the associated createSession restafLink
270
+ let createSession = contexts.itemsCmd(
271
+ contexts.itemsList(0),
272
+ 'createSession'
273
+ );
274
+ let session = await store.apiCall(createSession);
275
+ let v = document.getElementById('computeInput').value;
276
+ console.log(v);
277
+ // Now run a simple data step in that session
278
+ let payload = {
279
+ data: {
280
+ code: [ `%let dsname = ${v} ; data work.&dsname; do i = 1 to 20; x=1; end; run;
281
+ proc print; run;`
282
+ ]
283
+ }
284
+ };
285
+ console.log(payload);
286
+ // Now execute the data step and wait for completion
287
+ let job = await store.apiCall(
288
+ session.links('execute'),
289
+ payload
290
+ );
291
+ let status = await store.jobState(job, null, 5, 2);
292
+
293
+ if (status.data === 'running') {
294
+ throw `ERROR: Job did not complete in allotted time`;
295
+ } else {
296
+ switch (status.data) {
297
+ case 'warning':
298
+ console.log(`Warning: check your log for warnings`);
299
+ break;
300
+ case 'error':
301
+ throw `Please correct errors and rerun program`;
302
+ default:
303
+ log = await store.apiCall(status.job.links('log'));
304
+ break;
305
+ }
306
+ }
307
+ return log === null ? status : log.items();
308
+ }
309
+ </script>
310
+ </head>
311
+
312
+ <body onload="setup()">
313
+ <h1 id="head">Hi</h1>
314
+ <div>
315
+ <button onclick="runit('redir')">
316
+ Press to do some redirs
317
+ </button>
318
+ <button onclick="runit('files')">
319
+ Press to make a call to file service
320
+ </button>
321
+ <br />
322
+ <br />
323
+ <input id='computeInput'> </input>
324
+ <button onclick="runit('compute')">
325
+ Press to make a call compute service
326
+ </button>
327
+ <br />
328
+ <br />
329
+ <button onclick="runit('cas')">
330
+ Press to make a call to cas echo
331
+ </button>
332
+ <br />
333
+ <br />
334
+ <button onclick="runit('spre')">
335
+ REST call
336
+ </button>
337
+ <br />
338
+ <br />
339
+ <input id='filename'> </input>
340
+ <button onclick="runit('timedout')">
341
+ Press to test timedout
342
+ </button>
343
+ <br />
344
+ <br />
345
+ <button onclick="logoff()">
346
+ logoff
347
+ </button>
348
+ <br />
349
+ </div>
350
+ <div>
351
+ <pre id="output"></pre>
352
+ </div>
353
+ </body>
354
+
355
+ </html>