@webiny/api-form-builder-so-ddb 5.41.4-beta.3 → 5.41.4-beta.5

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.
@@ -1,6 +1,6 @@
1
- import { Entity, Table } from "@webiny/db-dynamodb/toolbox";
2
- import { PluginsContainer } from "@webiny/plugins";
3
- import { FormBuilderFormStorageOperations } from "../../types";
1
+ import type { Entity, Table } from "@webiny/db-dynamodb/toolbox";
2
+ import type { PluginsContainer } from "@webiny/plugins";
3
+ import type { FormBuilderFormStorageOperations } from "../../types";
4
4
  export interface CreateFormStorageOperationsParams {
5
5
  entity: Entity<any>;
6
6
  table: Table<string, string, string>;
@@ -7,7 +7,7 @@ Object.defineProperty(exports, "__esModule", {
7
7
  exports.createFormStorageOperations = void 0;
8
8
  var _error = _interopRequireDefault(require("@webiny/error"));
9
9
  var _query = require("@webiny/db-dynamodb/utils/query");
10
- var _batchWrite = require("@webiny/db-dynamodb/utils/batchWrite");
10
+ var _dbDynamodb = require("@webiny/db-dynamodb");
11
11
  var _filter = require("@webiny/db-dynamodb/utils/filter");
12
12
  var _sort = require("@webiny/db-dynamodb/utils/sort");
13
13
  var _utils = require("@webiny/utils");
@@ -17,7 +17,6 @@ var _get = require("@webiny/db-dynamodb/utils/get");
17
17
  const createFormStorageOperations = params => {
18
18
  const {
19
19
  entity,
20
- table,
21
20
  plugins
22
21
  } = params;
23
22
  const formDynamoDbFields = plugins.byType(_FormDynamoDbFieldPlugin.FormDynamoDbFieldPlugin.type);
@@ -107,21 +106,21 @@ const createFormStorageOperations = params => {
107
106
  const revisionKeys = createRevisionKeys(form);
108
107
  const latestKeys = createLatestKeys(form);
109
108
  const gsiKeys = createGSIKeys(form);
110
- const items = [entity.putBatch({
111
- ...form,
112
- ...revisionKeys,
113
- ...gsiKeys,
114
- TYPE: createFormType()
115
- }), entity.putBatch({
116
- ...form,
117
- ...latestKeys,
118
- TYPE: createFormLatestType()
119
- })];
109
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
110
+ entity,
111
+ put: [{
112
+ ...form,
113
+ ...revisionKeys,
114
+ ...gsiKeys,
115
+ TYPE: createFormType()
116
+ }, {
117
+ ...form,
118
+ ...latestKeys,
119
+ TYPE: createFormLatestType()
120
+ }]
121
+ });
120
122
  try {
121
- await (0, _batchWrite.batchWriteAll)({
122
- table,
123
- items
124
- });
123
+ await entityBatch.execute();
125
124
  } catch (ex) {
126
125
  throw new _error.default(ex.message || "Could not insert form data into table.", ex.code || "CREATE_FORM_ERROR", {
127
126
  revisionKeys,
@@ -140,21 +139,21 @@ const createFormStorageOperations = params => {
140
139
  const revisionKeys = createRevisionKeys(form);
141
140
  const latestKeys = createLatestKeys(form);
142
141
  const gsiKeys = createGSIKeys(form);
143
- const items = [entity.putBatch({
144
- ...form,
145
- ...revisionKeys,
146
- ...gsiKeys,
147
- TYPE: createFormType()
148
- }), entity.putBatch({
149
- ...form,
150
- ...latestKeys,
151
- TYPE: createFormLatestType()
152
- })];
142
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
143
+ entity,
144
+ put: [{
145
+ ...form,
146
+ ...revisionKeys,
147
+ ...gsiKeys,
148
+ TYPE: createFormType()
149
+ }, {
150
+ ...form,
151
+ ...latestKeys,
152
+ TYPE: createFormLatestType()
153
+ }]
154
+ });
153
155
  try {
154
- await (0, _batchWrite.batchWriteAll)({
155
- table,
156
- items
157
- });
156
+ await entityBatch.execute();
158
157
  } catch (ex) {
159
158
  throw new _error.default(ex.message || "Could not create form data in the table, from existing form.", ex.code || "CREATE_FORM_FROM_ERROR", {
160
159
  revisionKeys,
@@ -188,24 +187,24 @@ const createFormStorageOperations = params => {
188
187
  }
189
188
  });
190
189
  const isLatestForm = latestForm ? latestForm.id === form.id : false;
191
- const items = [entity.putBatch({
192
- ...form,
193
- ...revisionKeys,
194
- ...gsiKeys,
195
- TYPE: createFormType()
196
- })];
190
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
191
+ entity,
192
+ put: [{
193
+ ...form,
194
+ ...revisionKeys,
195
+ ...gsiKeys,
196
+ TYPE: createFormType()
197
+ }]
198
+ });
197
199
  if (isLatestForm) {
198
- items.push(entity.putBatch({
200
+ entityBatch.put({
199
201
  ...form,
200
202
  ...latestKeys,
201
203
  TYPE: createFormLatestType()
202
- }));
204
+ });
203
205
  }
204
206
  try {
205
- await (0, _batchWrite.batchWriteAll)({
206
- table,
207
- items
208
- });
207
+ await entityBatch.execute();
209
208
  } catch (ex) {
210
209
  throw new _error.default(ex.message || "Could not update form data in the table.", ex.code || "UPDATE_FORM_ERROR", {
211
210
  revisionKeys,
@@ -409,25 +408,25 @@ const createFormStorageOperations = params => {
409
408
  options: queryAllParams.options
410
409
  });
411
410
  }
412
- let hasLatestPublishedRecord = false;
413
- const deleteItems = items.map(item => {
414
- if (!hasLatestPublishedRecord && item.published) {
415
- hasLatestPublishedRecord = true;
411
+ let latestPublishedKeys;
412
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
413
+ entity,
414
+ delete: [createLatestKeys(form)]
415
+ });
416
+ for (const item of items) {
417
+ if (!latestPublishedKeys && item.published) {
418
+ latestPublishedKeys = createLatestPublishedKeys(item);
416
419
  }
417
- return entity.deleteBatch({
420
+ entityBatch.delete({
418
421
  PK: item.PK,
419
422
  SK: item.SK
420
423
  });
421
- });
422
- if (hasLatestPublishedRecord) {
423
- deleteItems.push(entity.deleteBatch(createLatestPublishedKeys(items[0])));
424
424
  }
425
- deleteItems.push(entity.deleteBatch(createLatestKeys(items[0])));
425
+ if (latestPublishedKeys) {
426
+ entityBatch.delete(latestPublishedKeys);
427
+ }
426
428
  try {
427
- await (0, _batchWrite.batchWriteAll)({
428
- table,
429
- items: deleteItems
430
- });
429
+ await entityBatch.execute();
431
430
  } catch (ex) {
432
431
  throw new _error.default(ex.message || "Could not delete form and it's submissions.", ex.code || "DELETE_FORM_AND_SUBMISSIONS_ERROR");
433
432
  }
@@ -451,7 +450,10 @@ const createFormStorageOperations = params => {
451
450
  const latestPublishedForm = revisions.find(rev => rev.published === true);
452
451
  const isLatest = latestForm ? latestForm.id === form.id : false;
453
452
  const isLatestPublished = latestPublishedForm ? latestPublishedForm.id === form.id : false;
454
- const items = [entity.deleteBatch(revisionKeys)];
453
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
454
+ entity,
455
+ delete: [revisionKeys]
456
+ });
455
457
  if (isLatest || isLatestPublished) {
456
458
  /**
457
459
  * Sort out the latest published record.
@@ -461,38 +463,35 @@ const createFormStorageOperations = params => {
461
463
  return new Date(b.publishedOn).getTime() - new Date(a.publishedOn).getTime();
462
464
  }).shift();
463
465
  if (previouslyPublishedForm) {
464
- items.push(entity.putBatch({
466
+ entityBatch.put({
465
467
  ...previouslyPublishedForm,
466
468
  ...createLatestPublishedKeys(previouslyPublishedForm),
467
469
  GSI1_PK: null,
468
470
  GSI1_SK: null,
469
471
  TYPE: createFormLatestPublishedType()
470
- }));
472
+ });
471
473
  } else {
472
- items.push(entity.deleteBatch(createLatestPublishedKeys(form)));
474
+ entityBatch.delete(createLatestPublishedKeys(form));
473
475
  }
474
476
  }
475
477
  /**
476
478
  * Sort out the latest record.
477
479
  */
478
480
  if (isLatest) {
479
- items.push(entity.putBatch({
481
+ entityBatch.put({
480
482
  ...previous,
481
483
  ...latestKeys,
482
484
  GSI1_PK: null,
483
485
  GSI1_SK: null,
484
486
  TYPE: createFormLatestType()
485
- }));
487
+ });
486
488
  }
487
489
  }
488
490
  /**
489
491
  * Now save the batch data.
490
492
  */
491
493
  try {
492
- await (0, _batchWrite.batchWriteAll)({
493
- table,
494
- items
495
- });
494
+ await entityBatch.execute();
496
495
  return form;
497
496
  } catch (ex) {
498
497
  throw new _error.default(ex.message || "Could not delete form revision from table.", ex.code || "DELETE_FORM_REVISION_ERROR", {
@@ -540,31 +539,32 @@ const createFormStorageOperations = params => {
540
539
  /**
541
540
  * Update revision and latest published records
542
541
  */
543
- const items = [entity.putBatch({
544
- ...form,
545
- ...revisionKeys,
546
- ...gsiKeys,
547
- TYPE: createFormType()
548
- }), entity.putBatch({
549
- ...form,
550
- ...latestPublishedKeys,
551
- TYPE: createFormLatestPublishedType()
552
- })];
542
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
543
+ entity,
544
+ put: [{
545
+ ...form,
546
+ ...revisionKeys,
547
+ ...gsiKeys,
548
+ TYPE: createFormType()
549
+ }, {
550
+ ...form,
551
+ ...latestPublishedKeys,
552
+ TYPE: createFormLatestPublishedType()
553
+ }]
554
+ });
555
+
553
556
  /**
554
557
  * Update the latest form as well
555
558
  */
556
559
  if (isLatestForm) {
557
- items.push(entity.putBatch({
560
+ entityBatch.put({
558
561
  ...form,
559
562
  ...latestKeys,
560
563
  TYPE: createFormLatestType()
561
- }));
564
+ });
562
565
  }
563
566
  try {
564
- await (0, _batchWrite.batchWriteAll)({
565
- table,
566
- items
567
- });
567
+ await entityBatch.execute();
568
568
  } catch (ex) {
569
569
  throw new _error.default(ex.message || "Could not publish form.", ex.code || "PUBLISH_FORM_ERROR", {
570
570
  form,
@@ -616,14 +616,17 @@ const createFormStorageOperations = params => {
616
616
  });
617
617
  const isLatest = latestForm ? latestForm.id === form.id : false;
618
618
  const isLatestPublished = latestPublishedForm ? latestPublishedForm.id === form.id : false;
619
- const items = [entity.putBatch({
620
- ...form,
621
- ...revisionKeys,
622
- ...gsiKeys,
623
- TYPE: createFormType()
624
- })];
619
+ const entityBatch = (0, _dbDynamodb.createEntityWriteBatch)({
620
+ entity,
621
+ put: [{
622
+ ...form,
623
+ ...revisionKeys,
624
+ ...gsiKeys,
625
+ TYPE: createFormType()
626
+ }]
627
+ });
625
628
  if (isLatest) {
626
- entity.putBatch({
629
+ entityBatch.put({
627
630
  ...form,
628
631
  ...latestKeys,
629
632
  TYPE: createFormLatestType()
@@ -646,20 +649,17 @@ const createFormStorageOperations = params => {
646
649
  });
647
650
  const previouslyPublishedRevision = revisions.shift();
648
651
  if (previouslyPublishedRevision) {
649
- items.push(entity.putBatch({
652
+ entityBatch.put({
650
653
  ...previouslyPublishedRevision,
651
654
  ...latestPublishedKeys,
652
655
  TYPE: createFormLatestPublishedType()
653
- }));
656
+ });
654
657
  } else {
655
- items.push(entity.deleteBatch(latestPublishedKeys));
658
+ entityBatch.delete(latestPublishedKeys);
656
659
  }
657
660
  }
658
661
  try {
659
- await (0, _batchWrite.batchWriteAll)({
660
- table,
661
- items
662
- });
662
+ await entityBatch.execute();
663
663
  return form;
664
664
  } catch (ex) {
665
665
  throw new _error.default(ex.message || "Could not unpublish form.", ex.code || "UNPUBLISH_FORM_ERROR", {
@@ -1 +1 @@
1
- {"version":3,"names":["_error","_interopRequireDefault","require","_query","_batchWrite","_filter","_sort","_utils","_FormDynamoDbFieldPlugin","_cursor","_get","createFormStorageOperations","params","entity","table","plugins","formDynamoDbFields","byType","FormDynamoDbFieldPlugin","type","createFormPartitionKey","tenant","locale","createFormLatestPartitionKey","createFormLatestPublishedPartitionKey","createFormGSIPartitionKey","id","targetId","parseIdentifier","createRevisionSortKey","createFormLatestSortKey","formId","value","createLatestPublishedSortKey","createGSISortKey","version","createFormType","createFormLatestType","createFormLatestPublishedType","createRevisionKeys","form","PK","SK","createLatestKeys","createLatestPublishedKeys","createGSIKeys","GSI1_PK","GSI1_SK","createForm","revisionKeys","latestKeys","gsiKeys","items","putBatch","TYPE","batchWriteAll","ex","WebinyError","message","code","createFormFrom","original","latest","updateForm","latestForm","getForm","where","isLatestForm","push","published","partitionKey","sortKey","createIdentifier","keys","getClean","listForms","sort","limit","initialWhere","after","queryAllParams","options","gte","results","queryAll","totalCount","length","filteredItems","filterItems","fields","sortedItems","sortItems","start","parseInt","decodeCursor","hasMoreItems","end","undefined","slice","cursor","encodeCursor","meta","listFormRevisions","index","deleteForm","beginsWith","hasLatestPublishedRecord","deleteItems","map","item","deleteBatch","deleteFormRevision","revisions","previous","latestPublishedForm","find","rev","isLatest","isLatestPublished","previouslyPublishedForm","filter","f","publishedOn","a","b","Date","getTime","shift","publishForm","latestPublishedKeys","unpublishForm","version_not","publishedOn_not","previouslyPublishedRevision","exports"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport {\n FbForm,\n FormBuilderStorageOperationsCreateFormFromParams,\n FormBuilderStorageOperationsCreateFormParams,\n FormBuilderStorageOperationsDeleteFormParams,\n FormBuilderStorageOperationsDeleteFormRevisionParams,\n FormBuilderStorageOperationsGetFormParams,\n FormBuilderStorageOperationsListFormRevisionsParams,\n FormBuilderStorageOperationsListFormRevisionsParamsWhere,\n FormBuilderStorageOperationsListFormsParams,\n FormBuilderStorageOperationsListFormsResponse,\n FormBuilderStorageOperationsPublishFormParams,\n FormBuilderStorageOperationsUnpublishFormParams,\n FormBuilderStorageOperationsUpdateFormParams\n} from \"@webiny/api-form-builder/types\";\nimport { Entity, Table } from \"@webiny/db-dynamodb/toolbox\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\nimport { batchWriteAll } from \"@webiny/db-dynamodb/utils/batchWrite\";\nimport { filterItems } from \"@webiny/db-dynamodb/utils/filter\";\nimport { sortItems } from \"@webiny/db-dynamodb/utils/sort\";\nimport { createIdentifier, parseIdentifier } from \"@webiny/utils\";\nimport { PluginsContainer } from \"@webiny/plugins\";\nimport {\n FormBuilderFormCreateGSIPartitionKeyParams,\n FormBuilderFormCreatePartitionKeyParams,\n FormBuilderFormStorageOperations\n} from \"~/types\";\nimport { FormDynamoDbFieldPlugin } from \"~/plugins/FormDynamoDbFieldPlugin\";\nimport { decodeCursor, encodeCursor } from \"@webiny/db-dynamodb/utils/cursor\";\nimport { getClean } from \"@webiny/db-dynamodb/utils/get\";\n\ntype DbRecord<T = any> = T & {\n PK: string;\n SK: string;\n TYPE: string;\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\n\ninterface FormLatestSortKeyParams {\n id?: string;\n formId?: string;\n}\n\ninterface GsiKeys {\n GSI1_PK: string;\n GSI1_SK: string;\n}\n\nexport interface CreateFormStorageOperationsParams {\n entity: Entity<any>;\n table: Table<string, string, string>;\n plugins: PluginsContainer;\n}\n\nexport const createFormStorageOperations = (\n params: CreateFormStorageOperationsParams\n): FormBuilderFormStorageOperations => {\n const { entity, table, plugins } = params;\n\n const formDynamoDbFields = plugins.byType<FormDynamoDbFieldPlugin>(\n FormDynamoDbFieldPlugin.type\n );\n\n const createFormPartitionKey = (params: FormBuilderFormCreatePartitionKeyParams): string => {\n const { tenant, locale } = params;\n\n return `T#${tenant}#L#${locale}#FB#F`;\n };\n\n const createFormLatestPartitionKey = (\n params: FormBuilderFormCreatePartitionKeyParams\n ): string => {\n return `${createFormPartitionKey(params)}#L`;\n };\n\n const createFormLatestPublishedPartitionKey = (\n params: FormBuilderFormCreatePartitionKeyParams\n ): string => {\n return `${createFormPartitionKey(params)}#LP`;\n };\n\n const createFormGSIPartitionKey = (\n params: FormBuilderFormCreateGSIPartitionKeyParams\n ): string => {\n const { tenant, locale, id: targetId } = params;\n const { id } = parseIdentifier(targetId);\n\n return `T#${tenant}#L#${locale}#FB#F#${id}`;\n };\n\n const createRevisionSortKey = ({ id }: { id: string }): string => {\n return `${id}`;\n };\n\n const createFormLatestSortKey = ({ id, formId }: FormLatestSortKeyParams): string => {\n const value = parseIdentifier(id || formId);\n return value.id;\n };\n\n const createLatestPublishedSortKey = ({ id, formId }: FormLatestSortKeyParams): string => {\n const value = parseIdentifier(id || formId);\n return value.id;\n };\n\n const createGSISortKey = (version: number) => {\n return `${version}`;\n };\n\n const createFormType = (): string => {\n return \"fb.form\";\n };\n\n const createFormLatestType = (): string => {\n return \"fb.form.latest\";\n };\n\n const createFormLatestPublishedType = (): string => {\n return \"fb.form.latestPublished\";\n };\n\n const createRevisionKeys = (form: FbForm): Keys => {\n return {\n PK: createFormPartitionKey(form),\n SK: createRevisionSortKey(form)\n };\n };\n\n const createLatestKeys = (form: FbForm): Keys => {\n return {\n PK: createFormLatestPartitionKey(form),\n SK: createFormLatestSortKey(form)\n };\n };\n\n const createLatestPublishedKeys = (form: FbForm): Keys => {\n return {\n PK: createFormLatestPublishedPartitionKey(form),\n SK: createLatestPublishedSortKey(form)\n };\n };\n\n const createGSIKeys = (form: FbForm): GsiKeys => {\n return {\n GSI1_PK: createFormGSIPartitionKey(form),\n GSI1_SK: createGSISortKey(form.version)\n };\n };\n\n const createForm = async (\n params: FormBuilderStorageOperationsCreateFormParams\n ): Promise<FbForm> => {\n const { form } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const items = [\n entity.putBatch({\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n }),\n entity.putBatch({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n })\n ];\n\n try {\n await batchWriteAll({\n table,\n items\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert form data into table.\",\n ex.code || \"CREATE_FORM_ERROR\",\n {\n revisionKeys,\n latestKeys,\n form\n }\n );\n }\n return form;\n };\n\n const createFormFrom = async (\n params: FormBuilderStorageOperationsCreateFormFromParams\n ): Promise<FbForm> => {\n const { form, original, latest } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const items = [\n entity.putBatch({\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n }),\n entity.putBatch({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n })\n ];\n\n try {\n await batchWriteAll({\n table,\n items\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create form data in the table, from existing form.\",\n ex.code || \"CREATE_FORM_FROM_ERROR\",\n {\n revisionKeys,\n latestKeys,\n original,\n form,\n latest\n }\n );\n }\n\n return form;\n };\n\n const updateForm = async (\n params: FormBuilderStorageOperationsUpdateFormParams\n ): Promise<FbForm> => {\n const { form, original } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const { formId, tenant, locale } = form;\n\n const latestForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n latest: true\n }\n });\n const isLatestForm = latestForm ? latestForm.id === form.id : false;\n\n const items = [\n entity.putBatch({\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n })\n ];\n if (isLatestForm) {\n items.push(\n entity.putBatch({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n })\n );\n }\n try {\n await batchWriteAll({\n table,\n items\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update form data in the table.\",\n ex.code || \"UPDATE_FORM_ERROR\",\n {\n revisionKeys,\n latestKeys,\n original,\n form,\n latestForm\n }\n );\n }\n\n return form;\n };\n\n const getForm = async (\n params: FormBuilderStorageOperationsGetFormParams\n ): Promise<FbForm | null> => {\n const { where } = params;\n const { id, formId, latest, published, version } = where;\n if (latest && published) {\n throw new WebinyError(\"Cannot have both latest and published params.\");\n }\n let partitionKey: string;\n let sortKey: string;\n if (latest) {\n partitionKey = createFormLatestPartitionKey(where);\n sortKey = createFormLatestSortKey(where);\n } else if (published && !version) {\n /**\n * Because of the specifics how DynamoDB works, we must not load the published record if version is sent.\n */\n partitionKey = createFormLatestPublishedPartitionKey(where);\n sortKey = createLatestPublishedSortKey(where);\n } else if (id || version) {\n partitionKey = createFormPartitionKey(where);\n sortKey = createRevisionSortKey({\n id:\n id ||\n createIdentifier({\n id: formId as string,\n version: version as number\n })\n });\n } else {\n throw new WebinyError(\n \"Missing parameter to create a sort key.\",\n \"MISSING_WHERE_PARAMETER\",\n {\n where\n }\n );\n }\n\n const keys = {\n PK: partitionKey,\n SK: sortKey\n };\n\n try {\n return await getClean<FbForm>({ entity, keys });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get form by keys.\",\n ex.code || \"GET_FORM_ERROR\",\n {\n keys\n }\n );\n }\n };\n\n const listForms = async (\n params: FormBuilderStorageOperationsListFormsParams\n ): Promise<FormBuilderStorageOperationsListFormsResponse> => {\n const { sort, limit, where: initialWhere, after } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createFormLatestPartitionKey(initialWhere),\n options: {\n gte: \" \"\n }\n };\n\n let results;\n try {\n results = await queryAll<FbForm>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could list forms.\",\n ex.code || \"LIST_FORMS_ERROR\",\n {\n where: initialWhere,\n partitionKey: queryAllParams.partitionKey\n }\n );\n }\n const totalCount = results.length;\n\n const where: Partial<FormBuilderStorageOperationsListFormsParams[\"where\"]> = {\n ...initialWhere\n };\n /**\n * We need to remove conditions so we do not filter by them again.\n */\n delete where.tenant;\n delete where.locale;\n\n const filteredItems = filterItems({\n plugins,\n items: results,\n where,\n fields: formDynamoDbFields\n });\n\n const sortedItems = sortItems({\n items: filteredItems,\n sort,\n fields: formDynamoDbFields\n });\n\n const start = parseInt(decodeCursor(after) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const items = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = items.length > 0 ? encodeCursor(start + limit) : null;\n\n const meta = {\n hasMoreItems,\n totalCount,\n cursor\n };\n\n return {\n items,\n meta\n };\n };\n\n const listFormRevisions = async (\n params: FormBuilderStorageOperationsListFormRevisionsParams\n ): Promise<FbForm[]> => {\n const { where: initialWhere, sort } = params;\n const { id, formId, tenant, locale } = initialWhere;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createFormGSIPartitionKey({\n tenant,\n locale,\n id: formId || id\n }),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n\n let items: FbForm[] = [];\n try {\n items = await queryAll<FbForm>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not query forms by given params.\",\n ex.code || \"QUERY_FORMS_ERROR\",\n {\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n }\n );\n }\n const where: Partial<FormBuilderStorageOperationsListFormRevisionsParamsWhere> = {\n ...initialWhere\n };\n /**\n * We need to remove conditions so we do not filter by them again.\n */\n delete where.id;\n delete where.formId;\n delete where.tenant;\n delete where.locale;\n\n const filteredItems = filterItems({\n plugins,\n items,\n where,\n fields: formDynamoDbFields\n });\n return sortItems({\n items: filteredItems,\n sort,\n fields: formDynamoDbFields\n });\n };\n\n const deleteForm = async (\n params: FormBuilderStorageOperationsDeleteFormParams\n ): Promise<FbForm> => {\n const { form } = params;\n let items: any[];\n /**\n * This will find all form records.\n */\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createFormPartitionKey(form),\n options: {\n beginsWith: form.formId || undefined\n }\n };\n try {\n items = await queryAll<DbRecord>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not query forms and submissions by given params.\",\n ex.code || \"QUERY_FORM_AND_SUBMISSIONS_ERROR\",\n {\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n }\n );\n }\n\n let hasLatestPublishedRecord = false;\n\n const deleteItems = items.map(item => {\n if (!hasLatestPublishedRecord && item.published) {\n hasLatestPublishedRecord = true;\n }\n return entity.deleteBatch({\n PK: item.PK,\n SK: item.SK\n });\n });\n if (hasLatestPublishedRecord) {\n deleteItems.push(entity.deleteBatch(createLatestPublishedKeys(items[0])));\n }\n\n deleteItems.push(entity.deleteBatch(createLatestKeys(items[0])));\n\n try {\n await batchWriteAll({\n table,\n items: deleteItems\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete form and it's submissions.\",\n ex.code || \"DELETE_FORM_AND_SUBMISSIONS_ERROR\"\n );\n }\n return form;\n };\n /**\n * We need to:\n * - delete current revision\n * - get previously published revision and update the record if it exists or delete if it does not\n * - update latest record if current one is the latest\n */\n const deleteFormRevision = async (\n params: FormBuilderStorageOperationsDeleteFormRevisionParams\n ): Promise<FbForm> => {\n const { form, revisions, previous } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n\n const latestForm = revisions[0];\n const latestPublishedForm = revisions.find(rev => rev.published === true);\n\n const isLatest = latestForm ? latestForm.id === form.id : false;\n const isLatestPublished = latestPublishedForm ? latestPublishedForm.id === form.id : false;\n\n const items = [entity.deleteBatch(revisionKeys)];\n\n if (isLatest || isLatestPublished) {\n /**\n * Sort out the latest published record.\n */\n if (isLatestPublished) {\n const previouslyPublishedForm = revisions\n .filter(f => !!f.publishedOn && f.version !== form.version)\n .sort((a, b) => {\n return (\n new Date(b.publishedOn as string).getTime() -\n new Date(a.publishedOn as string).getTime()\n );\n })\n .shift();\n if (previouslyPublishedForm) {\n items.push(\n entity.putBatch({\n ...previouslyPublishedForm,\n ...createLatestPublishedKeys(previouslyPublishedForm),\n GSI1_PK: null,\n GSI1_SK: null,\n TYPE: createFormLatestPublishedType()\n })\n );\n } else {\n items.push(entity.deleteBatch(createLatestPublishedKeys(form)));\n }\n }\n /**\n * Sort out the latest record.\n */\n if (isLatest) {\n items.push(\n entity.putBatch({\n ...previous,\n ...latestKeys,\n GSI1_PK: null,\n GSI1_SK: null,\n TYPE: createFormLatestType()\n })\n );\n }\n }\n /**\n * Now save the batch data.\n */\n try {\n await batchWriteAll({\n table,\n items\n });\n return form;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete form revision from table.\",\n ex.code || \"DELETE_FORM_REVISION_ERROR\",\n {\n form,\n latestForm,\n revisionKeys,\n latestKeys\n }\n );\n }\n };\n\n /**\n * We need to save form in:\n * - regular form record\n * - latest published form record\n * - latest form record - if form is latest one\n * - elasticsearch latest form record\n */\n const publishForm = async (\n params: FormBuilderStorageOperationsPublishFormParams\n ): Promise<FbForm> => {\n const { form, original } = params;\n\n const revisionKeys = createRevisionKeys(form);\n\n const latestKeys = createLatestKeys(form);\n\n const latestPublishedKeys = createLatestPublishedKeys(form);\n\n const gsiKeys = {\n GSI1_PK: createFormGSIPartitionKey(form),\n GSI1_SK: createGSISortKey(form.version)\n };\n\n const { locale, tenant, formId } = form;\n\n const latestForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n latest: true\n }\n });\n\n const isLatestForm = latestForm ? latestForm.id === form.id : false;\n /**\n * Update revision and latest published records\n */\n const items = [\n entity.putBatch({\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n }),\n entity.putBatch({\n ...form,\n ...latestPublishedKeys,\n TYPE: createFormLatestPublishedType()\n })\n ];\n /**\n * Update the latest form as well\n */\n if (isLatestForm) {\n items.push(\n entity.putBatch({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n })\n );\n }\n\n try {\n await batchWriteAll({\n table,\n items\n });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not publish form.\",\n ex.code || \"PUBLISH_FORM_ERROR\",\n {\n form,\n original,\n latestForm,\n revisionKeys,\n latestKeys,\n latestPublishedKeys\n }\n );\n }\n return form;\n };\n\n /**\n * We need to:\n * - update form revision record\n * - if latest published (LP) is current form, find the previously published record and update LP if there is some previously published, delete otherwise\n * - if is latest update the Elasticsearch record\n */\n const unpublishForm = async (\n params: FormBuilderStorageOperationsUnpublishFormParams\n ): Promise<FbForm> => {\n const { form, original } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const latestPublishedKeys = createLatestPublishedKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const { formId, tenant, locale } = form;\n\n const latestForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n latest: true\n }\n });\n\n const latestPublishedForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n published: true\n }\n });\n\n const isLatest = latestForm ? latestForm.id === form.id : false;\n const isLatestPublished = latestPublishedForm ? latestPublishedForm.id === form.id : false;\n\n const items = [\n entity.putBatch({\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n })\n ];\n\n if (isLatest) {\n entity.putBatch({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n });\n }\n /**\n * In case previously published revision exists, replace current one with that one.\n * And if it does not, delete the record.\n */\n if (isLatestPublished) {\n const revisions = await listFormRevisions({\n where: {\n formId,\n tenant,\n locale,\n version_not: form.version,\n publishedOn_not: null\n },\n sort: [\"savedOn_DESC\"]\n });\n\n const previouslyPublishedRevision = revisions.shift();\n if (previouslyPublishedRevision) {\n items.push(\n entity.putBatch({\n ...previouslyPublishedRevision,\n ...latestPublishedKeys,\n TYPE: createFormLatestPublishedType()\n })\n );\n } else {\n items.push(entity.deleteBatch(latestPublishedKeys));\n }\n }\n\n try {\n await batchWriteAll({\n table,\n items\n });\n return form;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not unpublish form.\",\n ex.code || \"UNPUBLISH_FORM_ERROR\",\n {\n form,\n original,\n latestForm,\n revisionKeys,\n latestKeys,\n latestPublishedKeys\n }\n );\n }\n };\n\n return {\n createForm,\n createFormFrom,\n updateForm,\n listForms,\n listFormRevisions,\n getForm,\n deleteForm,\n deleteFormRevision,\n publishForm,\n unpublishForm,\n createFormPartitionKey\n };\n};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_error","_interopRequireDefault","require","_query","_dbDynamodb","_filter","_sort","_utils","_FormDynamoDbFieldPlugin","_cursor","_get","createFormStorageOperations","params","entity","plugins","formDynamoDbFields","byType","FormDynamoDbFieldPlugin","type","createFormPartitionKey","tenant","locale","createFormLatestPartitionKey","createFormLatestPublishedPartitionKey","createFormGSIPartitionKey","id","targetId","parseIdentifier","createRevisionSortKey","createFormLatestSortKey","formId","value","createLatestPublishedSortKey","createGSISortKey","version","createFormType","createFormLatestType","createFormLatestPublishedType","createRevisionKeys","form","PK","SK","createLatestKeys","createLatestPublishedKeys","createGSIKeys","GSI1_PK","GSI1_SK","createForm","revisionKeys","latestKeys","gsiKeys","entityBatch","createEntityWriteBatch","put","TYPE","execute","ex","WebinyError","message","code","createFormFrom","original","latest","updateForm","latestForm","getForm","where","isLatestForm","published","partitionKey","sortKey","createIdentifier","keys","getClean","listForms","sort","limit","initialWhere","after","queryAllParams","options","gte","results","queryAll","totalCount","length","filteredItems","filterItems","items","fields","sortedItems","sortItems","start","parseInt","decodeCursor","hasMoreItems","end","undefined","slice","cursor","encodeCursor","meta","listFormRevisions","index","deleteForm","beginsWith","latestPublishedKeys","delete","item","deleteFormRevision","revisions","previous","latestPublishedForm","find","rev","isLatest","isLatestPublished","previouslyPublishedForm","filter","f","publishedOn","a","b","Date","getTime","shift","publishForm","unpublishForm","version_not","publishedOn_not","previouslyPublishedRevision","exports"],"sources":["index.ts"],"sourcesContent":["import WebinyError from \"@webiny/error\";\nimport type {\n FbForm,\n FormBuilderStorageOperationsCreateFormFromParams,\n FormBuilderStorageOperationsCreateFormParams,\n FormBuilderStorageOperationsDeleteFormParams,\n FormBuilderStorageOperationsDeleteFormRevisionParams,\n FormBuilderStorageOperationsGetFormParams,\n FormBuilderStorageOperationsListFormRevisionsParams,\n FormBuilderStorageOperationsListFormRevisionsParamsWhere,\n FormBuilderStorageOperationsListFormsParams,\n FormBuilderStorageOperationsListFormsResponse,\n FormBuilderStorageOperationsPublishFormParams,\n FormBuilderStorageOperationsUnpublishFormParams,\n FormBuilderStorageOperationsUpdateFormParams\n} from \"@webiny/api-form-builder/types\";\nimport type { Entity, Table } from \"@webiny/db-dynamodb/toolbox\";\nimport { queryAll, QueryAllParams } from \"@webiny/db-dynamodb/utils/query\";\nimport { createEntityWriteBatch } from \"@webiny/db-dynamodb\";\nimport { filterItems } from \"@webiny/db-dynamodb/utils/filter\";\nimport { sortItems } from \"@webiny/db-dynamodb/utils/sort\";\nimport { createIdentifier, parseIdentifier } from \"@webiny/utils\";\nimport type { PluginsContainer } from \"@webiny/plugins\";\nimport type {\n FormBuilderFormCreateGSIPartitionKeyParams,\n FormBuilderFormCreatePartitionKeyParams,\n FormBuilderFormStorageOperations\n} from \"~/types\";\nimport { FormDynamoDbFieldPlugin } from \"~/plugins/FormDynamoDbFieldPlugin\";\nimport { decodeCursor, encodeCursor } from \"@webiny/db-dynamodb/utils/cursor\";\nimport { getClean } from \"@webiny/db-dynamodb/utils/get\";\n\ntype DbRecord<T = any> = T & {\n PK: string;\n SK: string;\n TYPE: string;\n};\n\ninterface Keys {\n PK: string;\n SK: string;\n}\n\ninterface FormLatestSortKeyParams {\n id?: string;\n formId?: string;\n}\n\ninterface GsiKeys {\n GSI1_PK: string;\n GSI1_SK: string;\n}\n\nexport interface CreateFormStorageOperationsParams {\n entity: Entity<any>;\n table: Table<string, string, string>;\n plugins: PluginsContainer;\n}\n\nexport const createFormStorageOperations = (\n params: CreateFormStorageOperationsParams\n): FormBuilderFormStorageOperations => {\n const { entity, plugins } = params;\n\n const formDynamoDbFields = plugins.byType<FormDynamoDbFieldPlugin>(\n FormDynamoDbFieldPlugin.type\n );\n\n const createFormPartitionKey = (params: FormBuilderFormCreatePartitionKeyParams): string => {\n const { tenant, locale } = params;\n\n return `T#${tenant}#L#${locale}#FB#F`;\n };\n\n const createFormLatestPartitionKey = (\n params: FormBuilderFormCreatePartitionKeyParams\n ): string => {\n return `${createFormPartitionKey(params)}#L`;\n };\n\n const createFormLatestPublishedPartitionKey = (\n params: FormBuilderFormCreatePartitionKeyParams\n ): string => {\n return `${createFormPartitionKey(params)}#LP`;\n };\n\n const createFormGSIPartitionKey = (\n params: FormBuilderFormCreateGSIPartitionKeyParams\n ): string => {\n const { tenant, locale, id: targetId } = params;\n const { id } = parseIdentifier(targetId);\n\n return `T#${tenant}#L#${locale}#FB#F#${id}`;\n };\n\n const createRevisionSortKey = ({ id }: { id: string }): string => {\n return `${id}`;\n };\n\n const createFormLatestSortKey = ({ id, formId }: FormLatestSortKeyParams): string => {\n const value = parseIdentifier(id || formId);\n return value.id;\n };\n\n const createLatestPublishedSortKey = ({ id, formId }: FormLatestSortKeyParams): string => {\n const value = parseIdentifier(id || formId);\n return value.id;\n };\n\n const createGSISortKey = (version: number) => {\n return `${version}`;\n };\n\n const createFormType = (): string => {\n return \"fb.form\";\n };\n\n const createFormLatestType = (): string => {\n return \"fb.form.latest\";\n };\n\n const createFormLatestPublishedType = (): string => {\n return \"fb.form.latestPublished\";\n };\n\n const createRevisionKeys = (form: Pick<FbForm, \"id\" | \"tenant\" | \"locale\">): Keys => {\n return {\n PK: createFormPartitionKey(form),\n SK: createRevisionSortKey(form)\n };\n };\n\n const createLatestKeys = (form: Pick<FbForm, \"tenant\" | \"locale\" | \"id\" | \"formId\">): Keys => {\n return {\n PK: createFormLatestPartitionKey(form),\n SK: createFormLatestSortKey(form)\n };\n };\n\n const createLatestPublishedKeys = (\n form: Pick<FbForm, \"tenant\" | \"locale\" | \"id\" | \"formId\">\n ): Keys => {\n return {\n PK: createFormLatestPublishedPartitionKey(form),\n SK: createLatestPublishedSortKey(form)\n };\n };\n\n const createGSIKeys = (form: Pick<FbForm, \"version\" | \"tenant\" | \"locale\">): GsiKeys => {\n return {\n GSI1_PK: createFormGSIPartitionKey(form),\n GSI1_SK: createGSISortKey(form.version)\n };\n };\n\n const createForm = async (\n params: FormBuilderStorageOperationsCreateFormParams\n ): Promise<FbForm> => {\n const { form } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const entityBatch = createEntityWriteBatch({\n entity,\n put: [\n {\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n },\n {\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n }\n ]\n });\n\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not insert form data into table.\",\n ex.code || \"CREATE_FORM_ERROR\",\n {\n revisionKeys,\n latestKeys,\n form\n }\n );\n }\n return form;\n };\n\n const createFormFrom = async (\n params: FormBuilderStorageOperationsCreateFormFromParams\n ): Promise<FbForm> => {\n const { form, original, latest } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const entityBatch = createEntityWriteBatch({\n entity,\n put: [\n {\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n },\n {\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n }\n ]\n });\n\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not create form data in the table, from existing form.\",\n ex.code || \"CREATE_FORM_FROM_ERROR\",\n {\n revisionKeys,\n latestKeys,\n original,\n form,\n latest\n }\n );\n }\n\n return form;\n };\n\n const updateForm = async (\n params: FormBuilderStorageOperationsUpdateFormParams\n ): Promise<FbForm> => {\n const { form, original } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const { formId, tenant, locale } = form;\n\n const latestForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n latest: true\n }\n });\n const isLatestForm = latestForm ? latestForm.id === form.id : false;\n\n const entityBatch = createEntityWriteBatch({\n entity,\n put: [\n {\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n }\n ]\n });\n\n if (isLatestForm) {\n entityBatch.put({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n });\n }\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not update form data in the table.\",\n ex.code || \"UPDATE_FORM_ERROR\",\n {\n revisionKeys,\n latestKeys,\n original,\n form,\n latestForm\n }\n );\n }\n\n return form;\n };\n\n const getForm = async (\n params: FormBuilderStorageOperationsGetFormParams\n ): Promise<FbForm | null> => {\n const { where } = params;\n const { id, formId, latest, published, version } = where;\n if (latest && published) {\n throw new WebinyError(\"Cannot have both latest and published params.\");\n }\n let partitionKey: string;\n let sortKey: string;\n if (latest) {\n partitionKey = createFormLatestPartitionKey(where);\n sortKey = createFormLatestSortKey(where);\n } else if (published && !version) {\n /**\n * Because of the specifics how DynamoDB works, we must not load the published record if version is sent.\n */\n partitionKey = createFormLatestPublishedPartitionKey(where);\n sortKey = createLatestPublishedSortKey(where);\n } else if (id || version) {\n partitionKey = createFormPartitionKey(where);\n sortKey = createRevisionSortKey({\n id:\n id ||\n createIdentifier({\n id: formId as string,\n version: version as number\n })\n });\n } else {\n throw new WebinyError(\n \"Missing parameter to create a sort key.\",\n \"MISSING_WHERE_PARAMETER\",\n {\n where\n }\n );\n }\n\n const keys = {\n PK: partitionKey,\n SK: sortKey\n };\n\n try {\n return await getClean<FbForm>({ entity, keys });\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not get form by keys.\",\n ex.code || \"GET_FORM_ERROR\",\n {\n keys\n }\n );\n }\n };\n\n const listForms = async (\n params: FormBuilderStorageOperationsListFormsParams\n ): Promise<FormBuilderStorageOperationsListFormsResponse> => {\n const { sort, limit, where: initialWhere, after } = params;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createFormLatestPartitionKey(initialWhere),\n options: {\n gte: \" \"\n }\n };\n\n let results;\n try {\n results = await queryAll<FbForm>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could list forms.\",\n ex.code || \"LIST_FORMS_ERROR\",\n {\n where: initialWhere,\n partitionKey: queryAllParams.partitionKey\n }\n );\n }\n const totalCount = results.length;\n\n const where: Partial<FormBuilderStorageOperationsListFormsParams[\"where\"]> = {\n ...initialWhere\n };\n /**\n * We need to remove conditions so we do not filter by them again.\n */\n delete where.tenant;\n delete where.locale;\n\n const filteredItems = filterItems({\n plugins,\n items: results,\n where,\n fields: formDynamoDbFields\n });\n\n const sortedItems = sortItems({\n items: filteredItems,\n sort,\n fields: formDynamoDbFields\n });\n\n const start = parseInt(decodeCursor(after) || \"0\") || 0;\n const hasMoreItems = totalCount > start + limit;\n const end = limit > totalCount + start + limit ? undefined : start + limit;\n const items = sortedItems.slice(start, end);\n /**\n * Although we do not need a cursor here, we will use it as such to keep it standardized.\n * Number is simply encoded.\n */\n const cursor = items.length > 0 ? encodeCursor(start + limit) : null;\n\n const meta = {\n hasMoreItems,\n totalCount,\n cursor\n };\n\n return {\n items,\n meta\n };\n };\n\n const listFormRevisions = async (\n params: FormBuilderStorageOperationsListFormRevisionsParams\n ): Promise<FbForm[]> => {\n const { where: initialWhere, sort } = params;\n const { id, formId, tenant, locale } = initialWhere;\n\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createFormGSIPartitionKey({\n tenant,\n locale,\n id: formId || id\n }),\n options: {\n index: \"GSI1\",\n gte: \" \"\n }\n };\n\n let items: FbForm[] = [];\n try {\n items = await queryAll<FbForm>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not query forms by given params.\",\n ex.code || \"QUERY_FORMS_ERROR\",\n {\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n }\n );\n }\n const where: Partial<FormBuilderStorageOperationsListFormRevisionsParamsWhere> = {\n ...initialWhere\n };\n /**\n * We need to remove conditions so we do not filter by them again.\n */\n delete where.id;\n delete where.formId;\n delete where.tenant;\n delete where.locale;\n\n const filteredItems = filterItems({\n plugins,\n items,\n where,\n fields: formDynamoDbFields\n });\n return sortItems({\n items: filteredItems,\n sort,\n fields: formDynamoDbFields\n });\n };\n\n const deleteForm = async (\n params: FormBuilderStorageOperationsDeleteFormParams\n ): Promise<FbForm> => {\n const { form } = params;\n let items: any[];\n /**\n * This will find all form records.\n */\n const queryAllParams: QueryAllParams = {\n entity,\n partitionKey: createFormPartitionKey(form),\n options: {\n beginsWith: form.formId || undefined\n }\n };\n try {\n items = await queryAll<DbRecord>(queryAllParams);\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not query forms and submissions by given params.\",\n ex.code || \"QUERY_FORM_AND_SUBMISSIONS_ERROR\",\n {\n partitionKey: queryAllParams.partitionKey,\n options: queryAllParams.options\n }\n );\n }\n let latestPublishedKeys: Keys | undefined;\n const entityBatch = createEntityWriteBatch({\n entity,\n delete: [createLatestKeys(form)]\n });\n\n for (const item of items) {\n if (!latestPublishedKeys && item.published) {\n latestPublishedKeys = createLatestPublishedKeys(item);\n }\n entityBatch.delete({\n PK: item.PK,\n SK: item.SK\n });\n }\n\n if (latestPublishedKeys) {\n entityBatch.delete(latestPublishedKeys);\n }\n\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete form and it's submissions.\",\n ex.code || \"DELETE_FORM_AND_SUBMISSIONS_ERROR\"\n );\n }\n return form;\n };\n /**\n * We need to:\n * - delete current revision\n * - get previously published revision and update the record if it exists or delete if it does not\n * - update latest record if current one is the latest\n */\n const deleteFormRevision = async (\n params: FormBuilderStorageOperationsDeleteFormRevisionParams\n ): Promise<FbForm> => {\n const { form, revisions, previous } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n\n const latestForm = revisions[0];\n const latestPublishedForm = revisions.find(rev => rev.published === true);\n\n const isLatest = latestForm ? latestForm.id === form.id : false;\n const isLatestPublished = latestPublishedForm ? latestPublishedForm.id === form.id : false;\n\n const entityBatch = createEntityWriteBatch({\n entity,\n delete: [revisionKeys]\n });\n\n if (isLatest || isLatestPublished) {\n /**\n * Sort out the latest published record.\n */\n if (isLatestPublished) {\n const previouslyPublishedForm = revisions\n .filter(f => !!f.publishedOn && f.version !== form.version)\n .sort((a, b) => {\n return (\n new Date(b.publishedOn as string).getTime() -\n new Date(a.publishedOn as string).getTime()\n );\n })\n .shift();\n if (previouslyPublishedForm) {\n entityBatch.put({\n ...previouslyPublishedForm,\n ...createLatestPublishedKeys(previouslyPublishedForm),\n GSI1_PK: null,\n GSI1_SK: null,\n TYPE: createFormLatestPublishedType()\n });\n } else {\n entityBatch.delete(createLatestPublishedKeys(form));\n }\n }\n /**\n * Sort out the latest record.\n */\n if (isLatest) {\n entityBatch.put({\n ...previous,\n ...latestKeys,\n GSI1_PK: null,\n GSI1_SK: null,\n TYPE: createFormLatestType()\n });\n }\n }\n /**\n * Now save the batch data.\n */\n try {\n await entityBatch.execute();\n\n return form;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not delete form revision from table.\",\n ex.code || \"DELETE_FORM_REVISION_ERROR\",\n {\n form,\n latestForm,\n revisionKeys,\n latestKeys\n }\n );\n }\n };\n\n /**\n * We need to save form in:\n * - regular form record\n * - latest published form record\n * - latest form record - if form is latest one\n * - elasticsearch latest form record\n */\n const publishForm = async (\n params: FormBuilderStorageOperationsPublishFormParams\n ): Promise<FbForm> => {\n const { form, original } = params;\n\n const revisionKeys = createRevisionKeys(form);\n\n const latestKeys = createLatestKeys(form);\n\n const latestPublishedKeys = createLatestPublishedKeys(form);\n\n const gsiKeys = {\n GSI1_PK: createFormGSIPartitionKey(form),\n GSI1_SK: createGSISortKey(form.version)\n };\n\n const { locale, tenant, formId } = form;\n\n const latestForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n latest: true\n }\n });\n\n const isLatestForm = latestForm ? latestForm.id === form.id : false;\n /**\n * Update revision and latest published records\n */\n const entityBatch = createEntityWriteBatch({\n entity,\n put: [\n {\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n },\n {\n ...form,\n ...latestPublishedKeys,\n TYPE: createFormLatestPublishedType()\n }\n ]\n });\n\n /**\n * Update the latest form as well\n */\n if (isLatestForm) {\n entityBatch.put({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n });\n }\n\n try {\n await entityBatch.execute();\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not publish form.\",\n ex.code || \"PUBLISH_FORM_ERROR\",\n {\n form,\n original,\n latestForm,\n revisionKeys,\n latestKeys,\n latestPublishedKeys\n }\n );\n }\n return form;\n };\n\n /**\n * We need to:\n * - update form revision record\n * - if latest published (LP) is current form, find the previously published record and update LP if there is some previously published, delete otherwise\n * - if is latest update the Elasticsearch record\n */\n const unpublishForm = async (\n params: FormBuilderStorageOperationsUnpublishFormParams\n ): Promise<FbForm> => {\n const { form, original } = params;\n\n const revisionKeys = createRevisionKeys(form);\n const latestKeys = createLatestKeys(form);\n const latestPublishedKeys = createLatestPublishedKeys(form);\n const gsiKeys = createGSIKeys(form);\n\n const { formId, tenant, locale } = form;\n\n const latestForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n latest: true\n }\n });\n\n const latestPublishedForm = await getForm({\n where: {\n formId,\n tenant,\n locale,\n published: true\n }\n });\n\n const isLatest = latestForm ? latestForm.id === form.id : false;\n const isLatestPublished = latestPublishedForm ? latestPublishedForm.id === form.id : false;\n\n const entityBatch = createEntityWriteBatch({\n entity,\n put: [\n {\n ...form,\n ...revisionKeys,\n ...gsiKeys,\n TYPE: createFormType()\n }\n ]\n });\n\n if (isLatest) {\n entityBatch.put({\n ...form,\n ...latestKeys,\n TYPE: createFormLatestType()\n });\n }\n /**\n * In case previously published revision exists, replace current one with that one.\n * And if it does not, delete the record.\n */\n if (isLatestPublished) {\n const revisions = await listFormRevisions({\n where: {\n formId,\n tenant,\n locale,\n version_not: form.version,\n publishedOn_not: null\n },\n sort: [\"savedOn_DESC\"]\n });\n\n const previouslyPublishedRevision = revisions.shift();\n if (previouslyPublishedRevision) {\n entityBatch.put({\n ...previouslyPublishedRevision,\n ...latestPublishedKeys,\n TYPE: createFormLatestPublishedType()\n });\n } else {\n entityBatch.delete(latestPublishedKeys);\n }\n }\n\n try {\n await entityBatch.execute();\n return form;\n } catch (ex) {\n throw new WebinyError(\n ex.message || \"Could not unpublish form.\",\n ex.code || \"UNPUBLISH_FORM_ERROR\",\n {\n form,\n original,\n latestForm,\n revisionKeys,\n latestKeys,\n latestPublishedKeys\n }\n );\n }\n };\n\n return {\n createForm,\n createFormFrom,\n updateForm,\n listForms,\n listFormRevisions,\n getForm,\n deleteForm,\n deleteFormRevision,\n publishForm,\n unpublishForm,\n createFormPartitionKey\n };\n};\n"],"mappings":"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","ignoreList":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webiny/api-form-builder-so-ddb",
3
- "version": "5.41.4-beta.3",
3
+ "version": "5.41.4-beta.5",
4
4
  "main": "index.js",
5
5
  "keywords": [
6
6
  "@webiny/api-form-builder",
@@ -22,21 +22,21 @@
22
22
  "license": "MIT",
23
23
  "dependencies": {
24
24
  "@babel/runtime": "7.24.1",
25
- "@webiny/api-form-builder": "5.41.4-beta.3",
26
- "@webiny/aws-sdk": "5.41.4-beta.3",
27
- "@webiny/db-dynamodb": "5.41.4-beta.3",
28
- "@webiny/error": "5.41.4-beta.3",
29
- "@webiny/plugins": "5.41.4-beta.3",
30
- "@webiny/utils": "5.41.4-beta.3"
25
+ "@webiny/api-form-builder": "5.41.4-beta.5",
26
+ "@webiny/aws-sdk": "5.41.4-beta.5",
27
+ "@webiny/db-dynamodb": "5.41.4-beta.5",
28
+ "@webiny/error": "5.41.4-beta.5",
29
+ "@webiny/plugins": "5.41.4-beta.5",
30
+ "@webiny/utils": "5.41.4-beta.5"
31
31
  },
32
32
  "devDependencies": {
33
33
  "@babel/cli": "7.24.1",
34
34
  "@babel/core": "7.24.3",
35
35
  "@babel/preset-env": "7.24.3",
36
36
  "@babel/preset-typescript": "7.24.1",
37
- "@webiny/cli": "5.41.4-beta.3",
38
- "@webiny/handler-db": "5.41.4-beta.3",
39
- "@webiny/project-utils": "5.41.4-beta.3",
37
+ "@webiny/cli": "5.41.4-beta.5",
38
+ "@webiny/handler-db": "5.41.4-beta.5",
39
+ "@webiny/project-utils": "5.41.4-beta.5",
40
40
  "csvtojson": "2.0.10",
41
41
  "jest": "29.7.0",
42
42
  "jest-dynalite": "3.6.1",
@@ -52,5 +52,5 @@
52
52
  "build": "yarn webiny run build",
53
53
  "watch": "yarn webiny run watch"
54
54
  },
55
- "gitHead": "1be3b755403a5151fd830e72ec31c6b83f49e292"
55
+ "gitHead": "e3f273ea63f0c426c2ddde0794d303bc8ffaa6c4"
56
56
  }