@itleanchatbot/shared-models-js-postgres 2.0.0 → 2.1.1

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 (175) hide show
  1. package/README.md +28 -3
  2. package/package.json +6 -4
  3. package/src/migrations/20210503142857-create-intelligences.js +1 -1
  4. package/src/migrations/20210503154612-create-skills.js +1 -1
  5. package/src/migrations/20210503162618-create-entities-values.js +1 -1
  6. package/src/migrations/20210503162752-create-synonyms.js +1 -1
  7. package/src/migrations/20210503163437-create-responses-boxes.js +1 -1
  8. package/src/migrations/20210503190515-create-apis.js +1 -1
  9. package/src/migrations/20210503191041-create-apis-resources-body.js +1 -1
  10. package/src/migrations/20210503191107-create-apis-resources.js +1 -1
  11. package/src/migrations/20210503193511-create-dialog-nodes.js +1 -1
  12. package/src/migrations/20210504144332-create-messages-hsm.js +1 -1
  13. package/src/migrations/20210727110430-create-endSessionTriggers.js +1 -1
  14. package/src/migrations/20210906144034-alter-api-body-migration.js +2 -2
  15. package/src/migrations/20210927141630-alter-attendances.js +3 -3
  16. package/src/models/apiKeys.js +1 -1
  17. package/src/models/apiResourceBodies.js +1 -1
  18. package/src/models/apiResourceHeaders.js +1 -1
  19. package/src/models/apiResourcePathParams.js +1 -1
  20. package/src/models/apiResourceQueryStringParams.js +1 -1
  21. package/src/models/apiResources.js +1 -1
  22. package/src/models/apis.js +1 -1
  23. package/src/models/attendanceScale.js +1 -1
  24. package/src/models/attendanceScaleOff.js +1 -1
  25. package/src/models/attendances.js +1 -1
  26. package/src/models/botIterable.js +1 -5
  27. package/src/models/branches.js +1 -1
  28. package/src/models/channelConfigurations.js +1 -1
  29. package/src/models/channelTypes.js +15 -1
  30. package/src/models/channels.js +1 -1
  31. package/src/models/client.js +1 -1
  32. package/src/models/comments.js +1 -1
  33. package/src/models/contacts.js +41 -0
  34. package/src/models/customPostbacks.js +1 -1
  35. package/src/models/departments.js +1 -1
  36. package/src/models/dialogNodes.js +1 -1
  37. package/src/models/dialogNodes_MultipleResponses.js +1 -1
  38. package/src/models/dialogNodes_apiResources.js +1 -1
  39. package/src/models/endSessionTriggers.js +1 -1
  40. package/src/models/enterprises.js +1 -1
  41. package/src/models/entity.js +1 -1
  42. package/src/models/entityValues.js +1 -1
  43. package/src/models/faqQuestions.js +1 -1
  44. package/src/models/faqTriggers.js +1 -1
  45. package/src/models/fields.js +28 -0
  46. package/src/models/files.js +1 -1
  47. package/src/models/groups.js +45 -0
  48. package/src/models/groupsContracts.js +13 -0
  49. package/src/models/groupsSendHsms.js +13 -0
  50. package/src/models/ibmProvider.js +1 -1
  51. package/src/models/inactivityTriggers.js +1 -1
  52. package/src/models/index.js +1 -1
  53. package/src/models/intelligence.js +1 -1
  54. package/src/models/intention.js +1 -1
  55. package/src/models/intentionValue.js +1 -1
  56. package/src/models/itleanProvider.js +1 -1
  57. package/src/models/language.js +21 -0
  58. package/src/models/lineConfigurations.js +1 -1
  59. package/src/models/lines.js +1 -1
  60. package/src/models/messagesHsm.js +6 -2
  61. package/src/models/onlineEditions.js +27 -0
  62. package/src/models/openFaqs.js +1 -1
  63. package/src/models/permissions.js +1 -1
  64. package/src/models/postbackGupshup.js +1 -1
  65. package/src/models/profile.js +1 -1
  66. package/src/models/profiles_permission.js +1 -1
  67. package/src/models/quickMessages.js +1 -1
  68. package/src/models/responseChannels.js +39 -0
  69. package/src/models/response_DialogNodes.js +1 -1
  70. package/src/models/responses.js +1 -1
  71. package/src/models/responsesBoxes.js +1 -1
  72. package/src/models/returnHsm.js +1 -1
  73. package/src/models/sendHsm.js +51 -0
  74. package/src/models/sendHsmReturnHsm.js +13 -0
  75. package/src/models/sessions.js +1 -1
  76. package/src/models/skill.js +1 -1
  77. package/src/models/socketClients.js +1 -1
  78. package/src/models/stopwords.js +1 -1
  79. package/src/models/subDepartments.js +1 -1
  80. package/src/models/synonyms.js +1 -1
  81. package/src/models/systemUsers.js +1 -1
  82. package/src/models/systemUsers_Lines.js +1 -1
  83. package/src/models/systemUsers_profiles.js +1 -1
  84. package/src/models/templates.js +1 -1
  85. package/src/models/transhipConversations.js +1 -1
  86. package/src/models/transhipInactivityTriggers.js +1 -1
  87. package/src/models/transhipTriggers.js +1 -1
  88. package/src/presenters/database/migrationHelpers.js +62 -0
  89. package/src/presenters/encryptation.js +14 -0
  90. package/src/seeders/20210505130137-insert-channel-types.js +1 -1
  91. package/src/seeders/20210505132612-insert-intelligence.js +3 -3
  92. package/src/seeders/20210505134700-insert-profiles-permissions.js +3 -3
  93. package/src/seeders/20210505135931-insert-system-users.js +2 -2
  94. package/src/seeders/20210505140259-insert-itlean-provider.js +3 -3
  95. package/src/seeders/20210505140343-insert-templates.js +2 -3
  96. package/src/seeders/20210902160430-insert-apiKey.js +1 -1
  97. package/src/seeders/test/20200924195050-create-ibmprovider.js +38 -0
  98. package/src/seeders/test/20200924195050-create-itlean-provider.js +40 -0
  99. package/src/seeders/test/20200924195050-seed-enterprises.js +24 -0
  100. package/src/seeders/test/20200925184253-seed-skils-itlean-provider.js +37 -0
  101. package/src/seeders/test/20200925184253-seed-skils.js +41 -0
  102. package/src/seeders/test/20200925184254-seed-Intention.js +39 -0
  103. package/src/seeders/test/20200925184258-seed-Intention-values.js +41 -0
  104. package/src/seeders/test/20200925191642-seed-entity-skill-itlean.js +23 -0
  105. package/src/seeders/test/20200925191642-seed-entity.js +23 -0
  106. package/src/seeders/test/20200925191643-seed-entity-values-skill-itlean.js +32 -0
  107. package/src/seeders/test/20200925191643-seed-entity-values.js +33 -0
  108. package/src/seeders/test/20200929132705-seed-dialog-node.js +128 -0
  109. package/src/seeders/test/20201016200600-seed-responses.js +563 -0
  110. package/src/seeders/test/20201104183653-seed-create-ype-skill.js +42 -0
  111. package/src/seeders/test/20201104183700-seed-create-ype-intention.js +26 -0
  112. package/src/seeders/test/20201104183706-seed-create-ype-intention-values.js +70 -0
  113. package/src/seeders/test/20201104183714-seed-create-ype-entity.js +38 -0
  114. package/src/seeders/test/20201104183723-seed-create-ype-entity-values.js +243 -0
  115. package/src/seeders/test/20201104183727-seed-create-ype-synonyms.js +253 -0
  116. package/src/seeders/test/20201104202534-seed-create-ype-node-saudacao.js +124 -0
  117. package/src/seeders/test/20210224171409-create-apiResource.js +114 -0
  118. package/src/seeders/test/20210422144458-seed-context-test.js +175 -0
  119. package/src/seeders/test/20210422181114-seed-jump-node.js +123 -0
  120. package/src/seeders/test/20210422182413-seed-jump-skill.js +123 -0
  121. package/src/seeders/test/20210426100156-seed-api-test.js +138 -0
  122. package/src/seeders/test/20210426103704-seed-multiple-response-test.js +272 -0
  123. package/src/seeders/test/20210426190844-seed-entity-search-test.js +160 -0
  124. package/src/seeders/test/20210427172150-seed-test-with-input-test-fisrt.js +160 -0
  125. package/src/seeders/test/20210428105402-seed-test-condition-1.js +190 -0
  126. package/src/seeders/test/20210430181906-seed-test-input-text-zero.js +120 -0
  127. package/src/seeders/test/20210430183204-seed-ype-test-condition.js +557 -0
  128. package/src/seeders/test/20210503172321-seed-invalid-condition.js +119 -0
  129. package/src/seeders/test/20210505140225-insert-skills.js +41 -0
  130. package/src/seeders/test/20210505183810-seed-chain-with-context.js +147 -0
  131. package/src/seeders/test/20210506125701-seed-with-intention-and-entity-same-name.js +188 -0
  132. package/src/seeders/test/20210507204437-seed-condition-igual-true.js +119 -0
  133. package/src/seeders/test/20210511181006-seed-using-internal-functions.js +274 -0
  134. package/src/seeders/test/20210512140152-seed-ype-real-bot.js +2578 -0
  135. package/src/seeders/test/20210519162746-seed-response-with-context.js +186 -0
  136. package/src/seeders/test/20210524141819-seed-dialog-node-faq.js +244 -0
  137. package/src/seeders/test/20210525180523-seed-regex.js +173 -0
  138. package/src/seeders/test/20210602111930-insert-dialogNodes.js +200 -0
  139. package/src/seeders/test/20210610152534-seed-test-internal-function-in-context.js +216 -0
  140. package/src/seeders/test/20210610181308-seed-test-find-in-array-internal-function.js +147 -0
  141. package/src/seeders/test/20210611101042-bot-example-internal-functions.js +985 -0
  142. package/src/seeders/test/20210613111900-bot-example-api.js +420 -0
  143. package/src/seeders/test/20210614113654-miltiple-response-with-research.js +387 -0
  144. package/src/seeders/test/20210616212102-api-authentication-and-list.js +422 -0
  145. package/src/seeders/test/20210624172310-seed-api-duble-request.js +424 -0
  146. package/src/seeders/test/20210628135630-test-branches.js +224 -0
  147. package/src/seeders/test/20210629141030-test-departments.js +225 -0
  148. package/src/seeders/test/20210630105430-test-subDepartments.js +223 -0
  149. package/src/seeders/test/20210630114011-test-contact.js +178 -0
  150. package/src/seeders/test/20210701130630-test-channels.js +381 -0
  151. package/src/seeders/test/20210702191230-seed-test-counter-in-context.js +122 -0
  152. package/src/seeders/test/20210705061313-test-fields.js +152 -0
  153. package/src/seeders/test/20210705080813-test-groups.js +122 -0
  154. package/src/seeders/test/20210705105918-seed-test-function-slice.js +161 -0
  155. package/src/seeders/test/20210706105508-seed-node-without-condition.js +254 -0
  156. package/src/seeders/test/20210706112906-seed-1.0-on-response.js +172 -0
  157. package/src/seeders/test/20210706145547-seed-clean-context.js +132 -0
  158. package/src/seeders/test/20210707151538-seed-test-response-break-line.js +161 -0
  159. package/src/seeders/test/20210713155530-seed-test-itl0079-875.js +129 -0
  160. package/src/seeders/test/20210715125619-seed-multiple-response-with-several-jumps.js +764 -0
  161. package/src/seeders/test/20210715163606-seed-test-multiple-response-with-jump.js +250 -0
  162. package/src/seeders/test/20210719154025-seed-2-contexts-together.js +133 -0
  163. package/src/seeders/test/20210802144227-seed-end-session-trigger.js +163 -0
  164. package/src/seeders/test/20210803103030-tests-dialogNodes.js +406 -0
  165. package/src/seeders/test/20210804094630-tests-lines.js +487 -0
  166. package/src/seeders/test/20210805104130-tests-lineConfigurations.js +106 -0
  167. package/src/seeders/test/20210805133330-tests-systemUsers.js +507 -0
  168. package/src/seeders/test/20210813124630-tests-getMessagesBySession.js +333 -0
  169. package/src/seeders/test/20210816151830-testes-inactivityTriggers.js +196 -0
  170. package/src/seeders/test/20210830134230-tests-sessionReports.js +254 -0
  171. package/src/seeders/test/20210830165830-tests-attendancesHistory.js +181 -0
  172. package/src/seeders/test/20210927115821-skill-test-open-faq.js +37 -0
  173. package/src/seeders/test/20211004131813-true-and-context-with-parent.js +190 -0
  174. package/src/seeders/test/20211006210203-context-concat-with-text.js +193 -0
  175. package/src/migrations/20210613125036-unnamed-migration.js +0 -21
@@ -0,0 +1,272 @@
1
+ 'use strict'
2
+
3
+ const SkillId = '6388bfff-a7b8-4be7-a231-e3891a537c31'
4
+ const dialogNode1Id = '28ec2994-2385-49b1-9851-6200d1f975d6'
5
+
6
+ const dialogNodeMultiple1Id = '066db5d2-5f6d-41be-9be6-e653266f1d57'
7
+ const dialogNodeMultiple2Id = '11afd5cf-e57b-4b0e-a74f-18922942c61f'
8
+
9
+ const responseId1 = '5748f379-2c16-4639-9e1d-945eae6017f0'
10
+
11
+ const responseMultipleId1 = 'a84c4997-f59d-42e8-a212-3f2e13ea1f4b'
12
+ const responseMultipleId2 = 'd792b4e2-a39b-4800-8809-4c93e6ca1487'
13
+
14
+ module.exports = {
15
+ up: async (queryInterface, Sequelize) => {
16
+ const ibmIntelligenceId = await queryInterface.rawSelect(
17
+ 'Intelligences',
18
+ {
19
+ where: {
20
+ providerType: 'ibm',
21
+ },
22
+ },
23
+ ['id']
24
+ )
25
+
26
+ const ibmProviderId = 'f5cc3829-e441-452f-9bea-70581bde9eff'
27
+
28
+ await queryInterface.bulkInsert(
29
+ 'Skills',
30
+ [
31
+ {
32
+ id: SkillId,
33
+ IntelligenceId: ibmIntelligenceId,
34
+ AwsProviderId: null,
35
+ ItleanProviderId: null,
36
+ IbmProviderId: ibmProviderId,
37
+ name: 'Skill Multiple Response',
38
+ description: 'Multiple Response',
39
+ lang: 'pt-br',
40
+ createdAt: Sequelize.literal('now()'),
41
+ updatedAt: Sequelize.literal('now()'),
42
+ },
43
+ ],
44
+ {}
45
+ )
46
+
47
+ await queryInterface.bulkInsert(
48
+ 'DialogNodes',
49
+ [
50
+ {
51
+ id: dialogNode1Id,
52
+ name: 'by pass multiple response',
53
+ condition: 'input.text === oi',
54
+ SkillId,
55
+ contexts: JSON.stringify({
56
+ test: 'test-value',
57
+ }),
58
+ step: 1,
59
+ replayWait: true,
60
+ type: 'node',
61
+ isMultipleResponse: false,
62
+ JumpToDialogNodeId: null,
63
+ JumpToSkillId: null,
64
+ DialogNodeFolderId: null,
65
+ createdAt: Sequelize.literal('now()'),
66
+ updatedAt: Sequelize.literal('now()'),
67
+ },
68
+
69
+ {
70
+ id: dialogNodeMultiple1Id,
71
+ name: 'by pass multiple response 1',
72
+ condition: 'input.text === oi',
73
+ SkillId,
74
+ contexts: JSON.stringify({
75
+ test: 'test-value',
76
+ }),
77
+ step: 1,
78
+ replayWait: true,
79
+ type: 'node',
80
+ isMultipleResponse: true,
81
+ JumpToDialogNodeId: null,
82
+ JumpToSkillId: null,
83
+ DialogNodeFolderId: null,
84
+ createdAt: Sequelize.literal('now()'),
85
+ updatedAt: Sequelize.literal('now()'),
86
+ },
87
+
88
+ {
89
+ id: dialogNodeMultiple2Id,
90
+ name: 'by pass multiple response 2',
91
+ condition: 'input.text === oi',
92
+ SkillId,
93
+ contexts: JSON.stringify({
94
+ test: 'test-value',
95
+ }),
96
+ step: 2,
97
+ replayWait: true,
98
+ type: 'node',
99
+ isMultipleResponse: true,
100
+ JumpToDialogNodeId: null,
101
+ JumpToSkillId: null,
102
+ DialogNodeFolderId: null,
103
+ createdAt: Sequelize.literal('now()'),
104
+ updatedAt: Sequelize.literal('now()'),
105
+ },
106
+ ],
107
+ {}
108
+ )
109
+
110
+ await queryInterface.bulkInsert(
111
+ 'Responses',
112
+ [
113
+ {
114
+ id: responseId1,
115
+ name: 'Oi! Eu tenho multiplas respostas',
116
+ SkillId,
117
+ createdAt: Sequelize.literal('now()'),
118
+ updatedAt: Sequelize.literal('now()'),
119
+ },
120
+
121
+ {
122
+ id: responseMultipleId1,
123
+ name: 'Oi! Eu tenho sou a resposta do primeiro multiplo',
124
+ SkillId,
125
+ createdAt: Sequelize.literal('now()'),
126
+ updatedAt: Sequelize.literal('now()'),
127
+ },
128
+
129
+ {
130
+ id: responseMultipleId2,
131
+ name: 'Oi! Eu tenho sou a resposta do segundo multiplo',
132
+ SkillId,
133
+ createdAt: Sequelize.literal('now()'),
134
+ updatedAt: Sequelize.literal('now()'),
135
+ },
136
+ ],
137
+ {}
138
+ )
139
+
140
+ await queryInterface.bulkInsert(
141
+ 'ResponsesBoxes',
142
+ [
143
+ {
144
+ ResponseId: responseId1,
145
+ ChannelTypeId: null,
146
+ type: 'flow',
147
+ payload: JSON.stringify([
148
+ {
149
+ id: '',
150
+ type: 'text',
151
+ messages: [{ message: 'Mensagem de teste! 😍' }],
152
+ },
153
+ ]),
154
+ createdAt: Sequelize.literal('now()'),
155
+ updatedAt: Sequelize.literal('now()'),
156
+ },
157
+ {
158
+ ResponseId: responseMultipleId1,
159
+ ChannelTypeId: null,
160
+ type: 'flow',
161
+ payload: JSON.stringify([
162
+ {
163
+ id: '',
164
+ type: 'text',
165
+ messages: [{ message: 'Mensagem de teste! 😍' }],
166
+ },
167
+ ]),
168
+ createdAt: Sequelize.literal('now()'),
169
+ updatedAt: Sequelize.literal('now()'),
170
+ },
171
+ {
172
+ ResponseId: responseMultipleId2,
173
+ ChannelTypeId: null,
174
+ type: 'flow',
175
+ payload: JSON.stringify([
176
+ {
177
+ id: '',
178
+ type: 'text',
179
+ messages: [{ message: 'Mensagem de teste! 😍' }],
180
+ },
181
+ ]),
182
+ createdAt: Sequelize.literal('now()'),
183
+ updatedAt: Sequelize.literal('now()'),
184
+ },
185
+ ],
186
+ {}
187
+ )
188
+
189
+ await queryInterface.bulkInsert('Response_DialogNodes', [
190
+ {
191
+ DialogNodeId: dialogNode1Id,
192
+ ResponseId: responseId1,
193
+ createdAt: Sequelize.literal('now()'),
194
+ updatedAt: Sequelize.literal('now()'),
195
+ },
196
+
197
+ {
198
+ DialogNodeId: dialogNodeMultiple1Id,
199
+ ResponseId: responseMultipleId1,
200
+ createdAt: Sequelize.literal('now()'),
201
+ updatedAt: Sequelize.literal('now()'),
202
+ },
203
+
204
+ {
205
+ DialogNodeId: dialogNodeMultiple2Id,
206
+ ResponseId: responseMultipleId2,
207
+ createdAt: Sequelize.literal('now()'),
208
+ updatedAt: Sequelize.literal('now()'),
209
+ },
210
+ ])
211
+
212
+ await queryInterface.bulkInsert('DialogNodes_MultipleResponses', [
213
+ {
214
+ DialogNodeId: dialogNode1Id,
215
+ ResponseId: dialogNodeMultiple1Id,
216
+ createdAt: Sequelize.literal('now()'),
217
+ updatedAt: Sequelize.literal('now()'),
218
+ },
219
+
220
+ {
221
+ DialogNodeId: dialogNode1Id,
222
+ ResponseId: dialogNodeMultiple2Id,
223
+ createdAt: Sequelize.literal('now()'),
224
+ updatedAt: Sequelize.literal('now()'),
225
+ },
226
+ ])
227
+ },
228
+
229
+ down: async (queryInterface) => {
230
+ await queryInterface.bulkDelete('Response_DialogNodes', [
231
+ { DialogNodeId: dialogNode1Id },
232
+ ])
233
+
234
+ await queryInterface.bulkDelete('Response_DialogNodes', [
235
+ { DialogNodeId: dialogNodeMultiple1Id },
236
+ ])
237
+
238
+ await queryInterface.bulkDelete('Response_DialogNodes', [
239
+ { DialogNodeId: dialogNodeMultiple2Id },
240
+ ])
241
+
242
+ await queryInterface.bulkDelete('DialogNodes_MultipleResponses', [
243
+ { DialogNodeId: dialogNode1Id },
244
+ ])
245
+
246
+ await queryInterface.bulkDelete('ResponsesBoxes', [
247
+ { ResponseId: responseId1 },
248
+ ])
249
+
250
+ await queryInterface.bulkDelete('ResponsesBoxes', [
251
+ { ResponseId: responseMultipleId1 },
252
+ ])
253
+
254
+ await queryInterface.bulkDelete('ResponsesBoxes', [
255
+ { ResponseId: responseMultipleId2 },
256
+ ])
257
+
258
+ await queryInterface.bulkDelete('Responses', [{ id: responseId1 }])
259
+ await queryInterface.bulkDelete('Responses', [{ id: responseMultipleId1 }])
260
+ await queryInterface.bulkDelete('Responses', [{ id: responseMultipleId2 }])
261
+
262
+ await queryInterface.bulkDelete('DialogNodes', [{ id: dialogNode1Id }])
263
+ await queryInterface.bulkDelete('DialogNodes', [
264
+ { id: dialogNodeMultiple1Id },
265
+ ])
266
+ await queryInterface.bulkDelete('DialogNodes', [
267
+ { id: dialogNodeMultiple2Id },
268
+ ])
269
+
270
+ await queryInterface.bulkDelete('Skills', [{ id: SkillId }])
271
+ },
272
+ }
@@ -0,0 +1,160 @@
1
+ 'use strict'
2
+ const SkillId = 'a4e29b43-ad65-44b3-95a2-1083974f96f5'
3
+
4
+ const dialogNode1Id = '0970cb67-7162-4808-b842-55b9476ad490'
5
+
6
+ const responseId1 = '30c0a858-2190-4bf4-8f4e-481a1f544af5'
7
+
8
+ const EntityId = 'ef181875-4f54-44d8-b796-ecc7f6197f08'
9
+
10
+ module.exports = {
11
+ up: async (queryInterface, Sequelize) => {
12
+ const ibmIntelligenceId = await queryInterface.rawSelect(
13
+ 'Intelligences',
14
+ {
15
+ where: {
16
+ providerType: 'ibm',
17
+ },
18
+ },
19
+ ['id']
20
+ )
21
+
22
+ const ibmProviderId = 'f5cc3829-e441-452f-9bea-70581bde9eff'
23
+ await queryInterface.bulkInsert(
24
+ 'Skills',
25
+ [
26
+ {
27
+ id: SkillId,
28
+ IntelligenceId: ibmIntelligenceId,
29
+ AwsProviderId: null,
30
+ ItleanProviderId: null,
31
+ IbmProviderId: ibmProviderId,
32
+ name: 'Skill jump to skill',
33
+ description: 'jump to skill',
34
+ lang: 'pt-br',
35
+ createdAt: Sequelize.literal('now()'),
36
+ updatedAt: Sequelize.literal('now()'),
37
+ },
38
+ ],
39
+ {}
40
+ )
41
+
42
+ await queryInterface.bulkInsert(
43
+ 'Entities',
44
+ [
45
+ {
46
+ id: EntityId,
47
+ name: '@modelo',
48
+ SkillId,
49
+ createdAt: Sequelize.literal('now()'),
50
+ updatedAt: Sequelize.literal('now()'),
51
+ },
52
+ ],
53
+ {}
54
+ )
55
+
56
+ await queryInterface.bulkInsert(
57
+ 'EntityValues',
58
+ [
59
+ {
60
+ EntityId,
61
+ name: 'gol',
62
+ synonyms: 'gol',
63
+ type: 'synonyms',
64
+ createdAt: Sequelize.literal('now()'),
65
+ updatedAt: Sequelize.literal('now()'),
66
+ },
67
+ {
68
+ EntityId,
69
+ name: 'fusca',
70
+ synonyms: 'fusca',
71
+ type: 'synonyms',
72
+ createdAt: Sequelize.literal('now()'),
73
+ updatedAt: Sequelize.literal('now()'),
74
+ },
75
+ ],
76
+ {}
77
+ )
78
+
79
+ await queryInterface.bulkInsert(
80
+ 'DialogNodes',
81
+ [
82
+ {
83
+ id: dialogNode1Id,
84
+ name: 'Re-search entity',
85
+ condition: '@modelo:gol',
86
+ SkillId,
87
+ contexts: '[]',
88
+ step: 1,
89
+ replayWait: true,
90
+ type: 'node',
91
+ isMultipleResponse: false,
92
+ JumpToDialogNodeId: null,
93
+ JumpToSkillId: null,
94
+ DialogNodeFolderId: null,
95
+ createdAt: Sequelize.literal('now()'),
96
+ updatedAt: Sequelize.literal('now()'),
97
+ },
98
+ ],
99
+ {}
100
+ )
101
+
102
+ await queryInterface.bulkInsert(
103
+ 'Responses',
104
+ [
105
+ {
106
+ id: responseId1,
107
+ name: 'Oi! Eu tenho um jump de skill',
108
+ SkillId,
109
+ createdAt: Sequelize.literal('now()'),
110
+ updatedAt: Sequelize.literal('now()'),
111
+ },
112
+ ],
113
+ {}
114
+ )
115
+
116
+ await queryInterface.bulkInsert(
117
+ 'ResponsesBoxes',
118
+ [
119
+ {
120
+ ResponseId: responseId1,
121
+ ChannelTypeId: null,
122
+ type: 'flow',
123
+ payload: JSON.stringify([
124
+ {
125
+ id: '',
126
+ type: 'text',
127
+ messages: [{ message: 'Mensagem de teste! 😍' }],
128
+ },
129
+ ]),
130
+ createdAt: Sequelize.literal('now()'),
131
+ updatedAt: Sequelize.literal('now()'),
132
+ },
133
+ ],
134
+ {}
135
+ )
136
+
137
+ await queryInterface.bulkInsert('Response_DialogNodes', [
138
+ {
139
+ DialogNodeId: dialogNode1Id,
140
+ ResponseId: responseId1,
141
+ createdAt: Sequelize.literal('now()'),
142
+ updatedAt: Sequelize.literal('now()'),
143
+ },
144
+ ])
145
+ },
146
+
147
+ down: async (queryInterface) => {
148
+ await queryInterface.bulkDelete('Response_DialogNodes', [
149
+ { ResponseId: responseId1 },
150
+ ])
151
+ await queryInterface.bulkDelete('ResponsesBoxes', [
152
+ { ResponseId: responseId1 },
153
+ ])
154
+ await queryInterface.bulkDelete('Responses', [{ id: responseId1 }])
155
+ await queryInterface.bulkDelete('DialogNodes', [{ id: dialogNode1Id }])
156
+ await queryInterface.bulkDelete('Entities', [{ SkillId }])
157
+ await queryInterface.bulkDelete('EntityValues', [{ EntityId }])
158
+ await queryInterface.bulkDelete('Skills', [{ id: SkillId }])
159
+ },
160
+ }
@@ -0,0 +1,160 @@
1
+ 'use strict'
2
+ const SkillId = '62417a7b-854a-4539-a491-9c8e619bb4c9'
3
+
4
+ const dialogNode1Id = 'ed2f3b40-4d75-447a-8e43-6342cd67a8c7'
5
+
6
+ const responseId1 = 'f974f0dc-5189-439b-b33e-fb29843db87c'
7
+
8
+ const EntityId = '87e71b8a-f6a0-42d1-b450-eefa7dbbd235'
9
+
10
+ module.exports = {
11
+ up: async (queryInterface, Sequelize) => {
12
+ const ibmIntelligenceId = await queryInterface.rawSelect(
13
+ 'Intelligences',
14
+ {
15
+ where: {
16
+ providerType: 'ibm',
17
+ },
18
+ },
19
+ ['id']
20
+ )
21
+
22
+ const ibmProviderId = 'f5cc3829-e441-452f-9bea-70581bde9eff'
23
+ await queryInterface.bulkInsert(
24
+ 'Skills',
25
+ [
26
+ {
27
+ id: SkillId,
28
+ IntelligenceId: ibmIntelligenceId,
29
+ AwsProviderId: null,
30
+ ItleanProviderId: null,
31
+ IbmProviderId: ibmProviderId,
32
+ name: 'Skill to test input.text first',
33
+ description: 'input.text first in condition',
34
+ lang: 'pt-br',
35
+ createdAt: Sequelize.literal('now()'),
36
+ updatedAt: Sequelize.literal('now()'),
37
+ },
38
+ ],
39
+ {}
40
+ )
41
+
42
+ await queryInterface.bulkInsert(
43
+ 'Entities',
44
+ [
45
+ {
46
+ id: EntityId,
47
+ name: 'celulares',
48
+ SkillId,
49
+ createdAt: Sequelize.literal('now()'),
50
+ updatedAt: Sequelize.literal('now()'),
51
+ },
52
+ ],
53
+ {}
54
+ )
55
+
56
+ await queryInterface.bulkInsert(
57
+ 'EntityValues',
58
+ [
59
+ {
60
+ EntityId,
61
+ name: 'iphone',
62
+ type: 'synonyms',
63
+ synonyms: 'iphone',
64
+ createdAt: Sequelize.literal('now()'),
65
+ updatedAt: Sequelize.literal('now()'),
66
+ },
67
+ {
68
+ EntityId,
69
+ name: 'android',
70
+ type: 'synonyms',
71
+ synonyms: 'android',
72
+ createdAt: Sequelize.literal('now()'),
73
+ updatedAt: Sequelize.literal('now()'),
74
+ },
75
+ ],
76
+ {}
77
+ )
78
+
79
+ await queryInterface.bulkInsert(
80
+ 'DialogNodes',
81
+ [
82
+ {
83
+ id: dialogNode1Id,
84
+ name: 'Re-search entity',
85
+ condition: "input.text == 'oi' || @celulares",
86
+ SkillId,
87
+ contexts: '[]',
88
+ step: 1,
89
+ replayWait: true,
90
+ type: 'node',
91
+ isMultipleResponse: false,
92
+ JumpToDialogNodeId: null,
93
+ JumpToSkillId: null,
94
+ DialogNodeFolderId: null,
95
+ createdAt: Sequelize.literal('now()'),
96
+ updatedAt: Sequelize.literal('now()'),
97
+ },
98
+ ],
99
+ {}
100
+ )
101
+
102
+ await queryInterface.bulkInsert(
103
+ 'Responses',
104
+ [
105
+ {
106
+ id: responseId1,
107
+ name: 'Oi! Eu tenho um input.text na frente',
108
+ SkillId,
109
+ createdAt: Sequelize.literal('now()'),
110
+ updatedAt: Sequelize.literal('now()'),
111
+ },
112
+ ],
113
+ {}
114
+ )
115
+
116
+ await queryInterface.bulkInsert(
117
+ 'ResponsesBoxes',
118
+ [
119
+ {
120
+ ResponseId: responseId1,
121
+ ChannelTypeId: null,
122
+ type: 'flow',
123
+ payload: JSON.stringify([
124
+ {
125
+ id: '',
126
+ type: 'text',
127
+ messages: [{ message: 'Mensagem de teste! 😍' }],
128
+ },
129
+ ]),
130
+ createdAt: Sequelize.literal('now()'),
131
+ updatedAt: Sequelize.literal('now()'),
132
+ },
133
+ ],
134
+ {}
135
+ )
136
+
137
+ await queryInterface.bulkInsert('Response_DialogNodes', [
138
+ {
139
+ DialogNodeId: dialogNode1Id,
140
+ ResponseId: responseId1,
141
+ createdAt: Sequelize.literal('now()'),
142
+ updatedAt: Sequelize.literal('now()'),
143
+ },
144
+ ])
145
+ },
146
+
147
+ down: async (queryInterface) => {
148
+ await queryInterface.bulkDelete('Response_DialogNodes', [
149
+ { ResponseId: responseId1 },
150
+ ])
151
+ await queryInterface.bulkDelete('ResponsesBoxes', [
152
+ { ResponseId: responseId1 },
153
+ ])
154
+ await queryInterface.bulkDelete('Responses', [{ id: responseId1 }])
155
+ await queryInterface.bulkDelete('DialogNodes', [{ id: dialogNode1Id }])
156
+ await queryInterface.bulkDelete('Entities', [{ SkillId }])
157
+ await queryInterface.bulkDelete('EntityValues', [{ EntityId }])
158
+ await queryInterface.bulkDelete('Skills', [{ id: SkillId }])
159
+ },
160
+ }