@ez4/aws-function 0.18.0 → 0.19.0
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/dist/main.cjs +104 -102
- package/dist/main.mjs +95 -94
- package/dist/mapping/types.d.ts +4 -0
- package/package.json +7 -7
package/dist/main.cjs
CHANGED
|
@@ -1,129 +1,131 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
typeof t=="object"||typeof t=="function")for(let o of Je(t))!
|
|
3
|
-
A(e,o,{get:()=>t[o],enumerable:!(n=
|
|
4
|
-
enumerable:!0}):r,e)),
|
|
5
|
-
MappingServiceType:()=>S,PermissionServiceName:()=>
|
|
6
|
-
createFunction:()=>
|
|
7
|
-
getFunctionName:()=>C,getFunctionState:()=>
|
|
8
|
-
isMappingState:()=>
|
|
9
|
-
module.exports=
|
|
10
|
-
|
|
11
|
-
j=require("@ez4/aws-identity");var i=require("@aws-sdk/client-lambda"),p=require("@ez4/aws-common");var
|
|
12
|
-
a,`${t} is an invalid variable name .`)},b=e=>{let t={};for(let r in e)t[r]=(0,
|
|
13
|
-
e[r]);return t};var J=
|
|
1
|
+
"use strict";var ke=Object.create;var A=Object.defineProperty;var Qe=Object.getOwnPropertyDescriptor;var Je=Object.getOwnPropertyNames;var Ke=Object.getPrototypeOf,_e=Object.prototype.hasOwnProperty;var Xe=(e,t)=>{for(var r in t)A(e,r,{get:t[r],enumerable:!0})},Z=(e,t,r,n)=>{if(t&&
|
|
2
|
+
typeof t=="object"||typeof t=="function")for(let o of Je(t))!_e.call(e,o)&&o!==r&&
|
|
3
|
+
A(e,o,{get:()=>t[o],enumerable:!(n=Qe(t,o))||n.enumerable});return e};var Ye=(e,t,r)=>(r=e!=null?ke(Ke(e)):{},Z(t||!e||!e.__esModule?A(r,"default",{value:e,
|
|
4
|
+
enumerable:!0}):r,e)),et=e=>Z(A({},"__esModule",{value:!0}),e);var Tt={};Xe(Tt,{FunctionServiceName:()=>a,FunctionServiceType:()=>u,MappingService:()=>$,
|
|
5
|
+
MappingServiceName:()=>l,MappingServiceType:()=>S,PermissionServiceName:()=>x,PermissionServiceType:()=>f,
|
|
6
|
+
createFunction:()=>Et,createMapping:()=>Mt,createPermission:()=>ht,getFunctionArn:()=>gt,
|
|
7
|
+
getFunctionName:()=>C,getFunctionState:()=>lt,getPermission:()=>It,isFunctionState:()=>B,
|
|
8
|
+
isMappingState:()=>Nt,registerTriggers:()=>bt,tryGetFunctionArn:()=>ce,tryGetFunctionState:()=>ut});
|
|
9
|
+
module.exports=et(Tt);var Le=require("@ez4/aws-common"),ze=require("@ez4/aws-identity"),Ge=require("@ez4/aws-logs"),
|
|
10
|
+
Ve=require("@ez4/project/library");var ae=require("@ez4/aws-common");var d=require("@ez4/aws-common"),h=require("@ez4/utils"),H=require("@ez4/aws-logs"),
|
|
11
|
+
j=require("@ez4/aws-identity");var i=require("@aws-sdk/client-lambda"),p=require("@ez4/aws-common");var k=require("@ez4/aws-common"),Q=require("@ez4/utils");var a="AWS:Lambda/Function",u="aws:lambda.function";var tt=/[a-z][\w]+/i,rt=e=>tt.test(e),D=e=>{for(let t in e)if(!rt(t))throw new k.InvalidParameterError(
|
|
12
|
+
a,`${t} is an invalid variable name .`)},b=e=>{let t={};for(let r in e)t[r]=(0,Q.hashData)(
|
|
13
|
+
e[r]);return t};var J=Ye(require("adm-zip"),1),K=require("node:fs/promises"),_=async(e,t)=>{let r=new J.default,
|
|
14
14
|
n=await(0,K.readFile)(e);return r.addFile(t,n),r.toBufferPromise()};var g=new i.LambdaClient({}),E={minDelay:15,maxWaitTime:1800,maxDelay:60,client:g},
|
|
15
|
-
|
|
15
|
+
X=async(e,t)=>{p.Logger.logImport(a,e);try{let r=await g.send(new i.GetFunctionCommand(
|
|
16
16
|
{FunctionName:e,Qualifier:t})),n=r.Configuration.Version,o=r.Configuration.FunctionArn;
|
|
17
17
|
return{functionVersion:n,functionArn:o}}catch(r){if(!(r instanceof i.ResourceNotFoundException))
|
|
18
|
-
throw r;return}},
|
|
19
|
-
a,t),r&&
|
|
18
|
+
throw r;return}},Y=async e=>{let{functionName:t,variables:r}=e;p.Logger.logCreate(
|
|
19
|
+
a,t),r&&D(r);let n=oe(e.handlerName),o=await ne(e.sourceFile),s=await(0,p.waitCreation)(
|
|
20
20
|
()=>g.send(new i.CreateFunctionCommand({FunctionName:e.functionName,Description:e.
|
|
21
21
|
description,MemorySize:e.memory,Timeout:e.timeout,Role:e.roleArn,Handler:n,Runtime:"\
|
|
22
22
|
nodejs22.x",PackageType:"Zip",LoggingConfig:{LogGroup:e.logGroup,ApplicationLogLevel:e.
|
|
23
23
|
debug?i.ApplicationLogLevel.Debug:i.ApplicationLogLevel.Warn,SystemLogLevel:i.SystemLogLevel.
|
|
24
24
|
Warn,LogFormat:i.LogFormat.Json},Code:{ZipFile:o},Environment:{Variables:r},Tags:{
|
|
25
25
|
...e.tags,ManagedBy:"EZ4"}})));p.Logger.logWait(a,t),await(0,i.waitUntilFunctionActive)(
|
|
26
|
-
E,{FunctionName:t});let m=s.FunctionArn;return e.publish?{functionVersion:await
|
|
27
|
-
t),functionArn:m}:{functionArn:m}},
|
|
28
|
-
rce code`);let r=await
|
|
26
|
+
E,{FunctionName:t});let m=s.FunctionArn;return e.publish?{functionVersion:await te(
|
|
27
|
+
t),functionArn:m}:{functionArn:m}},L=async(e,t)=>{p.Logger.logUpdate(a,`${e} sou\
|
|
28
|
+
rce code`);let r=await ne(t.sourceFile),n=await g.send(new i.UpdateFunctionCodeCommand(
|
|
29
29
|
{FunctionName:e,Publish:t.publish,ZipFile:r}));p.Logger.logWait(a,e),await(0,i.waitUntilFunctionUpdated)(
|
|
30
|
-
E,{FunctionName:e});let o=n.FunctionArn;return t.publish?{functionVersion:await
|
|
30
|
+
E,{FunctionName:e});let o=n.FunctionArn;return t.publish?{functionVersion:await te(
|
|
31
31
|
e),functionArn:o}:{functionArn:o}},z=async(e,t)=>{let{handlerName:r,variables:n}=t;
|
|
32
|
-
p.Logger.logUpdate(a,`${e} configuration`),n&&
|
|
32
|
+
p.Logger.logUpdate(a,`${e} configuration`),n&&D(n),await g.send(new i.UpdateFunctionConfigurationCommand(
|
|
33
33
|
{FunctionName:e,Description:t.description,MemorySize:t.memory,Timeout:t.timeout,
|
|
34
|
-
Role:t.roleArn,...r&&{Handler:
|
|
35
|
-
debug?i.ApplicationLogLevel.Debug:i.ApplicationLogLevel.
|
|
36
|
-
Warn,LogFormat:i.LogFormat.Json},Environment:{
|
|
37
|
-
e),await(0,i.waitUntilFunctionUpdated)(E,{FunctionName:e})},
|
|
38
|
-
logDelete(a,e),await(0,p.waitDeletion)(async()=>{try{return await g.
|
|
39
|
-
{FunctionName:e})),!0}catch(t){if(!(t instanceof
|
|
40
|
-
return!1}})},
|
|
41
|
-
|
|
42
|
-
|
|
34
|
+
Role:t.roleArn,Runtime:"nodejs22.x",...r&&{Handler:oe(r)},LoggingConfig:{LogGroup:t.
|
|
35
|
+
logGroup,ApplicationLogLevel:t.debug?i.ApplicationLogLevel.Debug:i.ApplicationLogLevel.
|
|
36
|
+
Warn,SystemLogLevel:i.SystemLogLevel.Warn,LogFormat:i.LogFormat.Json},Environment:{
|
|
37
|
+
Variables:n}})),p.Logger.logWait(a,e),await(0,i.waitUntilFunctionUpdated)(E,{FunctionName:e})},
|
|
38
|
+
ee=async e=>{p.Logger.logDelete(a,e),await(0,p.waitDeletion)(async()=>{try{return await g.
|
|
39
|
+
send(new i.DeleteFunctionCommand({FunctionName:e})),!0}catch(t){if(!(t instanceof
|
|
40
|
+
i.ResourceNotFoundException))throw t;return!1}})},te=async e=>{p.Logger.logPublish(
|
|
41
|
+
a,e);let t=await g.send(new i.PublishVersionCommand({FunctionName:e}));p.Logger.
|
|
42
|
+
logWait(a,e);let r=t.Version;return await(0,i.waitUntilPublishedVersionActive)(E,
|
|
43
|
+
{FunctionName:e,Qualifier:r}),r},G=async(e,t)=>{let r=(0,p.tryParseArn)(e)?.resourceName??
|
|
43
44
|
e;p.Logger.logTag(a,r),await g.send(new i.TagResourceCommand({Resource:e,Tags:{...t,
|
|
44
|
-
ManagedBy:"EZ4"}}))},
|
|
45
|
+
ManagedBy:"EZ4"}}))},re=async(e,t)=>{let r=(0,p.tryParseArn)(e)?.resourceName??e;
|
|
45
46
|
p.Logger.logUntag(a,r),await g.send(new i.UntagResourceCommand({Resource:e,TagKeys:t}))},
|
|
46
|
-
|
|
47
|
-
result&&e.result.functionArn===t.result?.functionArn,
|
|
48
|
-
n=t.parameters,o=(0,h.deepCompare)({...r,dependencies:e.dependencies,sourceHash:await(0,d.
|
|
47
|
+
ne=e=>_(e,"main.mjs"),oe=e=>`main.${e}`;var ie=()=>({equals:nt,create:se,replace:it,preview:ot,update:st,delete:at}),nt=(e,t)=>!!e.
|
|
48
|
+
result&&e.result.functionArn===t.result?.functionArn,ot=async(e,t)=>{let r=e.parameters,
|
|
49
|
+
n=t.parameters,o=(0,h.deepCompare)({...r,dependencies:e.dependencies,sourceHash:await(0,d.getBundleHashFromCache)(
|
|
49
50
|
r.sourceFile),...r.variables&&{variables:b(r.variables)}},{...n,dependencies:t.dependencies,
|
|
50
51
|
sourceHash:t.result?.sourceHash});if(o.counts)return{...o,name:r.functionName}},
|
|
51
|
-
|
|
52
|
-
return
|
|
53
|
-
a,n,t),s=(0,H.getLogGroupName)(a,n,t),[m,
|
|
54
|
-
t),(0,d.
|
|
55
|
-
roleArn:o}),await
|
|
56
|
-
V(e),{functionArn:
|
|
57
|
-
{...r,publish:!0,sourceFile:m,logGroup:s,roleArn:o});return V(e),{
|
|
58
|
-
functionArn,sourceHash:
|
|
59
|
-
result:o}=e;if(!o)return;let s=n.functionName,m=(0,j.getRoleArn)(
|
|
60
|
-
roleArn??m,
|
|
61
|
-
logGroup:
|
|
62
|
-
o.functionArn,n,t.parameters);let
|
|
63
|
-
...
|
|
64
|
-
r.functionName)},V=e=>{let{parameters:t}=e;return t.variables&&(t.variables=
|
|
65
|
-
variables)),e},
|
|
66
|
-
|
|
67
|
-
e,t)},
|
|
68
|
-
e,n))},
|
|
69
|
-
if(o===s)return r;let m=await t.getFunctionBundle(n),{functionVersion:
|
|
70
|
-
e,{publish:!r?.functionVersion,sourceFile:m});return{sourceHash:o,functionVersion:
|
|
71
|
-
|
|
52
|
+
it=async(e,t,r)=>{if(t.result)throw new d.ReplaceResourceError(a,e.entryId,t.entryId);
|
|
53
|
+
return se(e,r)},se=async(e,t)=>{let r=e.parameters,n=r.functionName,o=(0,j.getRoleArn)(
|
|
54
|
+
a,n,t),s=(0,H.getLogGroupName)(a,n,t),[m,F]=await Promise.all([r.getFunctionBundle(
|
|
55
|
+
t),(0,d.getBundleHashFromCache)(r.sourceFile)]),w=await X(n);if(w)return await z(
|
|
56
|
+
n,{...r,logGroup:s,roleArn:o}),await L(n,{publish:!1,sourceFile:m}),await G(w.functionArn,
|
|
57
|
+
{...r.tags}),V(e),{functionArn:w.functionArn,sourceHash:F,logGroup:s,roleArn:o};
|
|
58
|
+
let U=await Y({...r,publish:!0,sourceFile:m,logGroup:s,roleArn:o});return V(e),{
|
|
59
|
+
functionArn:U.functionArn,sourceHash:F,logGroup:s,roleArn:o}},st=async(e,t,r)=>{
|
|
60
|
+
let{parameters:n,result:o}=e;if(!o)return;let s=n.functionName,m=(0,j.getRoleArn)(
|
|
61
|
+
a,s,r),F=t.result?.roleArn??m,w=(0,H.getLogGroupName)(a,s,r),U=t.result?.logGroup??
|
|
62
|
+
w,$e={...n,roleArn:m,logGroup:w},qe={...t.parameters,roleArn:F,logGroup:U};await pt(
|
|
63
|
+
s,$e,qe),await ct(o.functionArn,n,t.parameters);let Ze=await mt(s,n,t.result,r);
|
|
64
|
+
return V(e),{...o,...Ze,logGroup:w,roleArn:m}},at=async e=>{let{result:t,parameters:r}=e;
|
|
65
|
+
t&&await ee(r.functionName)},V=e=>{let{parameters:t}=e;return t.variables&&(t.variables=
|
|
66
|
+
b(t.variables)),e},pt=async(e,t,r)=>{let n={...t,...t.variables&&{variables:b(t.
|
|
67
|
+
variables)}};!(0,h.deepEqual)(n,r,{exclude:{sourceFile:!0,functionName:!0,tags:!0}})&&
|
|
68
|
+
await z(e,t)},ct=async(e,t,r)=>{await(0,d.applyTagUpdates)(t.tags,r.tags,n=>G(e,
|
|
69
|
+
n),n=>re(e,n))},mt=async(e,t,r,n)=>{let o=await(0,d.getBundleHashFromCache)(t.sourceFile),
|
|
70
|
+
s=r?.sourceHash;if(o===s)return r;let m=await t.getFunctionBundle(n),{functionVersion:F}=await L(
|
|
71
|
+
e,{publish:!r?.functionVersion,sourceFile:m});return{sourceHash:o,functionVersion:F}};var pe=()=>{(0,ae.registerProvider)(u,ie())};var ye=require("@ez4/aws-common");var ge=require("@ez4/aws-common");var O=require("@ez4/aws-common");var I=class extends Error{constructor(t){super(`Function ${t} wasn't found.`)}};var B=e=>e.type===u,ut=(e,t,r)=>{try{let n=e.getServiceState(t,r);if(B(n))return n}catch{}},
|
|
72
|
+
lt=(e,t,r)=>{let n=e.getServiceState(t,r);if(!B(n))throw new I(t);return n},C=(e,t,r)=>{
|
|
72
73
|
let n=r.getDependencies(u).at(0)?.parameters;if(!n?.functionName)throw new O.IncompleteResourceError(
|
|
73
|
-
e,t,"functionName");return n.functionName},
|
|
74
|
-
functionArn,
|
|
75
|
-
t,"functionArn");return n};var y=require("@aws-sdk/client-lambda"),W=require("@ez4/aws-common");var
|
|
76
|
-
let t=e.statementId??`SID${Date.now()}`;return await
|
|
74
|
+
e,t,"functionName");return n.functionName},ce=e=>e.getDependencies(u)[0]?.result?.
|
|
75
|
+
functionArn,gt=(e,t,r)=>{let n=ce(r);if(!n)throw new O.IncompleteResourceError(e,
|
|
76
|
+
t,"functionArn");return n};var y=require("@aws-sdk/client-lambda"),W=require("@ez4/aws-common");var x="AWS:Lambda/Permission",f="aws:lambda.permission";var me=new y.LambdaClient({}),ue=async e=>{W.Logger.logCreate(x,e.functionName);
|
|
77
|
+
let t=e.statementId??`SID${Date.now()}`;return await me.send(new y.AddPermissionCommand(
|
|
77
78
|
{StatementId:t,FunctionName:e.functionName,SourceArn:e.sourceArn,Principal:e.principal,
|
|
78
|
-
Action:e.action})),{statementId:t}},
|
|
79
|
-
return await
|
|
80
|
-
!0}catch(r){if(!(r instanceof y.ResourceNotFoundException))throw r;return!1}};var
|
|
81
|
-
result&&e.result.functionName===t.result?.functionName,
|
|
82
|
-
if(t.result)throw new
|
|
83
|
-
r)},
|
|
84
|
-
t);return{statementId:(await
|
|
85
|
-
sourceArn,action:"lambda:InvokeFunction"})).statementId,functionName:n}},
|
|
86
|
-
|
|
79
|
+
Action:e.action})),{statementId:t}},le=async(e,t)=>{W.Logger.logDelete(x,e);try{
|
|
80
|
+
return await me.send(new y.RemovePermissionCommand({FunctionName:e,StatementId:t})),
|
|
81
|
+
!0}catch(r){if(!(r instanceof y.ResourceNotFoundException))throw r;return!1}};var fe=()=>({equals:ft,create:de,replace:yt,preview:dt,update:St,delete:Ft}),ft=(e,t)=>!!e.
|
|
82
|
+
result&&e.result.functionName===t.result?.functionName,dt=async(e,t)=>{},yt=async(e,t,r)=>{
|
|
83
|
+
if(t.result)throw new ge.ReplaceResourceError(x,e.entryId,t.entryId);return de(e,
|
|
84
|
+
r)},de=async(e,t)=>{let r=e.parameters,n=C(x,"permission",t),o=await r.getPermission(
|
|
85
|
+
t);return{statementId:(await ue({functionName:n,principal:o.principal,sourceArn:o.
|
|
86
|
+
sourceArn,action:"lambda:InvokeFunction"})).statementId,functionName:n}},St=async()=>{},
|
|
87
|
+
Ft=async e=>{let t=e.result;t&&await le(t.functionName,t.statementId)};var Se=()=>{(0,ye.registerProvider)(f,fe())};var he=require("@ez4/aws-common");var Ae=require("@ez4/aws-common"),M=require("@ez4/utils");var c=require("@aws-sdk/client-lambda"),P=require("@ez4/aws-common"),Fe=require("@ez4/utils");var l="AWS:Lambda/Mapping",S="aws:lambda.mapping",$=(r=>(r.DynamoDB="dynamodb",r.
|
|
88
|
+
Queue="sqs",r))($||{});var v=new c.LambdaClient({}),we=async(e,t)=>{P.Logger.logImport(l,e);let r=await v.
|
|
87
89
|
send(new c.ListEventSourceMappingsCommand({FunctionName:e,EventSourceArn:t})),[n]=r.
|
|
88
|
-
EventSourceMappings;return n?{eventId:n.UUID}:void 0},
|
|
89
|
-
functionName:r}=e;
|
|
90
|
-
{FunctionName:r,EventSourceArn:t,...
|
|
91
|
-
Pe=async(e,t)=>{let{functionName:r}=t;
|
|
92
|
-
send(new c.UpdateEventSourceMappingCommand({UUID:e,FunctionName:r,...
|
|
93
|
-
e)},
|
|
90
|
+
EventSourceMappings;return n?{eventId:n.UUID}:void 0},xe=async e=>{let{sourceArn:t,
|
|
91
|
+
functionName:r}=e;P.Logger.logCreate(l,r);let o=(await v.send(new c.CreateEventSourceMappingCommand(
|
|
92
|
+
{FunctionName:r,EventSourceArn:t,...ve(e)}))).UUID;return await Re(o),{eventId:o}},
|
|
93
|
+
Pe=async(e,t)=>{let{functionName:r}=t;P.Logger.logUpdate(l,`${r} (${e})`),await v.
|
|
94
|
+
send(new c.UpdateEventSourceMappingCommand({UUID:e,FunctionName:r,...ve(t)})),await Re(
|
|
95
|
+
e)},Ce=async e=>{P.Logger.logDelete(l,e);try{return await v.send(new c.DeleteEventSourceMappingCommand(
|
|
94
96
|
{UUID:e})),!0}catch(t){if(!(t instanceof c.ResourceNotFoundException))throw t;return!1}},
|
|
95
|
-
wt=async e=>(await v.send(new c.GetEventSourceMappingCommand({UUID:e}))).State,
|
|
96
|
-
let t=new Set(["Enabled","Disabled"]);await(0,
|
|
97
|
-
e);return t.has(r)})},
|
|
98
|
-
{service:s}=(0,
|
|
97
|
+
wt=async e=>(await v.send(new c.GetEventSourceMappingCommand({UUID:e}))).State,Re=async e=>{
|
|
98
|
+
let t=new Set(["Enabled","Disabled"]);await(0,Fe.waitFor)(async()=>{let r=await wt(
|
|
99
|
+
e);return t.has(r)})},ve=e=>{let{sourceArn:t,enabled:r,concurrency:n,batch:o}=e,
|
|
100
|
+
{service:s}=(0,P.parseArn)(t);return{Enabled:r,FunctionResponseTypes:[c.FunctionResponseType.
|
|
99
101
|
ReportBatchItemFailures],MaximumBatchingWindowInSeconds:o?.maxWindow,BatchSize:o?.
|
|
100
102
|
batchSize,...s==="dynamodb"&&{StartingPosition:c.EventSourcePosition.LATEST},...s===
|
|
101
|
-
"sqs"&&
|
|
103
|
+
"sqs"&&{ScalingConfig:{MaximumConcurrency:n}}}};var be=()=>({equals:xt,create:Ee,replace:Ct,preview:Pt,update:Rt,delete:vt}),xt=(e,t)=>!!e.
|
|
102
104
|
result&&e.result.eventId===t.result?.eventId,Pt=async(e,t)=>{let r={...e.parameters,
|
|
103
|
-
dependencies:e.dependencies},n={...t.parameters,dependencies:t.dependencies},o=(0,
|
|
104
|
-
r,n,{exclude:{getSourceArn:!0}});if(o.counts)return{...o,name:r.fromService}},
|
|
105
|
-
if(t.result)throw new
|
|
106
|
-
r)},
|
|
107
|
-
t);return{eventId:(await we(n,o)??await
|
|
108
|
-
eventId,functionName:n,sourceArn:o}},
|
|
109
|
-
let o=n.sourceArn,s=C(l,"mapping",r),m=t.result?.functionName??n.functionName;return await
|
|
105
|
+
dependencies:e.dependencies},n={...t.parameters,dependencies:t.dependencies},o=(0,M.deepCompare)(
|
|
106
|
+
r,n,{exclude:{getSourceArn:!0}});if(o.counts)return{...o,name:r.fromService}},Ct=async(e,t,r)=>{
|
|
107
|
+
if(t.result)throw new Ae.ReplaceResourceError(l,e.entryId,t.entryId);return Ee(e,
|
|
108
|
+
r)},Ee=async(e,t)=>{let r=e.parameters,n=C(l,"mapping",t),o=await r.getSourceArn(
|
|
109
|
+
t);return{eventId:(await we(n,o)??await xe({...e.parameters,functionName:n,sourceArn:o})).
|
|
110
|
+
eventId,functionName:n,sourceArn:o}},Rt=async(e,t,r)=>{let n=e.result;if(!n)return;
|
|
111
|
+
let o=n.sourceArn,s=C(l,"mapping",r),m=t.result?.functionName??n.functionName;return await At(
|
|
110
112
|
n.eventId,{...e.parameters,functionName:s,sourceArn:o},{...t.parameters,functionName:m,
|
|
111
|
-
sourceArn:o}),{...n,functionName:s}},
|
|
112
|
-
|
|
113
|
-
await Pe(e,t)};var
|
|
113
|
+
sourceArn:o}),{...n,functionName:s}},vt=async e=>{let t=e.result;t&&await Ce(t.eventId)},
|
|
114
|
+
At=async(e,t,r)=>{!(0,M.deepEqual)(t,r,{exclude:{getSourceArn:!0,fromService:!0}})&&
|
|
115
|
+
await Pe(e,t)};var Ie=()=>{(0,he.registerProvider)(S,be())};var Me=()=>[{account:"lambda.amazonaws.com"}];var N=require("@ez4/aws-identity"),Te=require("@ez4/project/library");var R=require("@ez4/aws-identity"),Ne=async e=>{let[t,r]=await Promise.all([(0,R.getRegion)(),
|
|
114
116
|
(0,R.getAccountId)()]);return(0,R.createPolicyDocument)([{permissions:["logs:Cre\
|
|
115
117
|
ateLogStream","logs:PutLogEvents"],resourceIds:[`arn:aws:logs:${t}:${r}:log-grou\
|
|
116
|
-
p:${e}-*:*`]}])};var
|
|
117
|
-
lambda-policy`;return(0,N.tryGetPolicy)(t,o)??(0,N.createPolicy)(t,{
|
|
118
|
-
n),policyName:o})};var
|
|
119
|
-
(0,
|
|
120
|
-
ploy:prepareExecutionPolicy":
|
|
121
|
-
entryId,o),m=[t.entryId];return r&&m.push(r.entryId),(0,
|
|
122
|
-
entryId:s,dependencies:m,parameters:{...n,functionName:o}})};var
|
|
123
|
-
e,{type:f,entryId:o,dependencies:[t.entryId,r.entryId],parameters:n})},
|
|
124
|
-
let n=(0
|
|
125
|
-
e,{type:S,entryId:o,dependencies:[t.entryId,r.entryId],parameters:n})};var
|
|
126
|
-
PermissionServiceName,PermissionServiceType,createFunction,createMapping,
|
|
127
|
-
getFunctionArn,getFunctionName,getFunctionState,getPermission,isFunctionState,
|
|
128
|
-
registerTriggers,tryGetFunctionArn,tryGetFunctionState});
|
|
118
|
+
p:${e}-*:*`]}])};var Ue=async e=>{let{state:t,options:r}=e,n=(0,Te.getServiceName)("",r),o=`${n}-\
|
|
119
|
+
lambda-policy`;return(0,N.tryGetPolicy)(t,o)??(0,N.createPolicy)(t,{tags:r.tags,
|
|
120
|
+
policyDocument:await Ne(n),policyName:o})};var De=!1,bt=()=>{De||((0,Le.registerTriggers)(),(0,ze.registerTriggers)(),(0,Ge.registerTriggers)(),
|
|
121
|
+
(0,Ve.createTrigger)("@ez4/aws-function",{"deploy:prepareIdentityAccount":Me,"de\
|
|
122
|
+
ploy:prepareExecutionPolicy":Ue}),pe(),Se(),Ie(),De=!0)};var T=require("@ez4/utils"),He=require("@ez4/stateful");var Et=(e,t,r,n)=>{let o=(0,T.toKebabCase)(n.functionName),s=(0,T.hashData)(u,t.
|
|
123
|
+
entryId,o),m=[t.entryId];return r&&m.push(r.entryId),(0,He.attachEntry)(e,{type:u,
|
|
124
|
+
entryId:s,dependencies:m,parameters:{...n,functionName:o}})};var Oe=require("@ez4/stateful"),q=require("@ez4/utils");var je=e=>e.type===f;var ht=(e,t,r,n)=>{let o=(0,q.hashData)(f,t.entryId,r.entryId);return(0,Oe.attachEntry)(
|
|
125
|
+
e,{type:f,entryId:o,dependencies:[t.entryId,r.entryId],parameters:n})},It=(e,t,r)=>{
|
|
126
|
+
let n=(0,q.hashData)(f,t.entryId,r.entryId),o=e[n];return o&&je(o)?o:null};var Be=require("@ez4/utils"),We=require("@ez4/stateful");var Mt=(e,t,r,n)=>{let o=(0,Be.hashData)(S,t.entryId,r.entryId);return(0,We.attachEntry)(
|
|
127
|
+
e,{type:S,entryId:o,dependencies:[t.entryId,r.entryId],parameters:n})};var Nt=e=>e.type===S;0&&(module.exports={FunctionServiceName,FunctionServiceType,MappingService,MappingServiceName,
|
|
128
|
+
MappingServiceType,PermissionServiceName,PermissionServiceType,createFunction,createMapping,
|
|
129
|
+
createPermission,getFunctionArn,getFunctionName,getFunctionState,getPermission,isFunctionState,
|
|
130
|
+
isMappingState,registerTriggers,tryGetFunctionArn,tryGetFunctionState});
|
|
129
131
|
//# sourceMappingURL=main.cjs.map
|
package/dist/main.mjs
CHANGED
|
@@ -1,116 +1,117 @@
|
|
|
1
|
-
import{registerTriggers as
|
|
2
|
-
import{registerTriggers as
|
|
3
|
-
import{deepCompare as
|
|
4
|
-
import{getRoleArn as q}from"@ez4/aws-identity";import{LambdaClient as
|
|
5
|
-
UpdateFunctionCodeCommand as
|
|
6
|
-
TagResourceCommand as
|
|
7
|
-
waitUntilFunctionUpdated as T,waitUntilPublishedVersionActive as
|
|
8
|
-
ApplicationLogLevel as
|
|
9
|
-
import{Logger as p,tryParseArn as z,waitCreation as
|
|
10
|
-
s,`${t} is an invalid variable name .`)},
|
|
11
|
-
return t};import
|
|
12
|
-
let r=new
|
|
1
|
+
import{registerTriggers as Ot}from"@ez4/aws-common";import{registerTriggers as Bt}from"@ez4/aws-identity";
|
|
2
|
+
import{registerTriggers as Wt}from"@ez4/aws-logs";import{createTrigger as $t}from"@ez4/project/library";import{registerProvider as et}from"@ez4/aws-common";import{applyTagUpdates as Be,getBundleHashFromCache as M,ReplaceResourceError as We}from"@ez4/aws-common";
|
|
3
|
+
import{deepCompare as $e,deepEqual as qe}from"@ez4/utils";import{getLogGroupName as $}from"@ez4/aws-logs";
|
|
4
|
+
import{getRoleArn as q}from"@ez4/aws-identity";import{LambdaClient as Ie,GetFunctionCommand as Me,CreateFunctionCommand as Ne,DeleteFunctionCommand as Te,
|
|
5
|
+
UpdateFunctionCodeCommand as Ue,UpdateFunctionConfigurationCommand as De,PublishVersionCommand as Le,
|
|
6
|
+
TagResourceCommand as ze,UntagResourceCommand as Ge,waitUntilFunctionActive as Ve,
|
|
7
|
+
waitUntilFunctionUpdated as T,waitUntilPublishedVersionActive as He,ResourceNotFoundException as U,
|
|
8
|
+
ApplicationLogLevel as x,SystemLogLevel as D,LogFormat as L}from"@aws-sdk/client-lambda";
|
|
9
|
+
import{Logger as p,tryParseArn as z,waitCreation as je,waitDeletion as Oe}from"@ez4/aws-common";import{InvalidParameterError as Re}from"@ez4/aws-common";import{hashData as ve}from"@ez4/utils";var s="AWS:Lambda/Function",c="aws:lambda.function";var Ae=/[a-z][\w]+/i,be=e=>Ae.test(e),A=e=>{for(let t in e)if(!be(t))throw new Re(
|
|
10
|
+
s,`${t} is an invalid variable name .`)},w=e=>{let t={};for(let r in e)t[r]=ve(e[r]);
|
|
11
|
+
return t};import Ee from"adm-zip";import{readFile as he}from"node:fs/promises";var N=async(e,t)=>{
|
|
12
|
+
let r=new Ee,n=await he(e);return r.addFile(t,n),r.toBufferPromise()};var m=new Ie({}),P={minDelay:15,maxWaitTime:1800,maxDelay:60,client:m},G=async(e,t)=>{
|
|
13
13
|
p.logImport(s,e);try{let r=await m.send(new Me({FunctionName:e,Qualifier:t})),n=r.
|
|
14
14
|
Configuration.Version,o=r.Configuration.FunctionArn;return{functionVersion:n,functionArn:o}}catch(r){
|
|
15
15
|
if(!(r instanceof U))throw r;return}},V=async e=>{let{functionName:t,variables:r}=e;
|
|
16
|
-
p.logCreate(s,t),r&&A(r);let n=W(e.handlerName),o=await B(e.sourceFile),i=await
|
|
17
|
-
()=>m.send(new
|
|
16
|
+
p.logCreate(s,t),r&&A(r);let n=W(e.handlerName),o=await B(e.sourceFile),i=await je(
|
|
17
|
+
()=>m.send(new Ne({FunctionName:e.functionName,Description:e.description,MemorySize:e.
|
|
18
18
|
memory,Timeout:e.timeout,Role:e.roleArn,Handler:n,Runtime:"nodejs22.x",PackageType:"\
|
|
19
|
-
Zip",LoggingConfig:{LogGroup:e.logGroup,ApplicationLogLevel:e.debug?
|
|
20
|
-
SystemLogLevel:
|
|
21
|
-
Tags:{...e.tags,ManagedBy:"EZ4"}})));p.logWait(s,t),await
|
|
19
|
+
Zip",LoggingConfig:{LogGroup:e.logGroup,ApplicationLogLevel:e.debug?x.Debug:x.Warn,
|
|
20
|
+
SystemLogLevel:D.Warn,LogFormat:L.Json},Code:{ZipFile:o},Environment:{Variables:r},
|
|
21
|
+
Tags:{...e.tags,ManagedBy:"EZ4"}})));p.logWait(s,t),await Ve(P,{FunctionName:t});
|
|
22
22
|
let a=i.FunctionArn;return e.publish?{functionVersion:await j(t),functionArn:a}:
|
|
23
23
|
{functionArn:a}},b=async(e,t)=>{p.logUpdate(s,`${e} source code`);let r=await B(
|
|
24
|
-
t.sourceFile),n=await m.send(new
|
|
25
|
-
p.logWait(s,e),await T(
|
|
24
|
+
t.sourceFile),n=await m.send(new Ue({FunctionName:e,Publish:t.publish,ZipFile:r}));
|
|
25
|
+
p.logWait(s,e),await T(P,{FunctionName:e});let o=n.FunctionArn;return t.publish?
|
|
26
26
|
{functionVersion:await j(e),functionArn:o}:{functionArn:o}},E=async(e,t)=>{let{handlerName:r,
|
|
27
|
-
variables:n}=t;p.logUpdate(s,`${e} configuration`),n&&A(n),await m.send(new
|
|
27
|
+
variables:n}=t;p.logUpdate(s,`${e} configuration`),n&&A(n),await m.send(new De({
|
|
28
28
|
FunctionName:e,Description:t.description,MemorySize:t.memory,Timeout:t.timeout,Role:t.
|
|
29
|
-
roleArn,...r&&{Handler:W(r)},LoggingConfig:{LogGroup:t.logGroup,
|
|
30
|
-
debug?
|
|
31
|
-
p.logWait(s,e),await T(
|
|
32
|
-
async()=>{try{return await m.send(new
|
|
33
|
-
U))throw t;return!1}})},j=async e=>{p.logPublish(s,
|
|
34
|
-
{FunctionName:e}));p.logWait(s,e);let r=t.Version;return await
|
|
35
|
-
Qualifier:r}),r},h=async(e,t)=>{let r=z(e)?.resourceName??e;p.
|
|
36
|
-
send(new
|
|
37
|
-
resourceName??e;p.logUntag(s,r),await m.send(new
|
|
38
|
-
e,"main.mjs"),W=e=>`main.${e}`;var Z=()=>({equals:
|
|
39
|
-
result&&e.result.functionArn===t.result?.functionArn,
|
|
40
|
-
n=t.parameters,o
|
|
41
|
-
...r.variables&&{variables:
|
|
42
|
-
result?.sourceHash});if(o.counts)return{...o,name:r.functionName}},
|
|
43
|
-
if(t.result)throw new
|
|
29
|
+
roleArn,Runtime:"nodejs22.x",...r&&{Handler:W(r)},LoggingConfig:{LogGroup:t.logGroup,
|
|
30
|
+
ApplicationLogLevel:t.debug?x.Debug:x.Warn,SystemLogLevel:D.Warn,LogFormat:L.Json},
|
|
31
|
+
Environment:{Variables:n}})),p.logWait(s,e),await T(P,{FunctionName:e})},H=async e=>{
|
|
32
|
+
p.logDelete(s,e),await Oe(async()=>{try{return await m.send(new Te({FunctionName:e})),
|
|
33
|
+
!0}catch(t){if(!(t instanceof U))throw t;return!1}})},j=async e=>{p.logPublish(s,
|
|
34
|
+
e);let t=await m.send(new Le({FunctionName:e}));p.logWait(s,e);let r=t.Version;return await He(
|
|
35
|
+
P,{FunctionName:e,Qualifier:r}),r},h=async(e,t)=>{let r=z(e)?.resourceName??e;p.
|
|
36
|
+
logTag(s,r),await m.send(new ze({Resource:e,Tags:{...t,ManagedBy:"EZ4"}}))},O=async(e,t)=>{
|
|
37
|
+
let r=z(e)?.resourceName??e;p.logUntag(s,r),await m.send(new Ge({Resource:e,TagKeys:t}))},
|
|
38
|
+
B=e=>N(e,"main.mjs"),W=e=>`main.${e}`;var Z=()=>({equals:Ze,create:k,replace:Qe,preview:ke,update:Je,delete:Ke}),Ze=(e,t)=>!!e.
|
|
39
|
+
result&&e.result.functionArn===t.result?.functionArn,ke=async(e,t)=>{let r=e.parameters,
|
|
40
|
+
n=t.parameters,o=$e({...r,dependencies:e.dependencies,sourceHash:await M(r.sourceFile),
|
|
41
|
+
...r.variables&&{variables:w(r.variables)}},{...n,dependencies:t.dependencies,sourceHash:t.
|
|
42
|
+
result?.sourceHash});if(o.counts)return{...o,name:r.functionName}},Qe=async(e,t,r)=>{
|
|
43
|
+
if(t.result)throw new We(s,e.entryId,t.entryId);return k(e,r)},k=async(e,t)=>{let r=e.
|
|
44
44
|
parameters,n=r.functionName,o=q(s,n,t),i=$(s,n,t),[a,g]=await Promise.all([r.getFunctionBundle(
|
|
45
|
-
t),
|
|
46
|
-
await b(n,{publish:!1,sourceFile:a}),await h(f.functionArn,{...r.tags}),
|
|
45
|
+
t),M(r.sourceFile)]),f=await G(n);if(f)return await E(n,{...r,logGroup:i,roleArn:o}),
|
|
46
|
+
await b(n,{publish:!1,sourceFile:a}),await h(f.functionArn,{...r.tags}),I(e),{functionArn:f.
|
|
47
47
|
functionArn,sourceHash:g,logGroup:i,roleArn:o};let v=await V({...r,publish:!0,sourceFile:a,
|
|
48
|
-
logGroup:i,roleArn:o});return
|
|
48
|
+
logGroup:i,roleArn:o});return I(e),{functionArn:v.functionArn,sourceHash:g,logGroup:i,
|
|
49
49
|
roleArn:o}},Je=async(e,t,r)=>{let{parameters:n,result:o}=e;if(!o)return;let i=n.
|
|
50
50
|
functionName,a=q(s,i,r),g=t.result?.roleArn??a,f=$(s,i,r),v=t.result?.logGroup??
|
|
51
|
-
f,
|
|
52
|
-
i,
|
|
53
|
-
return
|
|
54
|
-
t&&await H(r.functionName)},
|
|
55
|
-
|
|
56
|
-
variables)}}
|
|
57
|
-
e,t)},
|
|
58
|
-
let o=await
|
|
51
|
+
f,xe={...n,roleArn:a,logGroup:f},Pe={...t.parameters,roleArn:g,logGroup:v};await _e(
|
|
52
|
+
i,xe,Pe),await Xe(o.functionArn,n,t.parameters);let Ce=await Ye(i,n,t.result,r);
|
|
53
|
+
return I(e),{...o,...Ce,logGroup:f,roleArn:a}},Ke=async e=>{let{result:t,parameters:r}=e;
|
|
54
|
+
t&&await H(r.functionName)},I=e=>{let{parameters:t}=e;return t.variables&&(t.variables=
|
|
55
|
+
w(t.variables)),e},_e=async(e,t,r)=>{let n={...t,...t.variables&&{variables:w(t.
|
|
56
|
+
variables)}};!qe(n,r,{exclude:{sourceFile:!0,functionName:!0,tags:!0}})&&await E(
|
|
57
|
+
e,t)},Xe=async(e,t,r)=>{await Be(t.tags,r.tags,n=>h(e,n),n=>O(e,n))},Ye=async(e,t,r,n)=>{
|
|
58
|
+
let o=await M(t.sourceFile),i=r?.sourceHash;if(o===i)return r;let a=await t.getFunctionBundle(
|
|
59
59
|
n),{functionVersion:g}=await b(e,{publish:!r?.functionVersion,sourceFile:a});return{
|
|
60
|
-
sourceHash:o,functionVersion:g}};var
|
|
61
|
-
|
|
62
|
-
let n=r.getDependencies(c).at(0)?.parameters;if(!n?.functionName)throw new
|
|
63
|
-
"functionName");return n.functionName},
|
|
64
|
-
|
|
65
|
-
ResourceNotFoundException as
|
|
66
|
-
`SID${Date.now()}`;return await X.send(new
|
|
60
|
+
sourceHash:o,functionVersion:g}};var Q=()=>{et(c,Z())};import{registerProvider as lt}from"@ez4/aws-common";import{ReplaceResourceError as st}from"@ez4/aws-common";import{IncompleteResourceError as J}from"@ez4/aws-common";var C=class extends Error{constructor(t){super(`Function ${t} wasn't found.`)}};var K=e=>e.type===c,Er=(e,t,r)=>{try{let n=e.getServiceState(t,r);if(K(n))return n}catch{}},
|
|
61
|
+
hr=(e,t,r)=>{let n=e.getServiceState(t,r);if(!K(n))throw new C(t);return n},S=(e,t,r)=>{
|
|
62
|
+
let n=r.getDependencies(c).at(0)?.parameters;if(!n?.functionName)throw new J(e,t,
|
|
63
|
+
"functionName");return n.functionName},tt=e=>e.getDependencies(c)[0]?.result?.functionArn,
|
|
64
|
+
Ir=(e,t,r)=>{let n=tt(r);if(!n)throw new J(e,t,"functionArn");return n};import{LambdaClient as rt,AddPermissionCommand as nt,RemovePermissionCommand as ot,
|
|
65
|
+
ResourceNotFoundException as it}from"@aws-sdk/client-lambda";import{Logger as _}from"@ez4/aws-common";var y="AWS:Lambda/Permission",l="aws:lambda.permission";var X=new rt({}),Y=async e=>{_.logCreate(y,e.functionName);let t=e.statementId??
|
|
66
|
+
`SID${Date.now()}`;return await X.send(new nt({StatementId:t,FunctionName:e.functionName,
|
|
67
67
|
SourceArn:e.sourceArn,Principal:e.principal,Action:e.action})),{statementId:t}},
|
|
68
|
-
ee=async(e,t)=>{_.logDelete(y,e);try{return await X.send(new
|
|
69
|
-
StatementId:t})),!0}catch(r){if(!(r instanceof
|
|
70
|
-
result&&e.result.functionName===t.result?.functionName,
|
|
71
|
-
if(t.result)throw new
|
|
68
|
+
ee=async(e,t)=>{_.logDelete(y,e);try{return await X.send(new ot({FunctionName:e,
|
|
69
|
+
StatementId:t})),!0}catch(r){if(!(r instanceof it))throw r;return!1}};var te=()=>({equals:at,create:re,replace:ct,preview:pt,update:mt,delete:ut}),at=(e,t)=>!!e.
|
|
70
|
+
result&&e.result.functionName===t.result?.functionName,pt=async(e,t)=>{},ct=async(e,t,r)=>{
|
|
71
|
+
if(t.result)throw new st(y,e.entryId,t.entryId);return re(e,r)},re=async(e,t)=>{
|
|
72
72
|
let r=e.parameters,n=S(y,"permission",t),o=await r.getPermission(t);return{statementId:(await Y(
|
|
73
73
|
{functionName:n,principal:o.principal,sourceArn:o.sourceArn,action:"lambda:Invok\
|
|
74
|
-
eFunction"})).statementId,functionName:n}},
|
|
75
|
-
t&&await ee(t.functionName,t.statementId)};var ne=()=>{
|
|
76
|
-
deepEqual as
|
|
77
|
-
UpdateEventSourceMappingCommand as
|
|
78
|
-
FunctionResponseType as wt,EventSourcePosition as
|
|
79
|
-
import{Logger as R,parseArn as
|
|
74
|
+
eFunction"})).statementId,functionName:n}},mt=async()=>{},ut=async e=>{let t=e.result;
|
|
75
|
+
t&&await ee(t.functionName,t.statementId)};var ne=()=>{lt(l,te())};import{registerProvider as Dt}from"@ez4/aws-common";import{ReplaceResourceError as At}from"@ez4/aws-common";import{deepCompare as bt,
|
|
76
|
+
deepEqual as Et}from"@ez4/utils";import{LambdaClient as gt,GetEventSourceMappingCommand as ft,CreateEventSourceMappingCommand as dt,
|
|
77
|
+
UpdateEventSourceMappingCommand as yt,DeleteEventSourceMappingCommand as St,ListEventSourceMappingsCommand as Ft,
|
|
78
|
+
FunctionResponseType as wt,EventSourcePosition as xt,ResourceNotFoundException as Pt}from"@aws-sdk/client-lambda";
|
|
79
|
+
import{Logger as R,parseArn as Ct}from"@ez4/aws-common";import{waitFor as Rt}from"@ez4/utils";var u="AWS:Lambda/Mapping",d="aws:lambda.mapping",oe=(r=>(r.DynamoDB="dynamodb",
|
|
80
|
+
r.Queue="sqs",r))(oe||{});var F=new gt({}),ie=async(e,t)=>{R.logImport(u,e);let r=await F.send(new Ft({FunctionName:e,
|
|
80
81
|
EventSourceArn:t})),[n]=r.EventSourceMappings;return n?{eventId:n.UUID}:void 0},
|
|
81
|
-
|
|
82
|
-
new
|
|
83
|
-
|
|
84
|
-
new
|
|
85
|
-
u,e);try{return await
|
|
86
|
-
throw t;return!1}},
|
|
87
|
-
let t=new Set(["Enabled","Disabled"]);await
|
|
88
|
-
has(r)})},
|
|
82
|
+
se=async e=>{let{sourceArn:t,functionName:r}=e;R.logCreate(u,r);let o=(await F.send(
|
|
83
|
+
new dt({FunctionName:r,EventSourceArn:t,...me(e)}))).UUID;return await ce(o),{eventId:o}},
|
|
84
|
+
ae=async(e,t)=>{let{functionName:r}=t;R.logUpdate(u,`${r} (${e})`),await F.send(
|
|
85
|
+
new yt({UUID:e,FunctionName:r,...me(t)})),await ce(e)},pe=async e=>{R.logDelete(
|
|
86
|
+
u,e);try{return await F.send(new St({UUID:e})),!0}catch(t){if(!(t instanceof Pt))
|
|
87
|
+
throw t;return!1}},vt=async e=>(await F.send(new ft({UUID:e}))).State,ce=async e=>{
|
|
88
|
+
let t=new Set(["Enabled","Disabled"]);await Rt(async()=>{let r=await vt(e);return t.
|
|
89
|
+
has(r)})},me=e=>{let{sourceArn:t,enabled:r,concurrency:n,batch:o}=e,{service:i}=Ct(
|
|
89
90
|
t);return{Enabled:r,FunctionResponseTypes:[wt.ReportBatchItemFailures],MaximumBatchingWindowInSeconds:o?.
|
|
90
|
-
maxWindow,BatchSize:o?.batchSize,...i==="dynamodb"&&{StartingPosition:
|
|
91
|
-
...i==="sqs"&&
|
|
92
|
-
result&&e.result.eventId===t.result?.eventId,
|
|
93
|
-
dependencies:e.dependencies},n={...t.parameters,dependencies:t.dependencies},o=
|
|
91
|
+
maxWindow,BatchSize:o?.batchSize,...i==="dynamodb"&&{StartingPosition:xt.LATEST},
|
|
92
|
+
...i==="sqs"&&{ScalingConfig:{MaximumConcurrency:n}}}};var ue=()=>({equals:ht,create:le,replace:Mt,preview:It,update:Nt,delete:Tt}),ht=(e,t)=>!!e.
|
|
93
|
+
result&&e.result.eventId===t.result?.eventId,It=async(e,t)=>{let r={...e.parameters,
|
|
94
|
+
dependencies:e.dependencies},n={...t.parameters,dependencies:t.dependencies},o=bt(
|
|
94
95
|
r,n,{exclude:{getSourceArn:!0}});if(o.counts)return{...o,name:r.fromService}},Mt=async(e,t,r)=>{
|
|
95
|
-
if(t.result)throw new
|
|
96
|
-
let r=e.parameters,n=S(u,"mapping",t),o=await r.getSourceArn(t);return{eventId:(await
|
|
97
|
-
n,o)??await
|
|
98
|
-
sourceArn:o}},
|
|
99
|
-
u,"mapping",r),a=t.result?.functionName??n.functionName;return await
|
|
96
|
+
if(t.result)throw new At(u,e.entryId,t.entryId);return le(e,r)},le=async(e,t)=>{
|
|
97
|
+
let r=e.parameters,n=S(u,"mapping",t),o=await r.getSourceArn(t);return{eventId:(await ie(
|
|
98
|
+
n,o)??await se({...e.parameters,functionName:n,sourceArn:o})).eventId,functionName:n,
|
|
99
|
+
sourceArn:o}},Nt=async(e,t,r)=>{let n=e.result;if(!n)return;let o=n.sourceArn,i=S(
|
|
100
|
+
u,"mapping",r),a=t.result?.functionName??n.functionName;return await Ut(n.eventId,
|
|
100
101
|
{...e.parameters,functionName:i,sourceArn:o},{...t.parameters,functionName:a,sourceArn:o}),
|
|
101
|
-
{...n,functionName:i}},
|
|
102
|
-
!
|
|
103
|
-
var
|
|
102
|
+
{...n,functionName:i}},Tt=async e=>{let t=e.result;t&&await pe(t.eventId)},Ut=async(e,t,r)=>{
|
|
103
|
+
!Et(t,r,{exclude:{getSourceArn:!0,fromService:!0}})&&await ae(e,t)};var ge=()=>{Dt(d,ue())};var fe=()=>[{account:"lambda.amazonaws.com"}];import{createPolicy as Vt,tryGetPolicy as Ht}from"@ez4/aws-identity";import{getServiceName as jt}from"@ez4/project/library";import{getAccountId as Lt,getRegion as zt,createPolicyDocument as Gt}from"@ez4/aws-identity";
|
|
104
|
+
var de=async e=>{let[t,r]=await Promise.all([zt(),Lt()]);return Gt([{permissions:[
|
|
104
105
|
"logs:CreateLogStream","logs:PutLogEvents"],resourceIds:[`arn:aws:logs:${t}:${r}\
|
|
105
|
-
:log-group:${e}-*:*`]}])};var
|
|
106
|
-
t,o)??
|
|
107
|
-
ntityAccount":
|
|
108
|
-
a.push(r.entryId),
|
|
109
|
-
dependencies:[t.entryId,r.entryId],parameters:n})},
|
|
110
|
-
r.entryId),o=e[n];return o&&
|
|
111
|
-
dependencies:[t.entryId,r.entryId],parameters:n})};var
|
|
112
|
-
d as MappingServiceType,y as PermissionServiceName,l as PermissionServiceType,
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
106
|
+
:log-group:${e}-*:*`]}])};var ye=async e=>{let{state:t,options:r}=e,n=jt("",r),o=`${n}-lambda-policy`;return Ht(
|
|
107
|
+
t,o)??Vt(t,{tags:r.tags,policyDocument:await de(n),policyName:o})};var Se=!1,vn=()=>{Se||(Ot(),Bt(),Wt(),$t("@ez4/aws-function",{"deploy:prepareIde\
|
|
108
|
+
ntityAccount":fe,"deploy:prepareExecutionPolicy":ye}),Q(),ne(),ge(),Se=!0)};import{toKebabCase as qt,hashData as Zt}from"@ez4/utils";import{attachEntry as kt}from"@ez4/stateful";var In=(e,t,r,n)=>{let o=qt(n.functionName),i=Zt(c,t.entryId,o),a=[t.entryId];return r&&
|
|
109
|
+
a.push(r.entryId),kt(e,{type:c,entryId:i,dependencies:a,parameters:{...n,functionName:o}})};import{attachEntry as Qt}from"@ez4/stateful";import{hashData as we}from"@ez4/utils";var Fe=e=>e.type===l;var Gn=(e,t,r,n)=>{let o=we(l,t.entryId,r.entryId);return Qt(e,{type:l,entryId:o,
|
|
110
|
+
dependencies:[t.entryId,r.entryId],parameters:n})},Vn=(e,t,r)=>{let n=we(l,t.entryId,
|
|
111
|
+
r.entryId),o=e[n];return o&&Fe(o)?o:null};import{hashData as Jt}from"@ez4/utils";import{attachEntry as Kt}from"@ez4/stateful";var Wn=(e,t,r,n)=>{let o=Jt(d,t.entryId,r.entryId);return Kt(e,{type:d,entryId:o,
|
|
112
|
+
dependencies:[t.entryId,r.entryId],parameters:n})};var Zn=e=>e.type===d;export{s as FunctionServiceName,c as FunctionServiceType,oe as MappingService,u as MappingServiceName,
|
|
113
|
+
d as MappingServiceType,y as PermissionServiceName,l as PermissionServiceType,In as createFunction,
|
|
114
|
+
Wn as createMapping,Gn as createPermission,Ir as getFunctionArn,S as getFunctionName,
|
|
115
|
+
hr as getFunctionState,Vn as getPermission,K as isFunctionState,Zn as isMappingState,
|
|
116
|
+
vn as registerTriggers,tt as tryGetFunctionArn,Er as tryGetFunctionState};
|
|
116
117
|
//# sourceMappingURL=main.mjs.map
|
package/dist/mapping/types.d.ts
CHANGED
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ez4/aws-function",
|
|
3
3
|
"description": "EZ4: Self-managed AWS lambda function provider",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.19.0",
|
|
5
5
|
"author": "Silas B.",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"type": "module",
|
|
@@ -38,12 +38,12 @@
|
|
|
38
38
|
},
|
|
39
39
|
"dependencies": {
|
|
40
40
|
"@aws-sdk/client-lambda": "^3.758.0",
|
|
41
|
-
"@ez4/aws-common": "^0.
|
|
42
|
-
"@ez4/aws-identity": "^0.
|
|
43
|
-
"@ez4/aws-logs": "^0.
|
|
44
|
-
"@ez4/project": "^0.
|
|
45
|
-
"@ez4/stateful": "^0.
|
|
46
|
-
"@ez4/utils": "^0.
|
|
41
|
+
"@ez4/aws-common": "^0.19.0",
|
|
42
|
+
"@ez4/aws-identity": "^0.19.0",
|
|
43
|
+
"@ez4/aws-logs": "^0.19.0",
|
|
44
|
+
"@ez4/project": "^0.19.0",
|
|
45
|
+
"@ez4/stateful": "^0.19.0",
|
|
46
|
+
"@ez4/utils": "^0.19.0",
|
|
47
47
|
"@types/adm-zip": "^0.5.5",
|
|
48
48
|
"adm-zip": "^0.5.14"
|
|
49
49
|
}
|