@fjell/client-api 4.4.0 → 4.4.2

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 (57) hide show
  1. package/.kodrdriv/config.yaml +10 -0
  2. package/.kodrdriv/context/content.md +1 -0
  3. package/dist/AItemAPI.js +3 -1
  4. package/dist/AItemAPI.js.map +1 -0
  5. package/dist/CItemAPI.d.ts +11 -9
  6. package/dist/CItemAPI.js +4 -2
  7. package/dist/CItemAPI.js.map +1 -0
  8. package/dist/ClientApi.d.ts +11 -9
  9. package/dist/PItemAPI.d.ts +12 -10
  10. package/dist/PItemAPI.js +6 -2
  11. package/dist/PItemAPI.js.map +1 -0
  12. package/dist/Utilities.js +1 -1
  13. package/dist/Utilities.js.map +1 -0
  14. package/dist/index.cjs +486 -0
  15. package/dist/index.cjs.map +1 -0
  16. package/dist/index.js +1 -1
  17. package/dist/index.js.map +1 -0
  18. package/dist/logger.js +2 -2
  19. package/dist/logger.js.map +1 -0
  20. package/dist/ops/action.js +1 -1
  21. package/dist/ops/action.js.map +1 -0
  22. package/dist/ops/all.js +1 -1
  23. package/dist/ops/all.js.map +1 -0
  24. package/dist/ops/allAction.js +1 -1
  25. package/dist/ops/allAction.js.map +1 -0
  26. package/dist/ops/create.js +1 -1
  27. package/dist/ops/create.js.map +1 -0
  28. package/dist/ops/facet.d.ts +5 -0
  29. package/dist/ops/facet.js +32 -0
  30. package/dist/ops/facet.js.map +1 -0
  31. package/dist/ops/find.js +1 -1
  32. package/dist/ops/find.js.map +1 -0
  33. package/dist/ops/findOne.d.ts +5 -0
  34. package/dist/ops/findOne.js +26 -0
  35. package/dist/ops/findOne.js.map +1 -0
  36. package/dist/ops/get.js +1 -1
  37. package/dist/ops/get.js.map +1 -0
  38. package/dist/ops/index.js +5 -1
  39. package/dist/ops/index.js.map +1 -0
  40. package/dist/ops/one.d.ts +1 -1
  41. package/dist/ops/one.js +2 -2
  42. package/dist/ops/one.js.map +1 -0
  43. package/dist/ops/remove.js +1 -1
  44. package/dist/ops/remove.js.map +1 -0
  45. package/dist/ops/update.js +1 -1
  46. package/dist/ops/update.js.map +1 -0
  47. package/package.json +25 -25
  48. package/src/AItemAPI.ts +12 -9
  49. package/src/CItemAPI.ts +27 -19
  50. package/src/ClientApi.ts +25 -14
  51. package/src/PItemAPI.ts +63 -35
  52. package/src/Utilities.ts +47 -47
  53. package/src/logger.ts +1 -1
  54. package/src/ops/facet.ts +59 -0
  55. package/src/ops/findOne.ts +52 -0
  56. package/src/ops/index.ts +74 -61
  57. package/src/ops/one.ts +22 -23
package/dist/index.cjs ADDED
@@ -0,0 +1,486 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
4
+
5
+ const core = require('@fjell/core');
6
+ const Logging = require('@fjell/logging');
7
+ const deepmerge = require('deepmerge');
8
+
9
+ const LibLogger = Logging.getLogger('@fjell/client-api');
10
+
11
+ const logger$e = LibLogger.get('client-api', 'ops', 'all');
12
+ const getAllOperation = (api, apiOptions, utilities)=>{
13
+ const all = async (query = {}, options = {}, locations = [])=>{
14
+ logger$e.default('all', {
15
+ query,
16
+ locations
17
+ });
18
+ utilities.verifyLocations(locations);
19
+ const loc = locations;
20
+ const params = core.queryToParams(query);
21
+ const requestOptions = Object.assign({}, options, {
22
+ isAuthenticated: apiOptions.allAuthenticated,
23
+ params
24
+ });
25
+ return utilities.validatePK(await utilities.processArray(api.httpGet(utilities.getPath(loc), requestOptions)));
26
+ };
27
+ return all;
28
+ };
29
+
30
+ const logger$d = LibLogger.get('client-api', 'ops', 'action');
31
+ const getActionOperation = (api, apiOptions, utilities)=>{
32
+ const action = async (ik, action, body = {}, options = {})=>{
33
+ logger$d.default('action', {
34
+ ik,
35
+ action,
36
+ body
37
+ });
38
+ const requestOptions = Object.assign({}, options, {
39
+ isAuthenticated: apiOptions.writeAuthenticated
40
+ });
41
+ return utilities.validatePK(await utilities.processOne(api.httpPost(`${utilities.getPath(ik)}/${action}`, body, requestOptions)));
42
+ };
43
+ return action;
44
+ };
45
+
46
+ const logger$c = LibLogger.get('client-api', 'ops', 'allAction');
47
+ const getAllActionOperation = (api, apiOptions, utilities)=>{
48
+ const allAction = async (action, body = {}, options = {}, locations = [])=>{
49
+ logger$c.default('allAction', {
50
+ action,
51
+ body,
52
+ locations
53
+ });
54
+ utilities.verifyLocations(locations);
55
+ const loc = locations;
56
+ const requestOptions = Object.assign({}, options, {
57
+ isAuthenticated: apiOptions.writeAuthenticated
58
+ });
59
+ // TODO: This should respond to either a single object, or multiple objects in an array.
60
+ return utilities.validatePK(await utilities.processArray(api.httpPost(utilities.getPath(loc), body, requestOptions)));
61
+ };
62
+ return allAction;
63
+ };
64
+
65
+ const logger$b = LibLogger.get('client-api', 'ops', 'one');
66
+ const getOneOperation = (api, apiOptions, utilities)=>{
67
+ const one = async (query = {}, options = {}, locations = [])=>{
68
+ logger$b.default('one', {
69
+ query,
70
+ locations
71
+ });
72
+ utilities.verifyLocations(locations);
73
+ const loc = locations;
74
+ const params = core.queryToParams(query);
75
+ const requestOptions = Object.assign({}, options, {
76
+ isAuthenticated: apiOptions.readAuthenticated,
77
+ params
78
+ });
79
+ let item = null;
80
+ const items = utilities.validatePK(await utilities.processArray(api.httpGet(utilities.getPath(loc), requestOptions)));
81
+ if (items.length > 0) {
82
+ item = items[0];
83
+ }
84
+ return item;
85
+ };
86
+ return one;
87
+ };
88
+
89
+ const logger$a = LibLogger.get('client-api', 'ops', 'create');
90
+ const getCreateOperation = (api, apiOptions, utilities)=>{
91
+ const create = async (item, options = {}, locations = [])=>{
92
+ logger$a.default('create', {
93
+ item,
94
+ locations
95
+ });
96
+ utilities.verifyLocations(locations);
97
+ const loc = locations;
98
+ const requestOptions = Object.assign({}, options, {
99
+ isAuthenticated: apiOptions.writeAuthenticated
100
+ });
101
+ const created = utilities.validatePK(await utilities.processOne(api.httpPost(utilities.getPath(loc), item, requestOptions)));
102
+ return created;
103
+ };
104
+ return create;
105
+ };
106
+
107
+ const logger$9 = LibLogger.get('client-api', 'ops', 'update');
108
+ const getUpdateOperation = (api, apiOptions, utilities)=>{
109
+ const update = async (ik, item, options = {})=>{
110
+ logger$9.default('update', {
111
+ ik,
112
+ item
113
+ });
114
+ const requestOptions = Object.assign({}, options, {
115
+ isAuthenticated: apiOptions.writeAuthenticated
116
+ });
117
+ return utilities.validatePK(await utilities.processOne(api.httpPut(utilities.getPath(ik), item, requestOptions)));
118
+ };
119
+ return update;
120
+ };
121
+
122
+ const logger$8 = LibLogger.get('client-api', 'ops', 'get');
123
+ const getGetOperation = (api, apiOptions, utilities)=>{
124
+ const get = async (ik, options = {})=>{
125
+ logger$8.default('get', {
126
+ ik
127
+ });
128
+ const requestOptions = Object.assign({}, options, {
129
+ isAuthenticated: apiOptions.readAuthenticated
130
+ });
131
+ return utilities.validatePK(await utilities.processOne(api.httpGet(utilities.getPath(ik), requestOptions)));
132
+ };
133
+ return get;
134
+ };
135
+
136
+ const logger$7 = LibLogger.get('client-api', 'ops', 'remove');
137
+ const getRemoveOperation = (api, apiOptions, utilities)=>{
138
+ const remove = async (ik, options = {})=>{
139
+ logger$7.default('remove', {
140
+ ik
141
+ });
142
+ const requestOptions = Object.assign({}, options, {
143
+ isAuthenticated: apiOptions.writeAuthenticated
144
+ });
145
+ return api.httpDelete(utilities.getPath(ik), requestOptions);
146
+ };
147
+ return remove;
148
+ };
149
+
150
+ const logger$6 = LibLogger.get('client-api', 'ops', 'find');
151
+ const getFindOperation = (api, apiOptions, utilities)=>{
152
+ const find = async (finder, finderParams, options = {}, locations = [])=>{
153
+ logger$6.default('find', {
154
+ finder,
155
+ finderParams,
156
+ locations
157
+ });
158
+ utilities.verifyLocations(locations);
159
+ const loc = locations;
160
+ const params = finderToParams(finder, finderParams);
161
+ const requestOptions = Object.assign({}, options, {
162
+ isAuthenticated: apiOptions.allAuthenticated,
163
+ params
164
+ });
165
+ return utilities.validatePK(await utilities.processArray(api.httpGet(utilities.getPath(loc), requestOptions)));
166
+ };
167
+ return find;
168
+ };
169
+
170
+ const logger$5 = LibLogger.get('client-api', 'ops', 'find');
171
+ const getFindOneOperation = (api, apiOptions, utilities)=>{
172
+ const findOne = async (finder, finderParams, options = {}, locations = [])=>{
173
+ logger$5.default('findOne', {
174
+ finder,
175
+ finderParams,
176
+ locations
177
+ });
178
+ utilities.verifyLocations(locations);
179
+ const loc = locations;
180
+ const params = finderToParams(finder, finderParams);
181
+ params.one = true;
182
+ const requestOptions = Object.assign({}, options, {
183
+ isAuthenticated: apiOptions.allAuthenticated,
184
+ params
185
+ });
186
+ return utilities.validatePK(await utilities.processArray(api.httpGet(utilities.getPath(loc), requestOptions)))[0];
187
+ };
188
+ return findOne;
189
+ };
190
+
191
+ const logger$4 = LibLogger.get('client-api', 'ops', 'facet');
192
+ const getFacetOperation = (api, apiOptions, utilities)=>{
193
+ /**
194
+ * Executes a facet operation on an item.
195
+ *
196
+ * A facet is a piece of information that is related to an item - it represents
197
+ * a specific aspect or characteristic of the item. Unlike actions which may
198
+ * return items or perform operations, facets are informational queries that
199
+ * return data about a particular facet of an item.
200
+ *
201
+ * @param ik - The item key (composite or primary key) identifying the item
202
+ * @param facet - The name of the facet to query
203
+ * @param body - Optional request body for the facet operation
204
+ * @param options - Optional HTTP request options
205
+ * @returns Promise resolving to the facet data
206
+ */ const facet = async (ik, facet, options = {})=>{
207
+ logger$4.default('facet', {
208
+ ik,
209
+ facet
210
+ });
211
+ const requestOptions = Object.assign({}, options, {
212
+ isAuthenticated: apiOptions.writeAuthenticated
213
+ });
214
+ return api.httpGet(`${utilities.getPath(ik)}/${facet}`, requestOptions);
215
+ };
216
+ return facet;
217
+ };
218
+
219
+ const getOperations = (api, apiOptions, utilities)=>{
220
+ return {
221
+ action: getActionOperation(api, apiOptions, utilities),
222
+ all: getAllOperation(api, apiOptions, utilities),
223
+ allAction: getAllActionOperation(api, apiOptions, utilities),
224
+ create: getCreateOperation(api, apiOptions, utilities),
225
+ facet: getFacetOperation(api, apiOptions, utilities),
226
+ findOne: getFindOneOperation(api, apiOptions, utilities),
227
+ find: getFindOperation(api, apiOptions, utilities),
228
+ get: getGetOperation(api, apiOptions, utilities),
229
+ one: getOneOperation(api, apiOptions, utilities),
230
+ remove: getRemoveOperation(api, apiOptions, utilities),
231
+ update: getUpdateOperation(api, apiOptions, utilities)
232
+ };
233
+ };
234
+
235
+ const logger$3 = LibLogger.get('client-api', 'Utility');
236
+ const createUtilities = (pkType, pathNames)=>{
237
+ logger$3.default('createUtilities', {
238
+ pkType,
239
+ pathNames
240
+ });
241
+ const verifyLocations = (locations)=>{
242
+ if (locations && locations.length < pathNames.length - 1) {
243
+ throw new Error('Not enough locations for pathNames: locations:' + locations.length + ' pathNames:' + pathNames.length);
244
+ }
245
+ return true;
246
+ };
247
+ const processOne = async (apiCall)=>{
248
+ logger$3.default('processOne', {
249
+ apiCall
250
+ });
251
+ const response = await apiCall;
252
+ logger$3.default('processOne response', {
253
+ response: JSON.stringify(response, null, 2)
254
+ });
255
+ return convertDoc(response);
256
+ };
257
+ const processArray = async (api)=>{
258
+ logger$3.default('processArray', {
259
+ api
260
+ });
261
+ const response = await api;
262
+ logger$3.default('processArray response', {
263
+ response: JSON.stringify(response, null, 2)
264
+ });
265
+ if (response && Array.isArray(response)) {
266
+ return response.map((subjectChat)=>convertDoc(subjectChat));
267
+ } else {
268
+ logger$3.error('Response was not an array', {
269
+ response
270
+ });
271
+ throw new Error('Response was not an array');
272
+ }
273
+ };
274
+ const convertDoc = (doc)=>{
275
+ logger$3.default('convertDoc', {
276
+ doc
277
+ });
278
+ // console.log(JSON.stringify(doc, null, 2));
279
+ if (doc && doc.events) {
280
+ const events = doc.events;
281
+ for(const key in events){
282
+ events[key] = deepmerge(events[key], {
283
+ at: events[key].at ? new Date(events[key].at) : null
284
+ });
285
+ }
286
+ return doc;
287
+ } else {
288
+ return doc;
289
+ }
290
+ };
291
+ const getPath = (key)=>{
292
+ const localPathNames = [
293
+ ...pathNames
294
+ ];
295
+ logger$3.default('getPath', {
296
+ key,
297
+ pathNames: localPathNames
298
+ });
299
+ // console.log('getPath key: ' + JSON.stringify(key));
300
+ const keys = core.generateKeyArray(key);
301
+ // console.log('getPath keys: ' + JSON.stringify(keys));
302
+ // console.log('getPath pathNames: ' + JSON.stringify(pathNames));
303
+ let path = addPath('', keys, localPathNames);
304
+ // If there is only one collection left in the collections array, this means that
305
+ // we received LocKeys and we need to add the last collection to the reference
306
+ if (localPathNames.length === 1) {
307
+ path = `${path}/${localPathNames[0]}`;
308
+ }
309
+ logger$3.default('getPath created', {
310
+ key,
311
+ path
312
+ });
313
+ return path;
314
+ };
315
+ const addPath = (base, keys, localPathNames)=>{
316
+ logger$3.default('addPath', {
317
+ base,
318
+ keys,
319
+ pathNames: localPathNames
320
+ });
321
+ if (keys.length < localPathNames.length - 1) {
322
+ logger$3.error('addPath should never have keys with a length less than the length of pathNames - 1', {
323
+ keys,
324
+ localPathNames
325
+ });
326
+ throw new Error('addPath should never have keys with a length less than the length of pathNames - 1: ' + keys.length + ' ' + localPathNames.length + ' ' + JSON.stringify(keys, localPathNames));
327
+ } else if (keys.length > localPathNames.length) {
328
+ logger$3.error('addPath should never have keys with a length greater than the length of pathNames', {
329
+ keys,
330
+ pathNames
331
+ });
332
+ throw new Error('addPath should never have keys with a length greater than the length of pathNames: ' + keys.length + ' ' + localPathNames.length + ' ' + JSON.stringify(keys, localPathNames));
333
+ }
334
+ if (keys.length === 0) {
335
+ // If you've recursively consumed all of the keys, return the base.
336
+ logger$3.default('addPath returning base', {
337
+ base
338
+ });
339
+ return base;
340
+ } else {
341
+ // Retrieve the next key and collection, and create the next base
342
+ let nextBase;
343
+ const key = keys.pop();
344
+ const pathName = localPathNames.pop();
345
+ if (core.isPriKey(key)) {
346
+ const PriKey = key;
347
+ nextBase = `${base}/${pathName}/${PriKey.pk}`;
348
+ logger$3.default('Adding Path for PK', {
349
+ pathName,
350
+ PriKey,
351
+ nextBase
352
+ });
353
+ } else {
354
+ const LocKey = key;
355
+ nextBase = `${base}/${pathName}/${LocKey.lk}`;
356
+ logger$3.default('Retrieving Collection for LK', {
357
+ pathName,
358
+ LocKey
359
+ });
360
+ }
361
+ logger$3.default('calling addPath recursively', {
362
+ nextBase,
363
+ keys,
364
+ localPathNames
365
+ });
366
+ return addPath(nextBase, keys, localPathNames);
367
+ }
368
+ };
369
+ const validatePK = (item)=>{
370
+ return core.validatePK(item, pkType);
371
+ };
372
+ return {
373
+ verifyLocations,
374
+ processOne,
375
+ convertDoc,
376
+ processArray,
377
+ getPath,
378
+ validatePK
379
+ };
380
+ };
381
+
382
+ const logger$2 = LibLogger.get('AItemAPI');
383
+ const finderToParams = (finder, finderParams)=>{
384
+ return {
385
+ finder,
386
+ finderParams: JSON.stringify(finderParams)
387
+ };
388
+ };
389
+ const createAItemAPI = (api, pkType, pathNames, options)=>{
390
+ logger$2.default('createAItemAPI', {
391
+ pkType,
392
+ pathNames,
393
+ options
394
+ });
395
+ let mergedOptions;
396
+ const defaultOptions = {
397
+ readAuthenticated: true,
398
+ allAuthenticated: true,
399
+ writeAuthenticated: true
400
+ };
401
+ if (options) {
402
+ mergedOptions = Object.assign({}, defaultOptions, options);
403
+ } else {
404
+ mergedOptions = defaultOptions;
405
+ }
406
+ const utilities = createUtilities(pkType, pathNames);
407
+ const operations = getOperations(api, mergedOptions, utilities);
408
+ return {
409
+ action: operations.action,
410
+ all: operations.all,
411
+ allAction: operations.allAction,
412
+ create: operations.create,
413
+ facet: operations.facet,
414
+ find: operations.find,
415
+ findOne: operations.findOne,
416
+ get: operations.get,
417
+ one: operations.one,
418
+ remove: operations.remove,
419
+ update: operations.update
420
+ };
421
+ };
422
+
423
+ const logger$1 = LibLogger.get('CItemAPI');
424
+ const createCItemApi = (api, type, pathNames, options)=>{
425
+ logger$1.default('createCItemApi', {
426
+ api,
427
+ type,
428
+ pathNames,
429
+ options
430
+ });
431
+ const aItemAPI = createAItemAPI(api, type, pathNames, options);
432
+ return {
433
+ action: aItemAPI.action,
434
+ all: aItemAPI.all,
435
+ allAction: aItemAPI.allAction,
436
+ one: aItemAPI.one,
437
+ get: aItemAPI.get,
438
+ create: aItemAPI.create,
439
+ remove: aItemAPI.remove,
440
+ update: aItemAPI.update,
441
+ facet: aItemAPI.facet,
442
+ find: aItemAPI.find,
443
+ findOne: aItemAPI.findOne
444
+ };
445
+ };
446
+
447
+ const logger = LibLogger.get('PItemAPI');
448
+ const createPItemApi = (api, type, pathName, options)=>{
449
+ logger.default('createPItemApi', {
450
+ type,
451
+ pathName,
452
+ options
453
+ });
454
+ const aItemAPI = createAItemAPI(api, type, [
455
+ pathName
456
+ ], options);
457
+ const action = async (ik, action, body = {}, options = {})=>await aItemAPI.action(ik, action, body, options);
458
+ const all = async (query = {}, options = {})=>await aItemAPI.all(query, options, []);
459
+ const allAction = async (action, body = {}, options = {})=>await aItemAPI.allAction(action, body, options, []);
460
+ const one = async (query = {}, options = {})=>await aItemAPI.one(query, options, []);
461
+ const get = async (ik, options = {})=>await aItemAPI.get(ik, options);
462
+ const create = async (item, options = {})=>await aItemAPI.create(item, options, []);
463
+ const remove = async (ik, options = {})=>await aItemAPI.remove(ik, options);
464
+ const update = async (ik, item, options = {})=>await aItemAPI.update(ik, item, options);
465
+ const facet = async (ik, facet, options = {})=>await aItemAPI.facet(ik, facet, options);
466
+ const find = async (finder, finderParams, options = {})=>await aItemAPI.find(finder, finderParams, options, []);
467
+ const findOne = async (finder, finderParams, options = {})=>await aItemAPI.findOne(finder, finderParams, options, []);
468
+ return {
469
+ ...aItemAPI,
470
+ action,
471
+ all,
472
+ allAction,
473
+ one,
474
+ get,
475
+ create,
476
+ remove,
477
+ update,
478
+ facet,
479
+ find,
480
+ findOne
481
+ };
482
+ };
483
+
484
+ exports.createCItemApi = createCItemApi;
485
+ exports.createPItemApi = createPItemApi;
486
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../src/logger.ts","../src/ops/all.ts","../src/ops/action.ts","../src/ops/allAction.ts","../src/ops/one.ts","../src/ops/create.ts","../src/ops/update.ts","../src/ops/get.ts","../src/ops/remove.ts","../src/ops/find.ts","../src/ops/findOne.ts","../src/ops/facet.ts","../src/ops/index.ts","../src/Utilities.ts","../src/AItemAPI.ts","../src/CItemAPI.ts","../src/PItemAPI.ts"],"sourcesContent":["import Logging from '@fjell/logging';\n\nconst LibLogger = Logging.getLogger('@fjell/client-api');\n\nexport default LibLogger;\n","import {\n Item,\n ItemQuery,\n LocKeyArray,\n queryToParams,\n} from \"@fjell/core\";\nimport { HttpApi, QueryParams } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\nimport { GetMethodOptions } from \"@fjell/http-api\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'all');\n\nexport const getAllOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const all = async (\n query: ItemQuery = {} as ItemQuery,\n options: Partial<GetMethodOptions> = {},\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] = []\n ): Promise<V[]> => {\n logger.default('all', { query, locations });\n utilities.verifyLocations(locations);\n const loc: LocKeyArray<L1, L2, L3, L4, L5> | [] = locations;\n \n const params: QueryParams = queryToParams(query);\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.allAuthenticated, params });\n \n return utilities.validatePK(await utilities.processArray(\n api.httpGet<V[]>(\n utilities.getPath(loc),\n requestOptions,\n ))) as V[];\n }\n\n return all;\n}\n \n","import {\n ComKey,\n Item,\n PriKey,\n} from \"@fjell/core\";\nimport { HttpApi, PostMethodOptions } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'action');\n \nexport const getActionOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const action = async (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n action: string,\n body: any = {},\n options: Partial<PostMethodOptions> = {}\n ):\n Promise<V> => {\n logger.default('action', { ik, action, body });\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n \n return utilities.validatePK(\n await utilities.processOne(\n api.httpPost<V>(\n `${utilities.getPath(ik)}/${action}`,\n body,\n requestOptions,\n )\n )) as V;\n \n };\n \n return action;\n}\n ","import {\n Item,\n LocKeyArray\n} from \"@fjell/core\";\nimport { HttpApi, PostMethodOptions } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'allAction');\n \nexport const getAllActionOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const allAction = async (\n action: string,\n body: any = {},\n options: Partial<PostMethodOptions> = {},\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] = []\n ): Promise<V[]> => {\n logger.default('allAction', { action, body, locations });\n utilities.verifyLocations(locations);\n \n const loc: LocKeyArray<L1, L2, L3, L4, L5> | [] = locations;\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n \n // TODO: This should respond to either a single object, or multiple objects in an array.\n return utilities.validatePK(\n await utilities.processArray(\n api.httpPost<V[]>(\n utilities.getPath(loc),\n body,\n requestOptions,\n )\n )) as V[];\n };\n \n return allAction;\n}\n ","import {\n Item,\n ItemQuery,\n LocKeyArray,\n QueryParams,\n queryToParams\n} from \"@fjell/core\";\nimport { GetMethodOptions, HttpApi } from \"@fjell/http-api\";\n\nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n\nconst logger = LibLogger.get('client-api', 'ops', 'one');\n\nexport const getOneOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n\n ): (\n query: ItemQuery,\n options?: Partial<GetMethodOptions>,\n locations?: LocKeyArray<L1, L2, L3, L4, L5> | []\n ) => Promise<V | null> => {\n\n const one = async (\n query: ItemQuery = {} as ItemQuery,\n options: Partial<GetMethodOptions> = {},\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] = []\n ): Promise<V | null> => {\n logger.default('one', { query, locations });\n utilities.verifyLocations(locations);\n\n const loc: LocKeyArray<L1, L2, L3, L4, L5> | [] = locations;\n\n const params: QueryParams = queryToParams(query);\n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.readAuthenticated, params });\n\n let item: V | null = null;\n\n const items = utilities.validatePK(await utilities.processArray(\n api.httpGet<V[]>(\n utilities.getPath(loc),\n requestOptions,\n ))) as V[];\n\n if (items.length > 0) {\n item = items[0];\n }\n\n return item as V;\n }\n\n return one;\n}\n","import {\n Item,\n ItemProperties,\n LocKeyArray\n} from \"@fjell/core\";\nimport { HttpApi, PostMethodOptions } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'create');\n\nexport const getCreateOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const create = async (\n item: ItemProperties<S, L1, L2, L3, L4, L5>,\n options: Partial<PostMethodOptions> = {},\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] = []\n ): Promise<V> => {\n logger.default('create', { item, locations });\n utilities.verifyLocations(locations);\n \n const loc: LocKeyArray<L1, L2, L3, L4, L5> | [] = locations;\n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n \n const created: V =\n utilities.validatePK(await utilities.processOne(api.httpPost<V>(\n utilities.getPath(loc),\n item,\n requestOptions,\n ))) as V;\n return created;\n };\n\n return create;\n}\n ","import {\n ComKey,\n Item,\n ItemProperties,\n PriKey\n} from \"@fjell/core\";\nimport { HttpApi, PutMethodOptions } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'update');\n \nexport const getUpdateOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const update = async (\n ik: PriKey<S> | ComKey<S, L1, L2, L3, L4, L5>,\n item: ItemProperties<S, L1, L2, L3, L4, L5>,\n options: Partial<PutMethodOptions> = {},\n ): Promise<V> => {\n logger.default('update', { ik, item });\n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n \n return utilities.validatePK(await utilities.processOne(\n api.httpPut<V>(\n utilities.getPath(ik),\n item,\n requestOptions,\n ))) as V;\n }\n \n return update;\n}\n ","import {\n ComKey,\n Item,\n PriKey,\n} from \"@fjell/core\";\nimport { GetMethodOptions, HttpApi } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'get');\n \nexport const getGetOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const get = async (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n options: Partial<GetMethodOptions> = {},\n ): Promise<V | null> => {\n logger.default('get', { ik });\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.readAuthenticated });\n \n return utilities.validatePK(await utilities.processOne(\n api.httpGet<V>(\n utilities.getPath(ik),\n requestOptions,\n ))) as V;\n }\n \n return get;\n}\n ","import {\n ComKey,\n Item,\n PriKey,\n} from \"@fjell/core\";\nimport { DeleteMethodOptions, HttpApi } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'remove');\n \nexport const getRemoveOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const remove = async (\n ik: PriKey<S> | ComKey<S, L1, L2, L3, L4, L5>,\n options: Partial<DeleteMethodOptions> = {},\n ): Promise<boolean> => {\n logger.default('remove', { ik });\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n \n return api.httpDelete<boolean>(utilities.getPath(ik), requestOptions);\n }\n \n return remove;\n}\n ","import {\n Item,\n LocKeyArray,\n QueryParams\n} from \"@fjell/core\";\nimport { GetMethodOptions, HttpApi } from \"@fjell/http-api\";\n \nimport { finderToParams } from \"@/AItemAPI\";\nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'find');\n \nexport const getFindOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const find = async (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options: Partial<GetMethodOptions> = {},\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] = []\n ): Promise<V[]> => {\n logger.default('find', { finder, finderParams, locations });\n utilities.verifyLocations(locations);\n const loc: LocKeyArray<L1, L2, L3, L4, L5> | [] = locations;\n \n const params: QueryParams = finderToParams(finder, finderParams);\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.allAuthenticated, params });\n \n return utilities.validatePK(await utilities.processArray(\n api.httpGet<V[]>(\n utilities.getPath(loc),\n requestOptions,\n ))) as V[];\n }\n \n return find;\n}\n ","import {\n Item,\n LocKeyArray,\n QueryParams\n} from \"@fjell/core\";\nimport { GetMethodOptions, HttpApi } from \"@fjell/http-api\";\n\nimport { finderToParams } from \"@/AItemAPI\";\nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n\nconst logger = LibLogger.get('client-api', 'ops', 'find');\n\nexport const getFindOneOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n\n ) => {\n\n const findOne = async (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options: Partial<GetMethodOptions> = {},\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] = []\n ): Promise<V> => {\n logger.default('findOne', { finder, finderParams, locations });\n utilities.verifyLocations(locations);\n const loc: LocKeyArray<L1, L2, L3, L4, L5> | [] = locations;\n\n const params: QueryParams = finderToParams(finder, finderParams);\n params.one = true;\n\n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.allAuthenticated, params });\n\n return (utilities.validatePK(await utilities.processArray(\n api.httpGet<V[]>(\n utilities.getPath(loc),\n requestOptions,\n ))) as V[])[0];\n }\n\n return findOne;\n}\n","import {\n ComKey,\n Item,\n PriKey,\n} from \"@fjell/core\";\nimport { GetMethodOptions, HttpApi } from \"@fjell/http-api\";\n\nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n\nconst logger = LibLogger.get('client-api', 'ops', 'facet');\n\nexport const getFacetOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n\n ) => {\n\n /**\n * Executes a facet operation on an item.\n *\n * A facet is a piece of information that is related to an item - it represents\n * a specific aspect or characteristic of the item. Unlike actions which may\n * return items or perform operations, facets are informational queries that\n * return data about a particular facet of an item.\n *\n * @param ik - The item key (composite or primary key) identifying the item\n * @param facet - The name of the facet to query\n * @param body - Optional request body for the facet operation\n * @param options - Optional HTTP request options\n * @returns Promise resolving to the facet data\n */\n const facet = async (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n facet: string,\n options: Partial<GetMethodOptions> = {}\n ): Promise<any> => {\n logger.default('facet', { ik, facet });\n\n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n\n return api.httpGet<any>(\n `${utilities.getPath(ik)}/${facet}`,\n requestOptions,\n );\n\n };\n\n return facet;\n}\n","/* eslint-disable indent */\nimport { Item } from \"@fjell/core\"\nimport { getAllOperation } from \"./all\"\nimport { getActionOperation } from \"./action\"\nimport { Utilities } from \"@/Utilities\"\nimport { HttpApi } from \"@fjell/http-api\"\nimport { getAllActionOperation } from \"./allAction\"\nimport { getOneOperation } from \"./one\"\nimport { getCreateOperation } from \"./create\"\nimport { getUpdateOperation } from \"./update\"\nimport { getGetOperation } from \"./get\"\nimport { getRemoveOperation } from \"./remove\"\nimport { getFindOperation } from \"./find\"\nimport { ClientApiOptions } from \"@/ClientApiOptions\"\nimport { ClientApi } from \"@/ClientApi\"\nimport { getFindOneOperation } from \"./findOne\"\nimport { getFacetOperation } from \"./facet\"\n\nexport const getOperations =\n <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>,\n\n ): ClientApi<V, S, L1, L2, L3, L4, L5> => {\n return {\n action: getActionOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n all: getAllOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n allAction: getAllActionOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n create: getCreateOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n facet: getFacetOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n findOne: getFindOneOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n find: getFindOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n get: getGetOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n one: getOneOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n remove: getRemoveOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n update: getUpdateOperation<V, S, L1, L2, L3, L4, L5>(\n api,\n apiOptions,\n utilities,\n ),\n }\n }","import {\n ComKey,\n validatePK as coreValidatePK,\n generateKeyArray,\n isPriKey,\n Item,\n LocKey,\n LocKeyArray,\n PriKey,\n} from \"@fjell/core\";\n\nimport LibLogger from \"@/logger\";\nimport deepmerge from \"deepmerge\";\n\nconst logger = LibLogger.get('client-api', 'Utility');\n\nexport interface Utilities<\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never\n> {\n verifyLocations: (locations: LocKeyArray<L1, L2, L3, L4, L5> | [] | never) => boolean;\n processOne: (apiCall: Promise<V>) => Promise<V>;\n processArray: (api: Promise<V[]>) => Promise<V[]>;\n convertDoc: (doc: V) => V;\n getPath: (key: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S> | LocKeyArray<L1, L2, L3, L4, L5> | []) => string;\n validatePK: (item: Item<S, L1, L2, L3, L4, L5> | Item<S, L1, L2, L3, L4, L5>[]) =>\n Item<S, L1, L2, L3, L4, L5> | Item<S, L1, L2, L3, L4, L5>[];\n}\n\nexport const createUtilities = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never\n>(pkType: S, pathNames: string[]): Utilities<V, S, L1, L2, L3, L4, L5> => {\n\n logger.default('createUtilities', { pkType, pathNames });\n\n const verifyLocations = (\n locations: LocKeyArray<L1, L2, L3, L4, L5> | [] | never,\n ): boolean => {\n\n if (locations && locations.length < pathNames.length - 1) {\n throw new Error('Not enough locations for pathNames: locations:'\n + locations.length + ' pathNames:' + pathNames.length);\n }\n return true;\n }\n\n const processOne = async (\n apiCall: Promise<V>,\n ): Promise<V> => {\n logger.default('processOne', { apiCall });\n const response = await apiCall;\n logger.default('processOne response', { response: JSON.stringify(response, null, 2) });\n return convertDoc(response);\n };\n\n const processArray = async (\n api: Promise<V[]>,\n ): Promise<V[]> => {\n logger.default('processArray', { api });\n const response = await api;\n logger.default('processArray response', { response: JSON.stringify(response, null, 2) });\n if (response && Array.isArray(response)) {\n return response.map((subjectChat: V) =>\n convertDoc(subjectChat),\n ) as unknown as V[];\n } else {\n logger.error('Response was not an array', { response });\n throw new Error('Response was not an array');\n }\n };\n\n const convertDoc = (doc: V): V => {\n logger.default('convertDoc', { doc });\n // console.log(JSON.stringify(doc, null, 2));\n if (doc && doc.events) {\n const events = doc.events;\n for (const key in events) {\n events[key] = deepmerge(events[key], { at: events[key].at ? new Date(events[key].at) : null });\n }\n\n return doc as unknown as V;\n } else {\n return doc;\n }\n };\n\n const getPath =\n (\n key: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S> | LocKeyArray<L1, L2, L3, L4, L5> | [],\n ):\n string => {\n\n const localPathNames = [...pathNames];\n logger.default('getPath', { key, pathNames: localPathNames });\n\n // console.log('getPath key: ' + JSON.stringify(key));\n\n const keys = generateKeyArray(key);\n\n // console.log('getPath keys: ' + JSON.stringify(keys));\n // console.log('getPath pathNames: ' + JSON.stringify(pathNames));\n\n let path: string = addPath('', keys, localPathNames);\n\n // If there is only one collection left in the collections array, this means that\n // we received LocKeys and we need to add the last collection to the reference\n if (localPathNames.length === 1) {\n path = `${path}/${localPathNames[0]}`;\n }\n\n logger.default('getPath created', { key, path });\n\n return path;\n };\n\n const addPath = (\n base: string,\n keys: Array<PriKey<S> | LocKey<L1 | L2 | L3 | L4 | L5>>,\n localPathNames: string[],\n ): string => {\n logger.default('addPath', { base, keys, pathNames: localPathNames });\n if (keys.length < localPathNames.length - 1) {\n logger.error('addPath should never have keys with a length less than the length of pathNames - 1',\n { keys, localPathNames });\n throw new Error('addPath should never have keys with a length less than the length of pathNames - 1: '\n + keys.length + ' ' + localPathNames.length + ' ' + JSON.stringify(keys, localPathNames));\n } else if (keys.length > localPathNames.length) {\n logger.error('addPath should never have keys with a length greater than the length of pathNames',\n { keys, pathNames });\n throw new Error('addPath should never have keys with a length greater than the length of pathNames: '\n + keys.length + ' ' + localPathNames.length + ' ' + JSON.stringify(keys, localPathNames));\n }\n if (keys.length === 0) {\n // If you've recursively consumed all of the keys, return the base.\n logger.default('addPath returning base', { base });\n return base;\n } else {\n // Retrieve the next key and collection, and create the next base\n let nextBase: string;\n const key = keys.pop();\n const pathName = localPathNames.pop();\n if (isPriKey(key)) {\n const PriKey = key as PriKey<S>;\n nextBase = `${base}/${pathName}/${PriKey.pk}`;\n logger.default('Adding Path for PK', { pathName, PriKey, nextBase });\n } else {\n const LocKey = key as LocKey<L1 | L2 | L3 | L4 | L5>;\n nextBase = `${base}/${pathName}/${LocKey.lk}`;\n logger.default('Retrieving Collection for LK', { pathName, LocKey });\n }\n\n logger.default('calling addPath recursively', { nextBase, keys, localPathNames });\n return addPath(nextBase, keys, localPathNames);\n }\n\n }\n\n const validatePK = (\n item: Item<S, L1, L2, L3, L4, L5> | Item<S, L1, L2, L3, L4, L5>[]):\n Item<S, L1, L2, L3, L4, L5> | Item<S, L1, L2, L3, L4, L5>[] => {\n return coreValidatePK<S, L1, L2, L3, L4, L5>(item, pkType);\n }\n\n return {\n verifyLocations,\n processOne,\n convertDoc,\n processArray,\n getPath,\n validatePK,\n }\n}\n","/* eslint-disable indent */\nimport { Item, QueryParams } from \"@fjell/core\";\nimport { HttpApi } from \"@fjell/http-api\";\n\nimport { ClientApiOptions } from \"./ClientApiOptions\";\nimport { getOperations } from \"./ops\";\nimport { createUtilities } from \"./Utilities\";\nimport { ClientApi } from \"./ClientApi\";\n\nimport LibLogger from \"@/logger\";\n\nconst logger = LibLogger.get('AItemAPI');\n\nexport type PathNamesArray<\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never\n> =\n ([L5] extends [never] ?\n ([L4] extends [never] ?\n ([L3] extends [never] ?\n ([L2] extends [never] ?\n ([L1] extends [never] ?\n [string] :\n [string, string]) :\n [string, string, string]) :\n [string, string, string, string]) :\n [string, string, string, string, string]) :\n [string, string, string, string, string, string]);\n\nexport const finderToParams = (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>\n): QueryParams => {\n return {\n finder,\n finderParams: JSON.stringify(finderParams),\n };\n};\n\nexport const createAItemAPI = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never\n>(\n api: HttpApi,\n pkType: S,\n pathNames: PathNamesArray<L1, L2, L3, L4, L5>,\n options?: ClientApiOptions,\n): ClientApi<V, S, L1, L2, L3, L4, L5> => {\n\n logger.default('createAItemAPI', { pkType, pathNames, options });\n\n let mergedOptions: ClientApiOptions;\n\n const defaultOptions: ClientApiOptions = {\n readAuthenticated: true,\n allAuthenticated: true,\n writeAuthenticated: true,\n };\n\n if (options) {\n mergedOptions = Object.assign({}, defaultOptions, options);\n } else {\n mergedOptions = defaultOptions;\n }\n\n const utilities = createUtilities<V, S, L1, L2, L3, L4, L5>(pkType, pathNames);\n const operations = getOperations<V, S, L1, L2, L3, L4, L5>(api, mergedOptions, utilities);\n\n return {\n action: operations.action,\n all: operations.all,\n allAction: operations.allAction,\n create: operations.create,\n facet: operations.facet,\n find: operations.find,\n findOne: operations.findOne,\n get: operations.get,\n one: operations.one,\n remove: operations.remove,\n update: operations.update,\n }\n}","\nimport {\n ComKey,\n Item,\n ItemQuery,\n LocKeyArray,\n PriKey,\n TypesProperties\n} from \"@fjell/core\";\nimport {\n DeleteMethodOptions,\n GetMethodOptions,\n HttpApi,\n PostMethodOptions,\n PutMethodOptions,\n} from \"@fjell/http-api\";\nimport { createAItemAPI, PathNamesArray } from \"./AItemAPI\";\n\nimport { ClientApi } from \"./ClientApi\";\nimport { ClientApiOptions } from \"./ClientApiOptions\";\nimport LibLogger from \"@/logger\";\n\nconst logger = LibLogger.get('CItemAPI');\n\nexport interface CItemApi<\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never\n> extends ClientApi<V, S, L1, L2, L3, L4, L5> {\n action: (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n action: string,\n body: any,\n options?: Partial<PostMethodOptions>\n ) => Promise<V>;\n all: (\n query: ItemQuery,\n options?: Partial<GetMethodOptions>,\n locations?: LocKeyArray<L1, L2, L3, L4, L5> | []\n ) => Promise<V[]>;\n allAction: (\n action: string,\n body: any,\n options?: Partial<PostMethodOptions>,\n locations?: LocKeyArray<L1, L2, L3, L4, L5> | []\n ) => Promise<V[]>;\n get: (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n options?: Partial<GetMethodOptions>,\n ) => Promise<V | null>;\n create: (\n item: TypesProperties<V, S, L1, L2, L3, L4, L5>,\n options?: Partial<PostMethodOptions>,\n locations?: LocKeyArray<L1, L2, L3, L4, L5> | []\n ) => Promise<V>;\n remove: (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n options?: Partial<DeleteMethodOptions>\n ) => Promise<boolean>;\n update: (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n item: TypesProperties<V, S, L1, L2, L3, L4, L5>,\n options?: Partial<PutMethodOptions>\n ) => Promise<V>;\n facet: (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n facet: string,\n options?: Partial<GetMethodOptions>,\n ) => Promise<any>;\n find: (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options?: Partial<GetMethodOptions>,\n locations?: LocKeyArray<L1, L2, L3, L4, L5> | []\n ) => Promise<V[]>;\n findOne: (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options?: Partial<GetMethodOptions>,\n locations?: LocKeyArray<L1, L2, L3, L4, L5> | []\n ) => Promise<V>;\n};\n\nexport const createCItemApi = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never\n>(api: HttpApi, type: S, pathNames: PathNamesArray<L1, L2, L3, L4, L5>, options?: ClientApiOptions): CItemApi<V, S, L1, L2, L3, L4, L5> => {\n\n logger.default('createCItemApi', { api, type, pathNames, options });\n\n const aItemAPI = createAItemAPI(api, type, pathNames, options);\n\n return {\n action: aItemAPI.action,\n all: aItemAPI.all,\n allAction: aItemAPI.allAction,\n one: aItemAPI.one,\n get: aItemAPI.get,\n create: aItemAPI.create,\n remove: aItemAPI.remove,\n update: aItemAPI.update,\n facet: aItemAPI.facet,\n find: aItemAPI.find,\n findOne: aItemAPI.findOne,\n } as unknown as CItemApi<V, S, L1, L2, L3, L4, L5>;\n}\n","/* eslint-disable @typescript-eslint/no-unused-vars */\n\nimport { ComKey, Item, ItemProperties, ItemQuery, PriKey, TypesProperties } from \"@fjell/core\";\nimport { HttpApi } from \"@fjell/http-api\";\nimport { createAItemAPI, PathNamesArray } from \"./AItemAPI\";\nimport { ClientApi } from \"./ClientApi\";\n\nimport { DeleteMethodOptions, GetMethodOptions, PostMethodOptions, PutMethodOptions } from \"@fjell/http-api\";\nimport { ClientApiOptions } from \"./ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nconst logger = LibLogger.get('PItemAPI');\n\nexport interface PItemApi<\n V extends Item<S>,\n S extends string\n> extends ClientApi<V, S> {\n\n action: (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n action: string,\n body: any,\n options?: Partial<PostMethodOptions>,\n locations?: []\n ) => Promise<V>;\n\n all: (\n query: ItemQuery,\n options?: Partial<GetMethodOptions>,\n locations?: []\n ) => Promise<V[]>;\n\n allAction: (\n action: string,\n body: any,\n options?: Partial<PostMethodOptions>\n ) => Promise<V[]>;\n\n one: (\n query: ItemQuery,\n options?: Partial<GetMethodOptions>\n ) => Promise<V | null>;\n\n get: (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n options?: Partial<GetMethodOptions>,\n locations?: []\n ) => Promise<V | null>;\n\n create: (\n item: TypesProperties<V, S>,\n options?: Partial<PostMethodOptions>,\n locations?: []\n ) => Promise<V>;\n\n remove: (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n options?: Partial<DeleteMethodOptions>,\n locations?: []\n ) => Promise<boolean>;\n\n update: (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n item: TypesProperties<V, S>,\n options?: Partial<PutMethodOptions>,\n locations?: []\n ) => Promise<V>;\n\n facet: (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n facet: string,\n options?: Partial<GetMethodOptions>,\n ) => Promise<any>;\n\n find: (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options?: Partial<GetMethodOptions>,\n locations?: []\n ) => Promise<V[]>;\n\n findOne: (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options?: Partial<GetMethodOptions>,\n locations?: []\n ) => Promise<V>;\n}\n\nexport const createPItemApi = <V extends Item<S>, S extends string>(\n api: HttpApi,\n type: S,\n pathName: string,\n options?: ClientApiOptions\n): PItemApi<V, S> => {\n\n logger.default('createPItemApi', { type, pathName, options });\n\n const aItemAPI = createAItemAPI<V, S>(api, type, [pathName], options);\n\n const action =\n async (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n action: string,\n body: any = {},\n options: Partial<PostMethodOptions> = {},\n ): Promise<V> =>\n await aItemAPI.action(ik, action, body, options) as V;\n\n const all =\n async (\n query: ItemQuery = {} as ItemQuery,\n options: Partial<GetMethodOptions> = {},\n ): Promise<V[]> =>\n await aItemAPI.all(query, options, []) as V[];\n\n const allAction =\n async (\n action: string,\n body: any = {},\n options: Partial<PostMethodOptions> = {},\n ): Promise<V[]> =>\n await aItemAPI.allAction(action, body, options, []) as V[];\n\n const one =\n async (\n query: ItemQuery = {} as ItemQuery,\n options: Partial<GetMethodOptions> = {},\n ): Promise<V | null> =>\n await aItemAPI.one(query, options, []) as V | null;\n\n const get =\n async (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n options: Partial<GetMethodOptions> = {},\n ): Promise<V | null> =>\n await aItemAPI.get(ik, options) as V | null;\n\n const create =\n async (\n item: TypesProperties<V, S>,\n options: Partial<PostMethodOptions> = {},\n ): Promise<V> =>\n await aItemAPI.create(item, options, []) as V;\n\n const remove =\n async (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n options: Partial<DeleteMethodOptions> = {},\n ): Promise<boolean> =>\n await aItemAPI.remove(ik, options) as boolean;\n\n const update =\n async (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n item: TypesProperties<V, S>,\n options: Partial<PutMethodOptions> = {},\n ): Promise<V> =>\n await aItemAPI.update(ik, item, options) as V;\n\n const facet =\n async (\n ik: PriKey<S> | ComKey<S, never, never, never, never, never>,\n facet: string,\n options: Partial<GetMethodOptions> = {},\n ): Promise<any> =>\n await aItemAPI.facet(ik, facet, options) as any;\n\n const find =\n async (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options: Partial<GetMethodOptions> = {},\n ): Promise<V[]> =>\n await aItemAPI.find(finder, finderParams, options, []) as V[];\n\n const findOne =\n async (\n finder: string,\n finderParams: Record<string, string | number | boolean | Date | Array<string | number | boolean | Date>>,\n options: Partial<GetMethodOptions> = {},\n ): Promise<V> =>\n await aItemAPI.findOne(finder, finderParams, options, []) as V;\n\n return {\n ...aItemAPI,\n action,\n all,\n allAction,\n one,\n get,\n create,\n remove,\n update,\n facet,\n find,\n findOne,\n };\n\n};\n"],"names":["LibLogger","Logging","getLogger","logger","get","getAllOperation","api","apiOptions","utilities","all","query","options","locations","default","verifyLocations","loc","params","queryToParams","requestOptions","Object","assign","isAuthenticated","allAuthenticated","validatePK","processArray","httpGet","getPath","getActionOperation","action","ik","body","writeAuthenticated","processOne","httpPost","getAllActionOperation","allAction","getOneOperation","one","readAuthenticated","item","items","length","getCreateOperation","create","created","getUpdateOperation","update","httpPut","getGetOperation","getRemoveOperation","remove","httpDelete","getFindOperation","find","finder","finderParams","finderToParams","getFindOneOperation","findOne","getFacetOperation","facet","getOperations","createUtilities","pkType","pathNames","Error","apiCall","response","JSON","stringify","convertDoc","Array","isArray","map","subjectChat","error","doc","events","key","deepmerge","at","Date","localPathNames","keys","generateKeyArray","path","addPath","base","nextBase","pop","pathName","isPriKey","PriKey","pk","LocKey","lk","coreValidatePK","createAItemAPI","mergedOptions","defaultOptions","operations","createCItemApi","type","aItemAPI","createPItemApi"],"mappings":"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"}
package/dist/index.js CHANGED
@@ -1,3 +1,3 @@
1
1
  export { createCItemApi } from './CItemAPI.js';
2
2
  export { createPItemApi } from './PItemAPI.js';
3
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOyJ9
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
package/dist/logger.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import Logging from '@fjell/logging';
2
2
 
3
- const LibLogger = Logging.getLogger('@fjellproject/client-api');
3
+ const LibLogger = Logging.getLogger('@fjell/client-api');
4
4
 
5
5
  export { LibLogger as default };
6
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nZ2VyLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OyJ9
6
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sources":["../src/logger.ts"],"sourcesContent":["import Logging from '@fjell/logging';\n\nconst LibLogger = Logging.getLogger('@fjell/client-api');\n\nexport default LibLogger;\n"],"names":["LibLogger","Logging","getLogger"],"mappings":";;AAEMA,MAAAA,SAAAA,GAAYC,OAAQC,CAAAA,SAAS,CAAC,mBAAA;;;;"}
@@ -17,4 +17,4 @@ const getActionOperation = (api, apiOptions, utilities)=>{
17
17
  };
18
18
 
19
19
  export { getActionOperation };
20
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7In0=
20
+ //# sourceMappingURL=action.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"action.js","sources":["../../src/ops/action.ts"],"sourcesContent":["import {\n ComKey,\n Item,\n PriKey,\n} from \"@fjell/core\";\nimport { HttpApi, PostMethodOptions } from \"@fjell/http-api\";\n \nimport { ClientApiOptions } from \"@/ClientApiOptions\";\nimport LibLogger from \"@/logger\";\nimport { Utilities } from \"@/Utilities\";\n \nconst logger = LibLogger.get('client-api', 'ops', 'action');\n \nexport const getActionOperation = <\n V extends Item<S, L1, L2, L3, L4, L5>,\n S extends string,\n L1 extends string = never,\n L2 extends string = never,\n L3 extends string = never,\n L4 extends string = never,\n L5 extends string = never>(\n api: HttpApi,\n apiOptions: ClientApiOptions,\n utilities: Utilities<V, S, L1, L2, L3, L4, L5>\n \n ) => {\n \n const action = async (\n ik: ComKey<S, L1, L2, L3, L4, L5> | PriKey<S>,\n action: string,\n body: any = {},\n options: Partial<PostMethodOptions> = {}\n ):\n Promise<V> => {\n logger.default('action', { ik, action, body });\n \n const requestOptions = Object.assign({}, options, { isAuthenticated: apiOptions.writeAuthenticated });\n \n return utilities.validatePK(\n await utilities.processOne(\n api.httpPost<V>(\n `${utilities.getPath(ik)}/${action}`,\n body,\n requestOptions,\n )\n )) as V;\n \n };\n \n return action;\n}\n "],"names":["logger","LibLogger","get","getActionOperation","api","apiOptions","utilities","action","ik","body","options","default","requestOptions","Object","assign","isAuthenticated","writeAuthenticated","validatePK","processOne","httpPost","getPath"],"mappings":";;AAWA,MAAMA,MAASC,GAAAA,SAAAA,CAAUC,GAAG,CAAC,cAAc,KAAO,EAAA,QAAA,CAAA;AAErCC,MAAAA,kBAAAA,GAAqB,CAQ9BC,GAAAA,EACAC,UACAC,EAAAA,SAAAA,GAAAA;IAIF,MAAMC,MAAAA,GAAS,OACbC,EAAAA,EACAD,MACAE,EAAAA,IAAAA,GAAY,EAAE,EACdC,OAAsC,GAAA,EAAE,GAAA;QAGxCV,MAAOW,CAAAA,OAAO,CAAC,QAAU,EAAA;AAAEH,YAAAA,EAAAA;AAAID,YAAAA,MAAAA;AAAQE,YAAAA;AAAK,SAAA,CAAA;AAE5C,QAAA,MAAMG,iBAAiBC,MAAOC,CAAAA,MAAM,CAAC,IAAIJ,OAAS,EAAA;AAAEK,YAAAA,eAAAA,EAAiBV,WAAWW;AAAmB,SAAA,CAAA;AAEnG,QAAA,OAAOV,UAAUW,UAAU,CACzB,MAAMX,SAAUY,CAAAA,UAAU,CACxBd,GAAIe,CAAAA,QAAQ,CACV,CAAGb,EAAAA,SAAAA,CAAUc,OAAO,CAACZ,EAAAA,CAAAA,CAAI,CAAC,EAAED,MAAAA,CAAAA,CAAQ,EACpCE,IACAG,EAAAA,cAAAA,CAAAA,CAAAA,CAAAA;AAIR,KAAA;IAEA,OAAOL,MAAAA;AACT;;;;"}