@izara_project/izara-market-library-service-schemas 1.0.32 → 1.0.33
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.
- package/package.json +1 -1
- package/src/GenerateCodeLibs/src/Consts.js +2 -1
- package/src/MainLibs/src/Consts.js +7 -2
- package/src/reStructure/GenerateCode.js +16 -18
- package/src/reStructure/TemplateData/EndpointPerService/yaml/data.js +1 -1
- package/src/reStructure/TemplateData/externalService/functionNameConfig/data.js +18 -8
- package/src/reStructure/TemplateData/externalService/snsTopicSubscriptions/data.js +15 -15
- package/src/reStructure/TemplateData/externalService/snsTopicSubscriptions/template.ejs +2 -2
- package/src/reStructure/TemplateData/flowSchema/components/upload/createObject/functionYaml/template.ejs +0 -4
- package/src/reStructure/TemplateData/flowSchema/components/upload/createObjectComplete/sns-sqs/data.js +1 -1
- package/src/reStructure/TemplateData/flowSchema/components/websocket/connect/functionYaml/data.js +11 -1
- package/src/reStructure/TemplateData/flowSchema/components/websocket/connect/functionYaml/template.ejs +1 -14
- package/src/reStructure/TemplateData/flowSchema/createRecordByStatusType/storedCacheTemplate.ejs +0 -0
- package/src/reStructure/TemplateData/flowSchema/dynamoDb/data.js +81 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/functionYaml/data.js +202 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/functionYaml/template.ejs +21 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/handler/inv/data.js +77 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/handler/inv/request.json +7 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/handler/inv/template.ejs +64 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/mainFunction/data.js +73 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/mainFunction/request.json +5 -0
- package/src/reStructure/TemplateData/flowSchema/eventBridge/mainFunction/template.ejs +88 -0
- package/src/reStructure/TemplateData/flowSchema/externalTopic/sqs/handler/data.js +1 -1
- package/src/reStructure/TemplateData/flowSchema/externalTopic/sqs/mainFunction/data.js +1 -1
- package/src/reStructure/TemplateData/flowSchema/externalTopic/websocket/handler/data.js +1 -1
- package/src/reStructure/TemplateData/flowSchema/externalTopic/websocket/mainFunction/data.js +1 -1
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComplete/functionYaml/data.js +89 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComplete/functionYaml/template.ejs +20 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComplete/handler/data.js +57 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComplete/handler/template.ejs +85 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComplete/mainFunction/data.js +55 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComplete/mainFunction/template.ejs +85 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComponent/functionYaml/data.js +3 -28
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComponent/functionYaml/template.ejs +6 -10
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComponent/handler/data.js +4 -2
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComponent/handler/template.ejs +4 -3
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComponent/mainFunction/template.ejs +26 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/FlowSchemaCompleteComponent/functionYaml/data.js +2 -2
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/FlowSchemaCompleteComponent/functionYaml/template.ejs +6 -10
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/FlowSchemaCompleteComponent/handler/data.js +4 -4
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/FlowSchemaComponent/functionYaml/template.ejs +0 -4
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/FlowSchemaComponent/mainFunction/template.ejs +3 -4
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/sns-in/data.js +18 -18
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/sns-in/sqsTemplate.ejs +53 -0
- package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/sns-out/data.js +77 -0
- package/src/reStructure/TemplateData/flowSchema/generateTemplateData.js +55 -10
- package/src/reStructure/TemplateData/generateRole/createSharedResource.js +27 -7
- package/src/reStructure/TemplateData/flowSchema/externalTopic/sqs/handler/template copy.ejs +0 -125
- /package/src/reStructure/TemplateData/flowSchema/{flowSchemaOwnTopic/sns-in/template.ejs → createRecordByStatusType/statusFieldTemplate.ejs} +0 -0
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Copyright (C) 2020 Sven Mason <http: //izara.io>
|
|
3
|
+
|
|
4
|
+
This program is free software: you can redistribute it and/or modify
|
|
5
|
+
it under the terms of the GNU Affero General Public License as
|
|
6
|
+
published by the Free Software Foundation, either version 3 of the
|
|
7
|
+
License, or (at your option) any later version.
|
|
8
|
+
|
|
9
|
+
This program is distributed in the hope that it will be useful,
|
|
10
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
11
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
12
|
+
GNU Affero General Public License for more details.
|
|
13
|
+
|
|
14
|
+
You should have received a copy of the GNU Affero General Public License
|
|
15
|
+
along with this program. If not, see
|
|
16
|
+
<http: //www.gnu.org/licenses />.
|
|
17
|
+
*/
|
|
18
|
+
|
|
19
|
+
'use strict';
|
|
20
|
+
|
|
21
|
+
const hash = require("object-hash");
|
|
22
|
+
const getObjectSchema = require('@izara_project/izara-core-library-service-schemas/src/GetObjectSchema');
|
|
23
|
+
|
|
24
|
+
const dynamodbSharedLib = require('@izara_project/izara-core-library-dynamodb');
|
|
25
|
+
const snsSharedLib = require('@izara_project/izara-core-library-sns');
|
|
26
|
+
const asyncFlowSharedLib = require('@izara_project/izara-core-library-asynchronous-flow');
|
|
27
|
+
const callingFlowSharedLib = require('@izara_project/izara-core-library-calling-flow');
|
|
28
|
+
const lambdaSharedLib = require('@izara_project/izara-core-library-lambda');
|
|
29
|
+
|
|
30
|
+
const externalRequest = require('@izara_project/izara-core-library-external-request');
|
|
31
|
+
const sns = externalRequest.sns
|
|
32
|
+
const { postToConnection } = require("../../../../libs/source/GenerateCodeLibs");
|
|
33
|
+
const utils = require('@izara_project/izara-market-library-service-schemas/src/MainLibs/src/Utils')
|
|
34
|
+
const NoRetryError = require('@izara_project/izara-core-library-core').NoRetryError
|
|
35
|
+
const { v4: uuidv4 } = require('uuid')
|
|
36
|
+
const coreConsts = require("@izara_project/izara-core-library-core/src/Consts");
|
|
37
|
+
const { TOPIC_NAME_GENERATE_CODE } = require('@izara_project/izara-market-library-service-schemas/src/GenerateCodeLibs/src/Consts')
|
|
38
|
+
/**
|
|
39
|
+
*
|
|
40
|
+
*
|
|
41
|
+
* description of function.
|
|
42
|
+
* @param {Object} _izContext
|
|
43
|
+
* @param {CorrelationIds} _izContext.correlationIds - property of _izContext
|
|
44
|
+
* @param {Logger} _izContext.logger - property of _izContext
|
|
45
|
+
* @param {Object} requestParams - request params
|
|
46
|
+
* @param {Object} requestParams.identifiers - identifiers for get data
|
|
47
|
+
* @param {Object} requestParams.additionalRequest - additionalRequest
|
|
48
|
+
*
|
|
49
|
+
*
|
|
50
|
+
* @returns {object} description of return value
|
|
51
|
+
*/
|
|
52
|
+
|
|
53
|
+
module.exports.FlowSchemaOwnTopicEndpointComplete = async (
|
|
54
|
+
_izContext,
|
|
55
|
+
requestParams,
|
|
56
|
+
callingFlowConfig = {},
|
|
57
|
+
//(<additionalParams>)
|
|
58
|
+
//(</additionalParams>)
|
|
59
|
+
) => {
|
|
60
|
+
|
|
61
|
+
try {
|
|
62
|
+
_izContext.logger.debug("FlowSchemaOwnTopicEndpointComplete _izContext", _izContext)
|
|
63
|
+
_izContext.logger.debug("FlowSchemaOwnTopicEndpointComplete requestParams", requestParams)
|
|
64
|
+
_izContext.logger.debug("FlowSchemaOwnTopicEndpointComplete callingFlowConfig", callingFlowConfig)
|
|
65
|
+
|
|
66
|
+
//(<endpointCompleteHookMainFunction>)
|
|
67
|
+
//(</endpointCompleteHookMainFunction>)
|
|
68
|
+
|
|
69
|
+
let messageObject = {
|
|
70
|
+
//(<messageObjectHook>)
|
|
71
|
+
//(</messageObjectHook>)
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
let sendMessageToOutFlowSchema = {
|
|
75
|
+
Message: JSON.stringify(messageObject),
|
|
76
|
+
TopicArn: await snsSharedLib.snsTopicArnByFlowSchema(_izContext, "<%- topicArn %>")
|
|
77
|
+
};
|
|
78
|
+
_izContext.logger.debug("before sendMessageToOutFlowSchema::", sendMessageToOutFlowSchema);
|
|
79
|
+
await sns.publishAsync(_izContext, sendMessageToOutFlowSchema)
|
|
80
|
+
|
|
81
|
+
} catch (err) {
|
|
82
|
+
_izContext.logger.error('error FlowSchemaOwnTopicEndpointComplete: ', err)
|
|
83
|
+
throw (err)
|
|
84
|
+
}
|
|
85
|
+
}
|
|
@@ -18,7 +18,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
18
18
|
'use strict';
|
|
19
19
|
const path = require('path');
|
|
20
20
|
|
|
21
|
-
const { FLOW_SCHEMA_HOOK_STATE, ACTIONS } = require('@izara_project/izara-core-library-service-schemas/src/Consts')
|
|
21
|
+
const { FLOW_SCHEMA_HOOK_STATE, ACTIONS, HANDLER } = require('@izara_project/izara-core-library-service-schemas/src/Consts')
|
|
22
22
|
const { firstLetterUpperCase: upperCase } = require('../../../../../../MainLibs/src/Utils')
|
|
23
23
|
const {
|
|
24
24
|
SOURCE_PATH,
|
|
@@ -52,36 +52,11 @@ function data(_izContext, flowSchema, srcPath) {
|
|
|
52
52
|
|
|
53
53
|
function createSourceParams(_izContext, flowSchema, srcPath) {
|
|
54
54
|
let functionName = upperCase(FUNCTION_NAME.flowSchemaOwnTopicEndpoint)
|
|
55
|
-
let handlerType = upperCase(
|
|
55
|
+
let handlerType = upperCase(HANDLER.hdrSqs)
|
|
56
56
|
let additionalResourcePermission = defaultIamRolePerAction();
|
|
57
57
|
let route = flowSchema.flowTag;
|
|
58
58
|
|
|
59
|
-
additionalResourcePermission.push(
|
|
60
|
-
createIamRole(
|
|
61
|
-
{
|
|
62
|
-
[RESOURCE_CLASSES.dynamoDbTable]: [
|
|
63
|
-
DYNAMO_RESOURCE.putItem,
|
|
64
|
-
DYNAMO_RESOURCE.getItem,
|
|
65
|
-
DYNAMO_RESOURCE.query,
|
|
66
|
-
DYNAMO_RESOURCE.deleteItem,
|
|
67
|
-
DYNAMO_RESOURCE.updateItem
|
|
68
|
-
]
|
|
69
|
-
},
|
|
70
|
-
[
|
|
71
|
-
resourceNames(RESOURCE_CLASSES.dynamoDbTable, "WebSocketTask")
|
|
72
|
-
]
|
|
73
|
-
),
|
|
74
|
-
createIamRole(
|
|
75
|
-
{
|
|
76
|
-
"execute-api": [
|
|
77
|
-
"ManageConnections"
|
|
78
|
-
]
|
|
79
|
-
},
|
|
80
|
-
[
|
|
81
|
-
resourceNames(RESOURCE_CLASSES.webSocket)
|
|
82
|
-
]
|
|
83
|
-
)
|
|
84
|
-
)
|
|
59
|
+
additionalResourcePermission.push()
|
|
85
60
|
|
|
86
61
|
|
|
87
62
|
return {
|
|
@@ -3,16 +3,12 @@
|
|
|
3
3
|
handler: <%- join(resourceLocation, `${firstLetterUpperCase(functionName)}_${firstLetterUpperCase(handlerType)}.main`)%>
|
|
4
4
|
name: ${self:custom.iz_resourcePrefix}<%- firstLetterUpperCase(functionName) %><%- firstLetterUpperCase(handlerType) %>
|
|
5
5
|
events:
|
|
6
|
-
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
- websocket:
|
|
13
|
-
route: <%- route %>
|
|
14
|
-
# authorizer: ${self:custom.iz_authorizerAppLevel}
|
|
15
|
-
# identifierResource: 'route.request.header.Auth'
|
|
6
|
+
- sqs:
|
|
7
|
+
arn: arn:aws:sqs:${self:custom.iz_region}:${self:custom.iz_accountId}:${self:custom.iz_resourcePrefix}<%- functionName %>
|
|
8
|
+
batchSize: 10
|
|
9
|
+
filterPatterns: #**** need to update serverless framwork upper v.2.69.1
|
|
10
|
+
- body: {"MessageAttributes":{"callingFlow":{"Value":["${self:custom.iz_resourcePrefix}<%- functionName %>"]}}} # functionName of callingFlow
|
|
11
|
+
- body: {"MessageAttributes":{"callingFlow":{"Value":[{"exists":false}]}}}
|
|
16
12
|
role: <%- roleName %>Role
|
|
17
13
|
#<#<%- functionName %><%- handlerType %>IamRole#>
|
|
18
14
|
#<#/<%- functionName %><%- handlerType %>IamRole#>
|
package/src/reStructure/TemplateData/flowSchema/flowSchemaOwnTopic/EndpointComponent/handler/data.js
CHANGED
|
@@ -37,14 +37,16 @@ function data(_izContext, flowSchema, srcPath) {
|
|
|
37
37
|
|
|
38
38
|
function createParamsForCreateSource(_izContext, flowSchema, srcPath) {
|
|
39
39
|
let functionName = upperCase(FUNCTION_NAME.flowSchemaOwnTopicEndpoint)
|
|
40
|
-
let handlerType = HANDLER.hdrSqs
|
|
40
|
+
let handlerType = upperCase(HANDLER.hdrSqs)
|
|
41
41
|
let route = flowSchema.flowTag;
|
|
42
|
+
let queueName = functionName
|
|
42
43
|
return {
|
|
43
44
|
templatePath: templatePath,
|
|
44
45
|
templateData: {
|
|
45
46
|
functionName,
|
|
46
47
|
handlerType,
|
|
47
|
-
route
|
|
48
|
+
route,
|
|
49
|
+
queueName
|
|
48
50
|
},
|
|
49
51
|
setting: {
|
|
50
52
|
savePath: path.join(srcPath, SOURCE_PATH.flowSchemaOwnTopic, flowSchema.flowTag, "source/"),
|
|
@@ -28,6 +28,7 @@ const Logger = require('@izara_project/izara-core-library-logger');
|
|
|
28
28
|
const FlowSchemaOwnTopicEndpoint = require('./FlowSchemaOwnTopicEndpoint_Main')
|
|
29
29
|
|
|
30
30
|
// validate event properties in body.Message of sqs event
|
|
31
|
+
let perRecordsValidatorSchema = {}
|
|
31
32
|
middleware.setValidatorSchema(recordHandlerSharedLib.baseValidatorSchema());
|
|
32
33
|
|
|
33
34
|
module.exports.main = middleware.wrap(async (event, context, callback) => {
|
|
@@ -45,7 +46,7 @@ module.exports.main = middleware.wrap(async (event, context, callback) => {
|
|
|
45
46
|
//validate message (and MessageAttributes)
|
|
46
47
|
await recordHandlerSharedLib.validateRecord(
|
|
47
48
|
record, // one record will send to mainFunction
|
|
48
|
-
"
|
|
49
|
+
"<%- queueName %>", // queue name that need to retry or send to dlq
|
|
49
50
|
perRecordsValidatorSchema, // schema for record.Message
|
|
50
51
|
// messageAttributeValidatorSchema // ----- for msgAttr default is null -> do not send this parameter if not want to validate msgAtt
|
|
51
52
|
);
|
|
@@ -57,8 +58,8 @@ module.exports.main = middleware.wrap(async (event, context, callback) => {
|
|
|
57
58
|
// call recordHandlerSharedLib.recordHandler with 3 parameters and return promise(resolve)
|
|
58
59
|
let recordPromise = recordHandlerSharedLib.recordHandler(
|
|
59
60
|
record, // one record will send to mainFunction
|
|
60
|
-
|
|
61
|
-
"
|
|
61
|
+
<%- functionName %>.<%- functionName %>, // mainFunction that need to invoke.
|
|
62
|
+
"<%- queueName %>", // queue name that need to retry or send to dlq
|
|
62
63
|
passOnProperties, // all parameters that mainFunction needed.
|
|
63
64
|
);
|
|
64
65
|
record._izContext.logger.debug('after recordPromise in handler');
|
|
@@ -66,6 +66,32 @@ module.exports.FlowSchemaOwnTopicEndpoint = async (
|
|
|
66
66
|
//(<endpointHookMainFunction>)
|
|
67
67
|
//(</endpointHookMainFunction>)
|
|
68
68
|
|
|
69
|
+
let messageObject = {
|
|
70
|
+
//(<messageObject>)
|
|
71
|
+
//(</messageObject>)
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
messageObject = callingFlowSharedLib.addCallingFlowToSnsRequestMessageObject(
|
|
75
|
+
sendMessageToTranslateIdIterFromAHdrDsq,
|
|
76
|
+
callingFlowSharedLib.addParentCallingFlowConfig(
|
|
77
|
+
callingFlow,
|
|
78
|
+
callingFlowSharedLib.createCallingFlowConfig(
|
|
79
|
+
await lambdaSharedLib.lambdaFunctionName(_izContext, TOPIC_NAME_GENERATE_CODE.flowSchemaOwnTopicComplete), {}
|
|
80
|
+
)
|
|
81
|
+
)
|
|
82
|
+
)
|
|
83
|
+
|
|
84
|
+
let sendMessageToFlowSchemaOutEndpointComplete = {
|
|
85
|
+
MessageBody: JSON.stringify(messageObject),
|
|
86
|
+
QueueUrl: await sqsSharedLib.sqsQueueUrl(_izContext, "FlowSchemaOwnTopicEndpointHdrSqs")
|
|
87
|
+
}
|
|
88
|
+
_izContext.logger.debug("before sendMessageToFlowSchemaOutEndpointComplete::",sendMessageToFlowSchemaOutEndpointComplete),
|
|
89
|
+
await sqs.sendMessage(_izContext, sendMessageToFlowSchemaOutEndpointComplete);
|
|
90
|
+
|
|
91
|
+
return {
|
|
92
|
+
//(<returnParams>)
|
|
93
|
+
//(</returnParams>)
|
|
94
|
+
}
|
|
69
95
|
} catch (err) {
|
|
70
96
|
_izContext.logger.error('error WebSocketInvoke: ', err)
|
|
71
97
|
throw (err)
|
|
@@ -18,7 +18,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
18
18
|
'use strict';
|
|
19
19
|
const path = require('path');
|
|
20
20
|
|
|
21
|
-
const { FLOW_SCHEMA_HOOK_STATE, ACTIONS } = require('@izara_project/izara-core-library-service-schemas/src/Consts')
|
|
21
|
+
const { FLOW_SCHEMA_HOOK_STATE, ACTIONS, HANDLER } = require('@izara_project/izara-core-library-service-schemas/src/Consts')
|
|
22
22
|
const { firstLetterUpperCase: upperCase } = require('../../../../../../MainLibs/src/Utils')
|
|
23
23
|
const {
|
|
24
24
|
SOURCE_PATH,
|
|
@@ -52,7 +52,7 @@ function data(_izContext, flowSchema, srcPath) {
|
|
|
52
52
|
|
|
53
53
|
function createSourceParams(_izContext, flowSchema, srcPath) {
|
|
54
54
|
let functionName = upperCase(FUNCTION_NAME.flowSchemaOwnTopicComplete)
|
|
55
|
-
let handlerType = upperCase(
|
|
55
|
+
let handlerType = upperCase(HANDLER.hdrSqs)
|
|
56
56
|
let additionalResourcePermission = defaultIamRolePerAction();
|
|
57
57
|
let route = flowSchema.flowTag;
|
|
58
58
|
let flowStep = Object.keys(flowSchema.flowSteps)
|
|
@@ -3,16 +3,12 @@
|
|
|
3
3
|
handler: <%- join(resourceLocation, `${firstLetterUpperCase(functionName)}_${firstLetterUpperCase(handlerType)}.main`)%>
|
|
4
4
|
name: ${self:custom.iz_resourcePrefix}<%- firstLetterUpperCase(functionName) %><%- firstLetterUpperCase(handlerType) %>
|
|
5
5
|
events:
|
|
6
|
-
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
- websocket:
|
|
13
|
-
route: <%- route %>
|
|
14
|
-
# authorizer: ${self:custom.iz_authorizerAppLevel}
|
|
15
|
-
# identifierResource: 'route.request.header.Auth'
|
|
6
|
+
- sqs:
|
|
7
|
+
arn: arn:aws:sqs:${self:custom.iz_region}:${self:custom.iz_accountId}:${self:custom.iz_resourcePrefix}<%- functionName %>
|
|
8
|
+
batchSize: 10
|
|
9
|
+
filterPatterns: #**** need to update serverless framwork upper v.2.69.1
|
|
10
|
+
- body: {"MessageAttributes":{"callingFlow":{"Value":["${self:custom.iz_resourcePrefix}<%- functionName %>"]}}} # functionName of callingFlow
|
|
11
|
+
- body: {"MessageAttributes":{"callingFlow":{"Value":[{"exists":false}]}}}
|
|
16
12
|
role: <%- roleName %>Role
|
|
17
13
|
#<#<%- functionName %><%- handlerType %>IamRole#>
|
|
18
14
|
#<#/<%- functionName %><%- handlerType %>IamRole#>
|
|
@@ -17,7 +17,7 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
17
17
|
|
|
18
18
|
'use strict';
|
|
19
19
|
const path = require('path');
|
|
20
|
-
const { FLOW_SCHEMA_HOOK_STATE } = require('@izara_project/izara-core-library-service-schemas/src/Consts')
|
|
20
|
+
const { FLOW_SCHEMA_HOOK_STATE, HANDLER } = require('@izara_project/izara-core-library-service-schemas/src/Consts')
|
|
21
21
|
const { SOURCE_PATH, FUNCTION_NAME } = require('../../../../../../MainLibs/src/Consts');
|
|
22
22
|
const { firstLetterLowerCase: lowerCase, firstLetterUpperCase: upperCase } = require("../../../../../../MainLibs/src/Utils")
|
|
23
23
|
const templatePath = path.join(__dirname, "template.ejs")
|
|
@@ -37,14 +37,14 @@ function data(_izContext, flowSchema, srcPath) {
|
|
|
37
37
|
|
|
38
38
|
function createParamsForCreateSource(_izContext, flowSchema, srcPath) {
|
|
39
39
|
let functionName = upperCase(FUNCTION_NAME.flowSchemaOwnTopicComplete)
|
|
40
|
-
let handlerType =
|
|
41
|
-
let
|
|
40
|
+
let handlerType = upperCase(HANDLER.hdrSqs)
|
|
41
|
+
let queueName = upperCase(functionName) + upperCase(handlerType);
|
|
42
42
|
return {
|
|
43
43
|
templatePath: templatePath,
|
|
44
44
|
templateData: {
|
|
45
45
|
functionName,
|
|
46
46
|
handlerType,
|
|
47
|
-
|
|
47
|
+
queueName
|
|
48
48
|
},
|
|
49
49
|
setting: {
|
|
50
50
|
savePath: path.join(srcPath, SOURCE_PATH.flowSchemaOwnTopic, flowSchema.flowTag, "source/"),
|
|
@@ -3,10 +3,6 @@
|
|
|
3
3
|
handler: <%- join(resourceLocation, `${firstLetterUpperCase(functionName)}_${firstLetterUpperCase(handlerType)}.main`)%>
|
|
4
4
|
name: ${self:custom.iz_resourcePrefix}<%- firstLetterUpperCase(functionName) %><%- firstLetterUpperCase(handlerType) %>
|
|
5
5
|
events:
|
|
6
|
-
- websocket:
|
|
7
|
-
route: $connect
|
|
8
|
-
- websocket:
|
|
9
|
-
route: $disconnect
|
|
10
6
|
- websocket:
|
|
11
7
|
route: $default
|
|
12
8
|
- websocket:
|
|
@@ -64,16 +64,15 @@ module.exports.flowSchemaOwnTopic = async (
|
|
|
64
64
|
_izContext.logger.debug("WebSocketInvoke callingFlowConfig", callingFlowConfig)
|
|
65
65
|
|
|
66
66
|
let flowSchema = await getObjectSchema.getFlowSchemaS3WithCache(_izContext, {
|
|
67
|
-
flowTag: requestParams.
|
|
67
|
+
flowTag: requestParams.action,
|
|
68
68
|
serviceTag: process.env.iz_serviceTag
|
|
69
|
-
// serviceTag: "GenerateCodeTamplateBas002"
|
|
70
69
|
})
|
|
71
70
|
|
|
72
71
|
_izContext.logger.debug("flowSchema", flowSchema)
|
|
73
72
|
|
|
74
73
|
|
|
75
74
|
if (!flowSchema) {
|
|
76
|
-
throw new NoRetryError(`flowTag not found ${requestParams.
|
|
75
|
+
throw new NoRetryError(`flowTag not found ${requestParams.action}`)
|
|
77
76
|
}
|
|
78
77
|
|
|
79
78
|
let messageObject = {
|
|
@@ -92,7 +91,7 @@ module.exports.flowSchemaOwnTopic = async (
|
|
|
92
91
|
|
|
93
92
|
let sendMessageToCreateEndpoint = {
|
|
94
93
|
Message: JSON.stringify(messageObject),
|
|
95
|
-
TopicArn: await snsSharedLib.snsTopicArnByFlowSchema(_izContext, )
|
|
94
|
+
TopicArn: await snsSharedLib.snsTopicArnByFlowSchema(_izContext, "<%- topicArn %>")
|
|
96
95
|
}
|
|
97
96
|
_izContext.logger.debug("sendMessageToCreateEndpoint", sendMessageToCreateEndpoint);
|
|
98
97
|
await sns.publishAsync(_izContext, sendMessageToCreateEndpoint);
|
|
@@ -25,16 +25,15 @@ const path = require("path")
|
|
|
25
25
|
// STORAGE_TYPES
|
|
26
26
|
// } = require('@izara_project/izara-core-library-service-schemas/src/Consts');
|
|
27
27
|
|
|
28
|
-
const { firstLetterLowerCase: lowerCase, firstLetterUpperCase: upperCase } = require("
|
|
28
|
+
const { firstLetterLowerCase: lowerCase, firstLetterUpperCase: upperCase } = require("../../../../../MainLibs/src/Utils.js");
|
|
29
29
|
const STORAGE_TYPES = {
|
|
30
30
|
dynamoDB: "dynamoDB",
|
|
31
31
|
graph: "graph"
|
|
32
32
|
}
|
|
33
33
|
|
|
34
|
-
const snsTemplatePath = path.join(__dirname, '
|
|
34
|
+
const snsTemplatePath = path.join(__dirname, '../../../resourceYaml/sns-in-sqs/snsTemplate.ejs');
|
|
35
35
|
const sqsTemplatePath = path.join(__dirname, './sqsTemplate.ejs');
|
|
36
|
-
const { SOURCE_PATH, SAVE_FILE_NAME, FUNCTION_NAME, HANDLER } = require('
|
|
37
|
-
|
|
36
|
+
const { SOURCE_PATH, SAVE_FILE_NAME, FUNCTION_NAME, HANDLER } = require('../../../../../MainLibs/src/Consts.js');
|
|
38
37
|
|
|
39
38
|
/**
|
|
40
39
|
* create data for dynamoDbYaml tempalte from objectSchema
|
|
@@ -46,9 +45,9 @@ const { SOURCE_PATH, SAVE_FILE_NAME, FUNCTION_NAME, HANDLER } = require('../../.
|
|
|
46
45
|
* @returns {Object[]} - data of multiple dynamoDb template
|
|
47
46
|
*/
|
|
48
47
|
|
|
49
|
-
function createDataForDefaultSnsInSqs(_izContext, srcPath) {
|
|
48
|
+
function createDataForDefaultSnsInSqs(_izContext, flowSchema, srcPath) {
|
|
50
49
|
let resultsForCreateDefaultSnsInSqs = [];
|
|
51
|
-
|
|
50
|
+
|
|
52
51
|
const setting = {
|
|
53
52
|
initialData: "Resources:\n",
|
|
54
53
|
savePath: path.join(srcPath, SOURCE_PATH.resourceYaml),
|
|
@@ -58,19 +57,15 @@ function createDataForDefaultSnsInSqs(_izContext, srcPath) {
|
|
|
58
57
|
}
|
|
59
58
|
|
|
60
59
|
// GCTpBasTestInPersonCreate => GCTpBas_Test_PersonCreate_In
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
queueName: upperCase(FUNCTION_NAME.findData)
|
|
64
|
-
},
|
|
60
|
+
let flowSteps = Object.keys(flowSchema.flowSteps)
|
|
61
|
+
const generatedSnsTopicInForFlowSchema = [
|
|
65
62
|
{
|
|
66
|
-
queueName: upperCase(
|
|
63
|
+
queueName: upperCase(flowSteps[0].split("_")[0]),
|
|
67
64
|
},
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
}
|
|
71
|
-
)
|
|
65
|
+
];
|
|
66
|
+
|
|
72
67
|
|
|
73
|
-
for (let defaultSnsInSqsData of
|
|
68
|
+
for (let defaultSnsInSqsData of generatedSnsTopicInForFlowSchema) {
|
|
74
69
|
resultsForCreateDefaultSnsInSqs.push({
|
|
75
70
|
templatePath: snsTemplatePath,
|
|
76
71
|
templateData: defaultSnsInSqsData,
|
|
@@ -80,8 +75,12 @@ function createDataForDefaultSnsInSqs(_izContext, srcPath) {
|
|
|
80
75
|
|
|
81
76
|
let defaultDsqQueueDataList = [
|
|
82
77
|
{
|
|
83
|
-
queueName: upperCase(FUNCTION_NAME.
|
|
84
|
-
|
|
78
|
+
queueName: upperCase(FUNCTION_NAME.flowSchemaOwnTopicEndpointComplete) + upperCase(HANDLER.hdrSqs),
|
|
79
|
+
subscribeTo: upperCase(flowSteps[1].split("_")[0])
|
|
80
|
+
},
|
|
81
|
+
// {
|
|
82
|
+
// queueName: upperCase(FUNCTION_NAME.flowSchemaOwnTopicComplete) + upperCase(HANDLER.hdrSqs)
|
|
83
|
+
// }
|
|
85
84
|
]
|
|
86
85
|
for (let defaultDsqQueueData of defaultDsqQueueDataList) {
|
|
87
86
|
resultsForCreateDefaultSnsInSqs.push({
|
|
@@ -90,6 +89,7 @@ function createDataForDefaultSnsInSqs(_izContext, srcPath) {
|
|
|
90
89
|
setting: setting
|
|
91
90
|
})
|
|
92
91
|
}
|
|
92
|
+
console.log()
|
|
93
93
|
return resultsForCreateDefaultSnsInSqs;
|
|
94
94
|
}
|
|
95
95
|
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
<% if (subscribeTo) { %>
|
|
2
|
+
##===== SNS Subscription
|
|
3
|
+
##===== [Topic In]
|
|
4
|
+
SubscriptionToOut<%- subscribeTo %>:
|
|
5
|
+
Type: AWS::SNS::Subscription
|
|
6
|
+
Properties:
|
|
7
|
+
TopicArn: !Ref Out<%- subscribeTo %>
|
|
8
|
+
Endpoint: "arn:aws:sqs:${self:custom.iz_region}:${self:custom.iz_accountId}:${self:custom.iz_resourcePrefix}<%- queueName %>"
|
|
9
|
+
Protocol: "sqs"
|
|
10
|
+
<% } %>
|
|
11
|
+
#------- queue ---------
|
|
12
|
+
<%- queueName %>:
|
|
13
|
+
Type: "AWS::SQS::Queue"
|
|
14
|
+
Properties:
|
|
15
|
+
QueueName: ${self:custom.iz_resourcePrefix}<%- queueName %>
|
|
16
|
+
RedrivePolicy:
|
|
17
|
+
deadLetterTargetArn: #!GetAtt
|
|
18
|
+
Fn::GetAtt:
|
|
19
|
+
- <%- queueName %>DLQ
|
|
20
|
+
- Arn
|
|
21
|
+
maxReceiveCount: 3
|
|
22
|
+
VisibilityTimeout: 120
|
|
23
|
+
|
|
24
|
+
<%- queueName %>DLQ:
|
|
25
|
+
Type: AWS::SQS::Queue
|
|
26
|
+
Properties:
|
|
27
|
+
QueueName: ${self:custom.iz_resourcePrefix}<%- queueName %>DLQ
|
|
28
|
+
|
|
29
|
+
<%- queueName %>Policy:
|
|
30
|
+
Type: AWS::SQS::QueuePolicy
|
|
31
|
+
Properties:
|
|
32
|
+
PolicyDocument:
|
|
33
|
+
Version: "2012-10-17"
|
|
34
|
+
Statement:
|
|
35
|
+
- Sid: "allow-sns-messages"
|
|
36
|
+
Effect: Allow
|
|
37
|
+
Principal: "*"
|
|
38
|
+
Resource: #!GetAtt
|
|
39
|
+
Fn::GetAtt:
|
|
40
|
+
- <%- queueName %>
|
|
41
|
+
- Arn
|
|
42
|
+
Action: "SQS:SendMessage"
|
|
43
|
+
Queues:
|
|
44
|
+
- Ref: <%- queueName %>
|
|
45
|
+
#<#<%- firstLetterUpperCase(queueName) %>QueueSetting#>
|
|
46
|
+
#<#/<%- firstLetterUpperCase(queueName) %>QueueSetting#>
|
|
47
|
+
|
|
48
|
+
<%_ function firstLetterUpperCase(text){
|
|
49
|
+
return text.charAt(0).toUpperCase() + text.slice(1)
|
|
50
|
+
} _%>
|
|
51
|
+
<%_ function firstLetterLowerCase(str) {
|
|
52
|
+
return str.charAt(0).toLowerCase() + str.slice(1)
|
|
53
|
+
} _%>
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/*
|
|
2
|
+
Copyright (C) 2020 Sven Mason <http://izara.io>
|
|
3
|
+
|
|
4
|
+
This program is free software: you can redistribute it and/or modify
|
|
5
|
+
it under the terms of the GNU Affero General Public License as
|
|
6
|
+
published by the Free Software Foundation, either version 3 of the
|
|
7
|
+
License, or (at your option) any later version.
|
|
8
|
+
|
|
9
|
+
This program is distributed in the hope that it will be useful,
|
|
10
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
11
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
12
|
+
GNU Affero General Public License for more details.
|
|
13
|
+
|
|
14
|
+
You should have received a copy of the GNU Affero General Public License
|
|
15
|
+
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
'use strict';
|
|
19
|
+
|
|
20
|
+
const path = require("path")
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
// const {
|
|
24
|
+
// HANDLER,
|
|
25
|
+
// STORAGE_TYPES
|
|
26
|
+
// } = require('@izara_project/izara-core-library-service-schemas/src/Consts');
|
|
27
|
+
|
|
28
|
+
const { firstLetterLowerCase: lowerCase, firstLetterUpperCase: upperCase } = require("../../../../../MainLibs/src/Utils.js");
|
|
29
|
+
const STORAGE_TYPES = {
|
|
30
|
+
dynamoDB: "dynamoDB",
|
|
31
|
+
graph: "graph"
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
const templatePath = path.join(__dirname, '../../../resourceYaml/sns-out/template.ejs');
|
|
35
|
+
const { SOURCE_PATH, SAVE_FILE_NAME, FUNCTION_NAME, HANDLER } = require('../../../../../MainLibs/src/Consts.js')
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* create data for dynamoDbYaml template from objectSchema
|
|
39
|
+
* return array of dynamoDb data
|
|
40
|
+
* because one objectSchema can create multiple dynamoDb table
|
|
41
|
+
*
|
|
42
|
+
* @param {Object} _izContext
|
|
43
|
+
* @param {String} saveFilePath
|
|
44
|
+
* @returns {Object[]} - data of multiple dynamoDb template
|
|
45
|
+
*/
|
|
46
|
+
|
|
47
|
+
function createDataForSnsOut(_izContext, flowSchema, srcPath) {
|
|
48
|
+
let resultsForCreateDefaultSnsInSqs = [];
|
|
49
|
+
|
|
50
|
+
// GCTpBasTestInPersonCreate => GCTpBas_Test_PersonCreate_In
|
|
51
|
+
let flowSteps = Object.keys(flowSchema.flowSteps)
|
|
52
|
+
const generatedSnsTopicOutForFlowSchema = [
|
|
53
|
+
{
|
|
54
|
+
queueName: upperCase(flowSteps[1].split("_")[0])
|
|
55
|
+
}
|
|
56
|
+
];
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
for (let defaultSnsOutData of generatedSnsTopicOutForFlowSchema) {
|
|
60
|
+
resultsForCreateDefaultSnsInSqs.push({
|
|
61
|
+
templatePath: templatePath,
|
|
62
|
+
templateData: defaultSnsOutData,
|
|
63
|
+
setting: {
|
|
64
|
+
initialData: "Resources:\n",
|
|
65
|
+
savePath: path.join(srcPath, SOURCE_PATH.resourceYaml),
|
|
66
|
+
saveFileName: SAVE_FILE_NAME.snsOutYaml,
|
|
67
|
+
fileExtension: ".yml",
|
|
68
|
+
isAppend: true
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
})
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
return resultsForCreateDefaultSnsInSqs;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
module.exports = createDataForSnsOut;
|