@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,190 @@
1
+ 'use strict'
2
+ const SkillId = '932e845c-6b2f-42b0-9965-9db2421fb69f'
3
+
4
+ const dialogNode1Id = '82bcbaf1-e483-4331-809c-c5d10c6e6da1'
5
+
6
+ const responseId1 = 'b8bfcc19-1bfa-4c8e-a608-4bb07d3cf4d8'
7
+
8
+ const IntentionPhoneId = '66375023-cdfd-45be-b5c4-6fa80fdba08f'
9
+ const IntentionWelcomeId = '648b19ee-8a44-4ddc-ae6c-34ef408a321b'
10
+
11
+ module.exports = {
12
+ up: async (queryInterface, Sequelize) => {
13
+ const ibmIntelligenceId = await queryInterface.rawSelect(
14
+ 'Intelligences',
15
+ {
16
+ where: {
17
+ providerType: 'ibm',
18
+ },
19
+ },
20
+ ['id']
21
+ )
22
+
23
+ const ibmProviderId = 'f5cc3829-e441-452f-9bea-70581bde9eff'
24
+ await queryInterface.bulkInsert(
25
+ 'Skills',
26
+ [
27
+ {
28
+ id: SkillId,
29
+ IntelligenceId: ibmIntelligenceId,
30
+ AwsProviderId: null,
31
+ ItleanProviderId: null,
32
+ IbmProviderId: ibmProviderId,
33
+ name: 'Skill to test input.text first',
34
+ description: 'input.text first in condition',
35
+ lang: 'pt-br',
36
+ createdAt: Sequelize.literal('now()'),
37
+ updatedAt: Sequelize.literal('now()'),
38
+ },
39
+ ],
40
+ {}
41
+ )
42
+
43
+ await queryInterface.bulkInsert(
44
+ 'Intentions',
45
+ [
46
+ {
47
+ id: IntentionPhoneId,
48
+ name: 'celulares',
49
+ description: 'Created by seeders',
50
+ SkillId,
51
+ createdAt: Sequelize.literal('now()'),
52
+ updatedAt: Sequelize.literal('now()'),
53
+ },
54
+ {
55
+ id: IntentionWelcomeId,
56
+ name: 'saudacao',
57
+ description: 'Created by seeders',
58
+ SkillId,
59
+ createdAt: Sequelize.literal('now()'),
60
+ updatedAt: Sequelize.literal('now()'),
61
+ },
62
+ ],
63
+ {}
64
+ )
65
+
66
+ await queryInterface.bulkInsert(
67
+ 'IntentionValues',
68
+ [
69
+ {
70
+ name: 'iphone',
71
+ IntentionId: IntentionPhoneId,
72
+ createdAt: Sequelize.literal('now()'),
73
+ updatedAt: Sequelize.literal('now()'),
74
+ },
75
+ {
76
+ name: 'android',
77
+ IntentionId: IntentionPhoneId,
78
+ createdAt: Sequelize.literal('now()'),
79
+ updatedAt: Sequelize.literal('now()'),
80
+ },
81
+ {
82
+ name: 'oi',
83
+ IntentionId: IntentionWelcomeId,
84
+ createdAt: Sequelize.literal('now()'),
85
+ updatedAt: Sequelize.literal('now()'),
86
+ },
87
+ {
88
+ name: 'oie',
89
+ IntentionId: IntentionWelcomeId,
90
+ createdAt: Sequelize.literal('now()'),
91
+ updatedAt: Sequelize.literal('now()'),
92
+ },
93
+ {
94
+ name: 'ola',
95
+ IntentionId: IntentionWelcomeId,
96
+ createdAt: Sequelize.literal('now()'),
97
+ updatedAt: Sequelize.literal('now()'),
98
+ },
99
+ ],
100
+ {}
101
+ )
102
+
103
+ await queryInterface.bulkInsert(
104
+ 'DialogNodes',
105
+ [
106
+ {
107
+ id: dialogNode1Id,
108
+ name: 'Re-search entity',
109
+ condition:
110
+ "(#celulares || input.text == 'test1') || input.text == 'test2' || #saudacao",
111
+ SkillId,
112
+ contexts: '[]',
113
+ step: 1,
114
+ replayWait: true,
115
+ type: 'node',
116
+ isMultipleResponse: false,
117
+ JumpToDialogNodeId: null,
118
+ JumpToSkillId: null,
119
+ DialogNodeFolderId: null,
120
+ createdAt: Sequelize.literal('now()'),
121
+ updatedAt: Sequelize.literal('now()'),
122
+ },
123
+ ],
124
+ {}
125
+ )
126
+
127
+ await queryInterface.bulkInsert(
128
+ 'Responses',
129
+ [
130
+ {
131
+ id: responseId1,
132
+ name: 'Oi! Eu sou um teste top',
133
+ SkillId,
134
+ createdAt: Sequelize.literal('now()'),
135
+ updatedAt: Sequelize.literal('now()'),
136
+ },
137
+ ],
138
+ {}
139
+ )
140
+
141
+ await queryInterface.bulkInsert(
142
+ 'ResponsesBoxes',
143
+ [
144
+ {
145
+ ResponseId: responseId1,
146
+ ChannelTypeId: null,
147
+ type: 'flow',
148
+ payload: JSON.stringify([
149
+ {
150
+ id: '',
151
+ type: 'text',
152
+ messages: [{ message: 'Mensagem de teste! 😍' }],
153
+ },
154
+ ]),
155
+ createdAt: Sequelize.literal('now()'),
156
+ updatedAt: Sequelize.literal('now()'),
157
+ },
158
+ ],
159
+ {}
160
+ )
161
+
162
+ await queryInterface.bulkInsert('Response_DialogNodes', [
163
+ {
164
+ DialogNodeId: dialogNode1Id,
165
+ ResponseId: responseId1,
166
+ createdAt: Sequelize.literal('now()'),
167
+ updatedAt: Sequelize.literal('now()'),
168
+ },
169
+ ])
170
+ },
171
+
172
+ down: async (queryInterface) => {
173
+ await queryInterface.bulkDelete('Response_DialogNodes', [
174
+ { ResponseId: responseId1 },
175
+ ])
176
+ await queryInterface.bulkDelete('ResponsesBoxes', [
177
+ { ResponseId: responseId1 },
178
+ ])
179
+ await queryInterface.bulkDelete('Responses', [{ id: responseId1 }])
180
+ await queryInterface.bulkDelete('DialogNodes', [{ id: dialogNode1Id }])
181
+ await queryInterface.bulkDelete('IntentionValues', [
182
+ { IntentionId: IntentionPhoneId },
183
+ ])
184
+ await queryInterface.bulkDelete('IntentionValues', [
185
+ { IntentionId: IntentionWelcomeId },
186
+ ])
187
+ await queryInterface.bulkDelete('Intentions', [{ SkillId }])
188
+ await queryInterface.bulkDelete('Skills', [{ id: SkillId }])
189
+ },
190
+ }
@@ -0,0 +1,120 @@
1
+ 'use strict'
2
+ const SkillId = '69f6c36c-5e97-4d4b-88f5-aa27ae67c738'
3
+
4
+ const dialogNode1Id = 'd7832cfb-9bf1-4c9b-a649-2d5b1f4edf2c'
5
+
6
+ const responseId1 = '5a36d0e9-9264-48d5-9c7a-95e77fc0ac1b'
7
+
8
+ module.exports = {
9
+ up: async (queryInterface, Sequelize) => {
10
+ const ibmIntelligenceId = await queryInterface.rawSelect(
11
+ 'Intelligences',
12
+ {
13
+ where: {
14
+ providerType: 'ibm',
15
+ },
16
+ },
17
+ ['id']
18
+ )
19
+
20
+ const ibmProviderId = 'f5cc3829-e441-452f-9bea-70581bde9eff'
21
+ await queryInterface.bulkInsert(
22
+ 'Skills',
23
+ [
24
+ {
25
+ id: SkillId,
26
+ IntelligenceId: ibmIntelligenceId,
27
+ AwsProviderId: null,
28
+ ItleanProviderId: null,
29
+ IbmProviderId: ibmProviderId,
30
+ name: 'Skill input.text == 0',
31
+ description: 'input.text == 0',
32
+ lang: 'pt-br',
33
+ createdAt: Sequelize.literal('now()'),
34
+ updatedAt: Sequelize.literal('now()'),
35
+ },
36
+ ],
37
+ {}
38
+ )
39
+
40
+ await queryInterface.bulkInsert(
41
+ 'DialogNodes',
42
+ [
43
+ {
44
+ id: dialogNode1Id,
45
+ name: 'Re-search entity',
46
+ condition: 'input.text == 0',
47
+ SkillId,
48
+ contexts: '[]',
49
+ step: 1,
50
+ replayWait: true,
51
+ type: 'node',
52
+ isMultipleResponse: false,
53
+ JumpToDialogNodeId: null,
54
+ JumpToSkillId: null,
55
+ DialogNodeFolderId: null,
56
+ createdAt: Sequelize.literal('now()'),
57
+ updatedAt: Sequelize.literal('now()'),
58
+ },
59
+ ],
60
+ {}
61
+ )
62
+
63
+ await queryInterface.bulkInsert(
64
+ 'Responses',
65
+ [
66
+ {
67
+ id: responseId1,
68
+ name: 'Oi! Minha condição é input.text == 0',
69
+ SkillId,
70
+ createdAt: Sequelize.literal('now()'),
71
+ updatedAt: Sequelize.literal('now()'),
72
+ },
73
+ ],
74
+ {}
75
+ )
76
+
77
+ await queryInterface.bulkInsert(
78
+ 'ResponsesBoxes',
79
+ [
80
+ {
81
+ ResponseId: responseId1,
82
+ ChannelTypeId: null,
83
+ type: 'flow',
84
+ payload: JSON.stringify([
85
+ {
86
+ id: '',
87
+ type: 'text',
88
+ messages: [{ message: 'Mensagem de teste! 😍' }],
89
+ },
90
+ ]),
91
+ createdAt: Sequelize.literal('now()'),
92
+ updatedAt: Sequelize.literal('now()'),
93
+ },
94
+ ],
95
+ {}
96
+ )
97
+
98
+ await queryInterface.bulkInsert('Response_DialogNodes', [
99
+ {
100
+ DialogNodeId: dialogNode1Id,
101
+ ResponseId: responseId1,
102
+ createdAt: Sequelize.literal('now()'),
103
+ updatedAt: Sequelize.literal('now()'),
104
+ },
105
+ ])
106
+ },
107
+
108
+ down: async (queryInterface) => {
109
+ await queryInterface.bulkDelete('Response_DialogNodes', [
110
+ { ResponseId: responseId1 },
111
+ ])
112
+ await queryInterface.bulkDelete('ResponsesBoxes', [
113
+ { ResponseId: responseId1 },
114
+ ])
115
+ await queryInterface.bulkDelete('Responses', [{ id: responseId1 }])
116
+ await queryInterface.bulkDelete('DialogNodes', [{ id: dialogNode1Id }])
117
+
118
+ await queryInterface.bulkDelete('Skills', [{ id: SkillId }])
119
+ },
120
+ }