@ez4/local-storage 0.45.0 → 0.46.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/client/local.d.ts +8 -2
- package/dist/handlers/lambda.d.ts +4 -0
- package/dist/main.cjs +46 -34
- package/dist/main.mjs +44 -33
- package/dist/provider/emulator.d.ts +2 -2
- package/package.json +10 -7
package/dist/client/local.d.ts
CHANGED
|
@@ -1,3 +1,9 @@
|
|
|
1
1
|
import type { ServeOptions } from '@ez4/project/library';
|
|
2
|
-
import type { Client } from '@ez4/storage';
|
|
3
|
-
export
|
|
2
|
+
import type { Bucket, Client } from '@ez4/storage';
|
|
3
|
+
export type LocalClientOptions = ServeOptions & {
|
|
4
|
+
events?: {
|
|
5
|
+
handler: (event: Bucket.Event) => Promise<void>;
|
|
6
|
+
path?: string;
|
|
7
|
+
};
|
|
8
|
+
};
|
|
9
|
+
export declare const createLocalClient: (resourceName: string, options: LocalClientOptions) => Client;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { BucketEvent, BucketService } from '@ez4/storage/library';
|
|
2
|
+
import type { EmulateServiceContext, ServeOptions } from '@ez4/project/library';
|
|
3
|
+
import type { Bucket } from '@ez4/storage';
|
|
4
|
+
export declare const processLambdaEvent: (service: BucketService, options: ServeOptions, context: EmulateServiceContext, events: BucketEvent, event: Bucket.Event) => Promise<void>;
|
package/dist/main.cjs
CHANGED
|
@@ -1,36 +1,48 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
typeof
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
(0,l.
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
e)}
|
|
29
|
-
|
|
1
|
+
"use strict";var y=Object.defineProperty;var R=Object.getOwnPropertyDescriptor;var j=Object.getOwnPropertyNames;var T=Object.prototype.hasOwnProperty;var c=(t,e)=>y(t,"name",{value:e,configurable:!0});var q=(t,e)=>{for(var i in e)y(t,i,{get:e[i],enumerable:!0})},L=(t,e,i,o)=>{if(e&&
|
|
2
|
+
typeof e=="object"||typeof e=="function")for(let a of j(e))!T.call(t,a)&&a!==i&&
|
|
3
|
+
y(t,a,{get:()=>e[a],enumerable:!(o=R(e,a))||o.enumerable});return t};var H=t=>L(y({},"__esModule",{value:!0}),t);var _={};q(_,{registerTriggers:()=>W});module.exports=H(_);var S=require("@ez4/storage/library"),x=require("@ez4/project/library");var h=require("@ez4/project/library"),F=require("@ez4/logger");var p=require("@ez4/local-common"),w=require("@ez4/utils"),b=require("@ez4/common");var B=c(async(t,e,i,o,a)=>{let{services:r}=t,n=await i.makeClients(r),s=(0,w.getRandomUUID)(),
|
|
4
|
+
m=await(0,p.createModule)({listener:o.listener,handler:o.handler,version:e.version,
|
|
5
|
+
variables:{...e.variables,...t.variables,...o.variables}}),g,f={requestId:(0,w.getRandomUUID)()};
|
|
6
|
+
try{await(0,p.onBegin)(m,n,f),g={...f,...a,traceId:s},b.Runtime.setScope({traceId:s}),
|
|
7
|
+
await(0,p.onReady)(m,n,g),await m.handler(g,n),await(0,p.onDone)(m,n,g)}catch(C){
|
|
8
|
+
throw await(0,p.onError)(m,n,g??f,C),C}finally{await(0,p.onEnd)(m,n,f)}},"proces\
|
|
9
|
+
sLambdaEvent");var l=require("node:fs/promises"),u=require("node:path"),O=require("node:fs"),z=require("file-type"),
|
|
10
|
+
v=require("@ez4/utils"),P=require("@ez4/project/library"),E=require("@ez4/storage"),
|
|
11
|
+
d=require("@ez4/logger");var k=c((t,e)=>{let i=(0,P.getServiceName)(t,e),o=(0,u.join)(".ez4",(0,v.toKebabCase)(
|
|
12
|
+
t)),a=e.events;return new class{async stat(r){let n=(0,u.join)(o,r);try{let s=await(0,z.fileTypeFromFile)(
|
|
13
|
+
n),m=await(0,l.stat)(n);return{type:s?.mime??"application/octet-stream",size:m.size}}catch(s){
|
|
14
|
+
if(!(0,v.isAnyObject)(s)||s.code!=="ENOENT")throw s;return}}async exists(r){let n=(0,u.join)(
|
|
15
|
+
o,r);return Promise.resolve((0,O.existsSync)(n))}async write(r,n){let s=(0,u.join)(
|
|
16
|
+
o,r);if(await(0,l.mkdir)((0,u.dirname)(s),{recursive:!0}),await(0,l.writeFile)(s,
|
|
17
|
+
n),d.Logger.log(`\u2B06\uFE0F File ${r} uploaded.`),a&&(!a.path||r.startsWith(a.
|
|
18
|
+
path))){let m=await(0,l.stat)(s);await a.handler({eventType:E.BucketEventType.Create,
|
|
19
|
+
bucketName:i,objectSize:m.size,objectKey:r})}}async read(r){let n=(0,u.join)(o,r),
|
|
20
|
+
s=await(0,l.readFile)(n);return d.Logger.log(`\u2B07\uFE0F File ${r} downloaded\
|
|
21
|
+
.`),s}async delete(r){let n=(0,u.join)(o,r);await(0,l.unlink)(n),d.Logger.log(`\u2139\
|
|
22
|
+
\uFE0F File ${r} deleted.`),a&&(!a.path||r.startsWith(a.path))&&await a.handler(
|
|
23
|
+
{eventType:E.BucketEventType.Delete,bucketName:i,objectKey:r})}async copy(r,n){let s=(0,u.join)(
|
|
24
|
+
o,r),m=(0,u.join)(o,n);await(0,l.copyFile)(s,m),d.Logger.log(`\u2139\uFE0F File ${r}\
|
|
25
|
+
copied.`)}async*scan(){let r=await(0,l.readdir)(o,{recursive:!0});for(let n of r){
|
|
26
|
+
let{size:s,mtime:m}=await(0,l.stat)((0,u.join)(o,n));yield{key:n,modifiedAt:m,size:s}}}async getStatUrl(r,n){
|
|
27
|
+
return Promise.resolve(`http://${e.serviceHost}/${i}/${r}`)}async getWriteUrl(r,n){
|
|
28
|
+
return Promise.resolve(`http://${e.serviceHost}/${i}/${r}`)}async getReadUrl(r,n){
|
|
29
|
+
return Promise.resolve(`http://${e.serviceHost}/${i}/${r}`)}}},"createLocalClien\
|
|
30
|
+
t");var $=c(async(t,e,i)=>{let o=await U(t,e,i),{name:a}=t;return{type:"Storage",name:a,
|
|
31
|
+
identifier:(0,h.getServiceName)(a,e),bootstrapHandler:c(()=>{F.Logger.log(`\u{1F4C2} ${e.
|
|
32
|
+
local?"Local":"Remote"} storage [${a}] in use.`)},"bootstrapHandler"),requestHandler:c(
|
|
33
|
+
r=>A(o,r),"requestHandler"),exportHandler:c(()=>o,"exportHandler")}},"registerBu\
|
|
34
|
+
cketEmulator"),U=c(async(t,e,i)=>{let o=await(0,h.triggerAllAsync)("emulator:get\
|
|
35
|
+
Client",a=>a({service:t,options:e}));if(!o){let{events:a}=t;return k(t.name,{...e,
|
|
36
|
+
events:a&&{path:a.path,handler:c(r=>B(t,e,i,a,r),"handler")}})}return o},"getSto\
|
|
37
|
+
rageClient"),A=c(async(t,e)=>{let{method:i,path:o,body:a}=e;if(!o||o==="/")throw new Error(
|
|
38
|
+
"File path wasn't given.");switch(i){case"HEAD":return I(t,o);case"GET":return N(
|
|
39
|
+
t,o);case"PUT":{if(!a)throw new Error("File content wasn't given.");return D(t,o,
|
|
40
|
+
a)}default:throw new Error("Unsupported storage request.")}},"handleRequest"),N=c(
|
|
41
|
+
async(t,e)=>{let[i,o]=await Promise.all([t.read(e),t.stat(e)]);return{status:200,
|
|
30
42
|
body:i,headers:{"content-type":o?.type??"application/octet-stream"}}},"loadFile"),
|
|
31
|
-
|
|
32
|
-
let i=await
|
|
33
|
-
"content-type":i.type}}:{status:404}},"headFile");var
|
|
34
|
-
{"emulator:getServices":
|
|
35
|
-
t):null,"emulator:getServices")})},"registerTriggers");0&&(module.exports={registerTriggers});
|
|
43
|
+
D=c(async(t,e,i)=>(await t.write(e,i),{status:204}),"storeFile"),I=c(async(t,e)=>{
|
|
44
|
+
let i=await t.stat(e);return i?{status:200,headers:{"content-length":i.size.toString(),
|
|
45
|
+
"content-type":i.type}}:{status:404}},"headFile");var W=c(()=>{(0,S.registerTriggers)(),(0,x.tryCreateTrigger)("@ez4/local-storage",
|
|
46
|
+
{"emulator:getServices":c(({service:t,options:e,context:i})=>(0,S.isBucketService)(
|
|
47
|
+
t)?$(t,e,i):null,"emulator:getServices")})},"registerTriggers");0&&(module.exports={registerTriggers});
|
|
36
48
|
//# sourceMappingURL=main.cjs.map
|
package/dist/main.mjs
CHANGED
|
@@ -1,34 +1,45 @@
|
|
|
1
|
-
var
|
|
2
|
-
tryCreateTrigger as
|
|
3
|
-
|
|
4
|
-
import{
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
let
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
1
|
+
var E=Object.defineProperty;var c=(t,r)=>E(t,"name",{value:r,configurable:!0});import{isBucketService as Q,registerTriggers as V}from"@ez4/storage/library";import{
|
|
2
|
+
tryCreateTrigger as X}from"@ez4/project/library";import{getServiceName as D,triggerAllAsync as I}from"@ez4/project/library";import{
|
|
3
|
+
Logger as W}from"@ez4/logger";import{createModule as C,onBegin as b,onReady as B,onDone as O,onError as z,onEnd as P}from"@ez4/local-common";
|
|
4
|
+
import{getRandomUUID as y}from"@ez4/utils";import{Runtime as k}from"@ez4/common";var v=c(async(t,r,i,o,n)=>{let{services:e}=t,a=await i.makeClients(e),s=y(),l=await C(
|
|
5
|
+
{listener:o.listener,handler:o.handler,version:r.version,variables:{...r.variables,
|
|
6
|
+
...t.variables,...o.variables}}),p,u={requestId:y()};try{await b(l,a,u),p={...u,
|
|
7
|
+
...n,traceId:s},k.setScope({traceId:s}),await B(l,a,p),await l.handler(p,a),await O(
|
|
8
|
+
l,a,p)}catch(f){throw await z(l,a,p??u,f),f}finally{await P(l,a,u)}},"processLam\
|
|
9
|
+
bdaEvent");import{copyFile as F,mkdir as $,readdir as x,readFile as R,stat as d,unlink as j,
|
|
10
|
+
writeFile as T}from"node:fs/promises";import{dirname as q,join as m}from"node:path";
|
|
11
|
+
import{existsSync as L}from"node:fs";import{fileTypeFromFile as H}from"file-type";
|
|
12
|
+
import{isAnyObject as U,toKebabCase as A}from"@ez4/utils";import{getServiceName as N}from"@ez4/project/library";
|
|
13
|
+
import{BucketEventType as h}from"@ez4/storage";import{Logger as g}from"@ez4/logger";var S=c((t,r)=>{let i=N(t,r),o=m(".ez4",A(t)),n=r.events;return new class{async stat(e){
|
|
14
|
+
let a=m(o,e);try{let s=await H(a),l=await d(a);return{type:s?.mime??"application\
|
|
15
|
+
/octet-stream",size:l.size}}catch(s){if(!U(s)||s.code!=="ENOENT")throw s;return}}async exists(e){
|
|
16
|
+
let a=m(o,e);return Promise.resolve(L(a))}async write(e,a){let s=m(o,e);if(await $(
|
|
17
|
+
q(s),{recursive:!0}),await T(s,a),g.log(`\u2B06\uFE0F File ${e} uploaded.`),n&&
|
|
18
|
+
(!n.path||e.startsWith(n.path))){let l=await d(s);await n.handler({eventType:h.Create,
|
|
19
|
+
bucketName:i,objectSize:l.size,objectKey:e})}}async read(e){let a=m(o,e),s=await R(
|
|
20
|
+
a);return g.log(`\u2B07\uFE0F File ${e} downloaded.`),s}async delete(e){let a=m(
|
|
21
|
+
o,e);await j(a),g.log(`\u2139\uFE0F File ${e} deleted.`),n&&(!n.path||e.startsWith(
|
|
22
|
+
n.path))&&await n.handler({eventType:h.Delete,bucketName:i,objectKey:e})}async copy(e,a){
|
|
23
|
+
let s=m(o,e),l=m(o,a);await F(s,l),g.log(`\u2139\uFE0F File ${e} copied.`)}async*scan(){
|
|
24
|
+
let e=await x(o,{recursive:!0});for(let a of e){let{size:s,mtime:l}=await d(m(o,
|
|
25
|
+
a));yield{key:a,modifiedAt:l,size:s}}}async getStatUrl(e,a){return Promise.resolve(
|
|
26
|
+
`http://${r.serviceHost}/${i}/${e}`)}async getWriteUrl(e,a){return Promise.resolve(
|
|
27
|
+
`http://${r.serviceHost}/${i}/${e}`)}async getReadUrl(e,a){return Promise.resolve(
|
|
28
|
+
`http://${r.serviceHost}/${i}/${e}`)}}},"createLocalClient");var w=c(async(t,r,i)=>{let o=await _(t,r,i),{name:n}=t;return{type:"Storage",name:n,
|
|
29
|
+
identifier:D(n,r),bootstrapHandler:c(()=>{W.log(`\u{1F4C2} ${r.local?"Local":"Re\
|
|
30
|
+
mote"} storage [${n}] in use.`)},"bootstrapHandler"),requestHandler:c(e=>G(o,e),
|
|
31
|
+
"requestHandler"),exportHandler:c(()=>o,"exportHandler")}},"registerBucketEmulat\
|
|
32
|
+
or"),_=c(async(t,r,i)=>{let o=await I("emulator:getClient",n=>n({service:t,options:r}));
|
|
33
|
+
if(!o){let{events:n}=t;return S(t.name,{...r,events:n&&{path:n.path,handler:c(e=>v(
|
|
34
|
+
t,r,i,n,e),"handler")}})}return o},"getStorageClient"),G=c(async(t,r)=>{let{method:i,
|
|
35
|
+
path:o,body:n}=r;if(!o||o==="/")throw new Error("File path wasn't given.");switch(i){case"\
|
|
36
|
+
HEAD":return J(t,o);case"GET":return K(t,o);case"PUT":{if(!n)throw new Error("Fi\
|
|
37
|
+
le content wasn't given.");return M(t,o,n)}default:throw new Error("Unsupported \
|
|
38
|
+
storage request.")}},"handleRequest"),K=c(async(t,r)=>{let[i,o]=await Promise.all(
|
|
39
|
+
[t.read(r),t.stat(r)]);return{status:200,body:i,headers:{"content-type":o?.type??
|
|
40
|
+
"application/octet-stream"}}},"loadFile"),M=c(async(t,r,i)=>(await t.write(r,i),
|
|
41
|
+
{status:204}),"storeFile"),J=c(async(t,r)=>{let i=await t.stat(r);return i?{status:200,
|
|
42
|
+
headers:{"content-length":i.size.toString(),"content-type":i.type}}:{status:404}},
|
|
43
|
+
"headFile");var Be=c(()=>{V(),X("@ez4/local-storage",{"emulator:getServices":c(({service:t,options:r,
|
|
44
|
+
context:i})=>Q(t)?w(t,r,i):null,"emulator:getServices")})},"registerTriggers");export{Be as registerTriggers};
|
|
34
45
|
//# sourceMappingURL=main.mjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type { EmulatorRequestEvent, ServeOptions } from '@ez4/project/library';
|
|
1
|
+
import type { EmulateServiceContext, EmulatorRequestEvent, ServeOptions } from '@ez4/project/library';
|
|
2
2
|
import type { Client as StorageClient } from '@ez4/storage';
|
|
3
3
|
import type { BucketService } from '@ez4/storage/library';
|
|
4
|
-
export declare const registerBucketEmulator: (service: BucketService, options: ServeOptions) => Promise<{
|
|
4
|
+
export declare const registerBucketEmulator: (service: BucketService, options: ServeOptions, context: EmulateServiceContext) => Promise<{
|
|
5
5
|
type: string;
|
|
6
6
|
name: string;
|
|
7
7
|
identifier: string;
|
package/package.json
CHANGED
|
@@ -1,13 +1,15 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ez4/local-storage",
|
|
3
3
|
"description": "EZ4: Local storage emulator",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.46.0",
|
|
5
5
|
"author": "Silas B.",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"type": "module",
|
|
8
8
|
"keywords": [
|
|
9
9
|
"ez4",
|
|
10
|
-
"
|
|
10
|
+
"local",
|
|
11
|
+
"emulator",
|
|
12
|
+
"storage"
|
|
11
13
|
],
|
|
12
14
|
"repository": {
|
|
13
15
|
"type": "git",
|
|
@@ -48,11 +50,12 @@
|
|
|
48
50
|
"live:publish": "npm run build && npm publish --access public"
|
|
49
51
|
},
|
|
50
52
|
"dependencies": {
|
|
51
|
-
"@ez4/
|
|
52
|
-
"@ez4/
|
|
53
|
-
"@ez4/
|
|
54
|
-
"@ez4/
|
|
55
|
-
"@ez4/
|
|
53
|
+
"@ez4/common": "^0.46.0",
|
|
54
|
+
"@ez4/local-common": "^0.46.0",
|
|
55
|
+
"@ez4/logger": "^0.46.0",
|
|
56
|
+
"@ez4/project": "^0.46.0",
|
|
57
|
+
"@ez4/storage": "^0.46.0",
|
|
58
|
+
"@ez4/utils": "^0.46.0",
|
|
56
59
|
"file-type": "^21.3.0"
|
|
57
60
|
}
|
|
58
61
|
}
|