@ez4/local-storage 0.43.0 → 0.45.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 +3 -0
- package/dist/main.cjs +35 -29
- package/dist/main.mjs +33 -27
- package/dist/provider/emulator.d.ts +4 -3
- package/dist/run.cjs +4 -0
- package/dist/run.d.ts +1 -0
- package/dist/run.mjs +2 -0
- package/dist/service/runner.d.ts +4 -0
- package/dist/service/tester.d.ts +6 -2
- package/dist/test.cjs +24 -19
- package/dist/test.mjs +22 -15
- package/package.json +11 -6
package/dist/main.cjs
CHANGED
|
@@ -1,30 +1,36 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
typeof
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
return
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
o,
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
t.
|
|
18
|
-
i
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
"
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
1
|
+
"use strict";var p=Object.defineProperty;var F=Object.getOwnPropertyDescriptor;var P=Object.getOwnPropertyNames;var $=Object.prototype.hasOwnProperty;var s=(r,t)=>p(r,"name",{value:t,configurable:!0});var O=(r,t)=>{for(var i in t)p(r,i,{get:t[i],enumerable:!0})},b=(r,t,i,o)=>{if(t&&
|
|
2
|
+
typeof t=="object"||typeof t=="function")for(let e of P(t))!$.call(r,e)&&e!==i&&
|
|
3
|
+
p(r,e,{get:()=>t[e],enumerable:!(o=F(t,e))||o.enumerable});return r};var z=r=>b(p({},"__esModule",{value:!0}),r);var k={};O(k,{registerTriggers:()=>H});module.exports=z(k);var y=require("@ez4/storage/library"),C=require("@ez4/project/library");var f=require("@ez4/project/library");var a=require("node:fs/promises"),l=require("node:path"),S=require("node:fs"),w=require("file-type"),
|
|
4
|
+
u=require("@ez4/utils"),v=require("@ez4/project/library"),m=require("@ez4/logger");var h=s((r,t)=>{let i=(0,v.getServiceName)(r,t),o=(0,l.join)(".ez4",(0,u.toKebabCase)(
|
|
5
|
+
r));return new class{async stat(e){let n=(0,l.join)(o,e);try{let c=await(0,w.fileTypeFromFile)(
|
|
6
|
+
n),g=await(0,a.stat)(n);return{type:c?.mime??"application/octet-stream",size:g.size}}catch(c){
|
|
7
|
+
if(!(0,u.isAnyObject)(c)||c.code!=="ENOENT")throw c;return}}async exists(e){let n=(0,l.join)(
|
|
8
|
+
o,e);return Promise.resolve((0,S.existsSync)(n))}async write(e,n){let c=(0,l.join)(
|
|
9
|
+
o,e);await(0,a.mkdir)((0,l.dirname)(c),{recursive:!0}),await(0,a.writeFile)(c,n),
|
|
10
|
+
m.Logger.log(`\u2B06\uFE0F File ${e} uploaded.`)}async read(e){let n=(0,l.join)(
|
|
11
|
+
o,e),c=await(0,a.readFile)(n);return m.Logger.log(`\u2B07\uFE0F File ${e} downl\
|
|
12
|
+
oaded.`),c}async delete(e){let n=(0,l.join)(o,e);await(0,a.unlink)(n),m.Logger.log(
|
|
13
|
+
`\u2139\uFE0F File ${e} deleted.`)}async copy(e,n){let c=(0,l.join)(o,e),g=(0,l.join)(
|
|
14
|
+
o,n);await(0,a.copyFile)(c,g),m.Logger.log(`\u2139\uFE0F File ${e} copied.`)}async*scan(){
|
|
15
|
+
let e=await(0,a.readdir)(o,{recursive:!0});for(let n of e){let{size:c,mtime:g}=await(0,a.stat)(
|
|
16
|
+
(0,l.join)(o,n));yield{key:n,modifiedAt:g,size:c}}}async getStatUrl(e,n){return Promise.
|
|
17
|
+
resolve(`http://${t.serviceHost}/${i}/${e}`)}async getWriteUrl(e,n){return Promise.
|
|
18
|
+
resolve(`http://${t.serviceHost}/${i}/${e}`)}async getReadUrl(e,n){return Promise.
|
|
19
|
+
resolve(`http://${t.serviceHost}/${i}/${e}`)}}},"createLocalClient");var d=require("@ez4/logger");var E=s(async(r,t)=>{let i=await R(r,t),{name:o}=r;return{type:"Storage",name:o,
|
|
20
|
+
identifier:(0,f.getServiceName)(o,t),bootstrapHandler:s(()=>{t.local?d.Logger.log(
|
|
21
|
+
`\u{1F4C2} Local storage [${o}] in use.`):d.Logger.log(`\u{1F4C2} Remote storage [${o}\
|
|
22
|
+
] in use.`)},"bootstrapHandler"),requestHandler:s(e=>B(i,e),"requestHandler"),exportHandler:s(
|
|
23
|
+
()=>i,"exportHandler")}},"registerBucketEmulator"),R=s(async(r,t)=>{let i=await(0,f.triggerAllAsync)(
|
|
24
|
+
"emulator:getClient",o=>o({service:r,options:t}));return i||h(r.name,t)},"getSto\
|
|
25
|
+
rageClient"),B=s(async(r,t)=>{let{method:i,path:o,body:e}=t;if(!o||o==="/")throw new Error(
|
|
26
|
+
"File path wasn't given.");switch(i){case"HEAD":return x(r,o);case"GET":return T(
|
|
27
|
+
r,o);case"PUT":{if(!e)throw new Error("File content wasn't given.");return j(r,o,
|
|
28
|
+
e)}default:throw new Error("Unsupported storage request.")}},"handleRequest"),T=s(
|
|
29
|
+
async(r,t)=>{let[i,o]=await Promise.all([r.read(t),r.stat(t)]);return{status:200,
|
|
30
|
+
body:i,headers:{"content-type":o?.type??"application/octet-stream"}}},"loadFile"),
|
|
31
|
+
j=s(async(r,t,i)=>(await r.write(t,i),{status:204}),"storeFile"),x=s(async(r,t)=>{
|
|
32
|
+
let i=await r.stat(t);return i?{status:200,headers:{"content-length":i.size.toString(),
|
|
33
|
+
"content-type":i.type}}:{status:404}},"headFile");var H=s(()=>{(0,y.registerTriggers)(),(0,C.tryCreateTrigger)("@ez4/local-storage",
|
|
34
|
+
{"emulator:getServices":s(({service:r,options:t})=>(0,y.isBucketService)(r)?E(r,
|
|
35
|
+
t):null,"emulator:getServices")})},"registerTriggers");0&&(module.exports={registerTriggers});
|
|
30
36
|
//# sourceMappingURL=main.cjs.map
|
package/dist/main.mjs
CHANGED
|
@@ -1,28 +1,34 @@
|
|
|
1
|
-
var
|
|
2
|
-
tryCreateTrigger as
|
|
3
|
-
|
|
4
|
-
import{
|
|
5
|
-
import{
|
|
6
|
-
|
|
7
|
-
await
|
|
8
|
-
|
|
9
|
-
let n=c(
|
|
10
|
-
|
|
11
|
-
return
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
t
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
"
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
1
|
+
var y=Object.defineProperty;var s=(e,r)=>y(e,"name",{value:r,configurable:!0});import{isBucketService as k,registerTriggers as q}from"@ez4/storage/library";import{
|
|
2
|
+
tryCreateTrigger as A}from"@ez4/project/library";import{getServiceName as z,triggerAllAsync as R}from"@ez4/project/library";import{copyFile as d,mkdir as S,readdir as w,readFile as v,stat as m,unlink as h,
|
|
3
|
+
writeFile as E}from"node:fs/promises";import{dirname as C,join as c}from"node:path";
|
|
4
|
+
import{existsSync as F}from"node:fs";import{fileTypeFromFile as P}from"file-type";
|
|
5
|
+
import{isAnyObject as $,toKebabCase as O}from"@ez4/utils";import{getServiceName as b}from"@ez4/project/library";
|
|
6
|
+
import{Logger as g}from"@ez4/logger";var p=s((e,r)=>{let i=b(e,r),o=c(".ez4",O(e));return new class{async stat(t){let n=c(
|
|
7
|
+
o,t);try{let a=await P(n),l=await m(n);return{type:a?.mime??"application/octet-s\
|
|
8
|
+
tream",size:l.size}}catch(a){if(!$(a)||a.code!=="ENOENT")throw a;return}}async exists(t){
|
|
9
|
+
let n=c(o,t);return Promise.resolve(F(n))}async write(t,n){let a=c(o,t);await S(
|
|
10
|
+
C(a),{recursive:!0}),await E(a,n),g.log(`\u2B06\uFE0F File ${t} uploaded.`)}async read(t){
|
|
11
|
+
let n=c(o,t),a=await v(n);return g.log(`\u2B07\uFE0F File ${t} downloaded.`),a}async delete(t){
|
|
12
|
+
let n=c(o,t);await h(n),g.log(`\u2139\uFE0F File ${t} deleted.`)}async copy(t,n){
|
|
13
|
+
let a=c(o,t),l=c(o,n);await d(a,l),g.log(`\u2139\uFE0F File ${t} copied.`)}async*scan(){
|
|
14
|
+
let t=await w(o,{recursive:!0});for(let n of t){let{size:a,mtime:l}=await m(c(o,
|
|
15
|
+
n));yield{key:n,modifiedAt:l,size:a}}}async getStatUrl(t,n){return Promise.resolve(
|
|
16
|
+
`http://${r.serviceHost}/${i}/${t}`)}async getWriteUrl(t,n){return Promise.resolve(
|
|
17
|
+
`http://${r.serviceHost}/${i}/${t}`)}async getReadUrl(t,n){return Promise.resolve(
|
|
18
|
+
`http://${r.serviceHost}/${i}/${t}`)}}},"createLocalClient");import{Logger as u}from"@ez4/logger";var f=s(async(e,r)=>{let i=await B(e,r),{name:o}=e;return{type:"Storage",name:o,
|
|
19
|
+
identifier:z(o,r),bootstrapHandler:s(()=>{r.local?u.log(`\u{1F4C2} Local storage [${o}\
|
|
20
|
+
] in use.`):u.log(`\u{1F4C2} Remote storage [${o}] in use.`)},"bootstrapHandler"),
|
|
21
|
+
requestHandler:s(t=>T(i,t),"requestHandler"),exportHandler:s(()=>i,"exportHandle\
|
|
22
|
+
r")}},"registerBucketEmulator"),B=s(async(e,r)=>{let i=await R("emulator:getClie\
|
|
23
|
+
nt",o=>o({service:e,options:r}));return i||p(e.name,r)},"getStorageClient"),T=s(
|
|
24
|
+
async(e,r)=>{let{method:i,path:o,body:t}=r;if(!o||o==="/")throw new Error("File \
|
|
25
|
+
path wasn't given.");switch(i){case"HEAD":return H(e,o);case"GET":return j(e,o);case"\
|
|
26
|
+
PUT":{if(!t)throw new Error("File content wasn't given.");return x(e,o,t)}default:
|
|
27
|
+
throw new Error("Unsupported storage request.")}},"handleRequest"),j=s(async(e,r)=>{
|
|
28
|
+
let[i,o]=await Promise.all([e.read(r),e.stat(r)]);return{status:200,body:i,headers:{
|
|
29
|
+
"content-type":o?.type??"application/octet-stream"}}},"loadFile"),x=s(async(e,r,i)=>(await e.
|
|
30
|
+
write(r,i),{status:204}),"storeFile"),H=s(async(e,r)=>{let i=await e.stat(r);return i?
|
|
31
|
+
{status:200,headers:{"content-length":i.size.toString(),"content-type":i.type}}:
|
|
32
|
+
{status:404}},"headFile");var ot=s(()=>{q(),A("@ez4/local-storage",{"emulator:getServices":s(({service:e,options:r})=>k(
|
|
33
|
+
e)?f(e,r):null,"emulator:getServices")})},"registerTriggers");export{ot as registerTriggers};
|
|
28
34
|
//# sourceMappingURL=main.mjs.map
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import type { 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) => {
|
|
4
|
+
export declare const registerBucketEmulator: (service: BucketService, options: ServeOptions) => Promise<{
|
|
5
5
|
type: string;
|
|
6
6
|
name: string;
|
|
7
7
|
identifier: string;
|
|
8
|
-
|
|
8
|
+
bootstrapHandler: () => void;
|
|
9
9
|
requestHandler: (request: EmulatorRequestEvent) => Promise<{
|
|
10
10
|
status: number;
|
|
11
11
|
}>;
|
|
12
|
-
|
|
12
|
+
exportHandler: () => StorageClient;
|
|
13
|
+
}>;
|
package/dist/run.cjs
ADDED
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
"use strict";var i=Object.defineProperty;var a=Object.getOwnPropertyDescriptor;var g=Object.getOwnPropertyNames;var l=Object.prototype.hasOwnProperty;var p=(t,e)=>i(t,"name",{value:e,configurable:!0});var C=(t,e)=>{for(var r in e)i(t,r,{get:e[r],enumerable:!0})},f=(t,e,r,n)=>{if(e&&
|
|
2
|
+
typeof e=="object"||typeof e=="function")for(let o of g(e))!l.call(t,o)&&o!==r&&
|
|
3
|
+
i(t,o,{get:()=>e[o],enumerable:!(n=a(e,o))||n.enumerable});return t};var x=t=>f(i({},"__esModule",{value:!0}),t);var c={};C(c,{BucketRunner:()=>s});module.exports=x(c);var m=require("@ez4/project/library");var s;(e=>e.getClient=p(r=>m.Runner.getServiceClient(r),"getClient"))(s||={});0&&(module.exports={BucketRunner});
|
|
4
|
+
//# sourceMappingURL=run.cjs.map
|
package/dist/run.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './service/runner';
|
package/dist/run.mjs
ADDED
package/dist/service/tester.d.ts
CHANGED
|
@@ -4,15 +4,19 @@ import type { ClientMockOptions } from '../client/mock';
|
|
|
4
4
|
export declare namespace BucketTester {
|
|
5
5
|
type MockOptions = ClientMockOptions;
|
|
6
6
|
type ClientMock = Client & {
|
|
7
|
+
stat: Mock<Client['stat']>;
|
|
7
8
|
exists: Mock<Client['exists']>;
|
|
8
9
|
write: Mock<Client['write']>;
|
|
9
10
|
read: Mock<Client['read']>;
|
|
10
11
|
delete: Mock<Client['delete']>;
|
|
12
|
+
copy: Mock<Client['copy']>;
|
|
13
|
+
scan: Mock<Client['scan']>;
|
|
14
|
+
getStatUrl: Mock<Client['getStatUrl']>;
|
|
11
15
|
getWriteUrl: Mock<Client['getWriteUrl']>;
|
|
12
16
|
getReadUrl: Mock<Client['getReadUrl']>;
|
|
13
|
-
getStatsUrl: Mock<Client['getStatsUrl']>;
|
|
14
|
-
getStats: Mock<Client['getStats']>;
|
|
15
17
|
};
|
|
16
18
|
const getClient: (resourceName: string) => Client;
|
|
17
19
|
const getClientMock: (resourceName: string, options?: MockOptions) => ClientMock;
|
|
20
|
+
const setClientMock: (resourceName: string, options: MockOptions) => void;
|
|
21
|
+
const restoreClient: (resourceName: string) => void;
|
|
18
22
|
}
|
package/dist/test.cjs
CHANGED
|
@@ -1,20 +1,25 @@
|
|
|
1
|
-
"use strict";var
|
|
2
|
-
typeof
|
|
3
|
-
|
|
4
|
-
let t=
|
|
5
|
-
|
|
6
|
-
o
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
return Promise.resolve(
|
|
12
|
-
resolve(
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
l
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
1
|
+
"use strict";var d=Object.defineProperty;var u=Object.getOwnPropertyDescriptor;var h=Object.getOwnPropertyNames;var k=Object.prototype.hasOwnProperty;var a=(n,o)=>d(n,"name",{value:o,configurable:!0});var v=(n,o)=>{for(var l in o)d(n,l,{get:o[l],enumerable:!0})},w=(n,o,l,r)=>{if(o&&
|
|
2
|
+
typeof o=="object"||typeof o=="function")for(let e of h(o))!k.call(n,e)&&e!==l&&
|
|
3
|
+
d(n,e,{get:()=>o[e],enumerable:!(r=u(o,e))||r.enumerable});return n};var x=n=>w(d({},"__esModule",{value:!0}),n);var O={};v(O,{BucketTester:()=>M});module.exports=x(O);var p=require("@ez4/project/library"),s=require("node:test");var g=require("node:stream"),f=require("file-type"),C=require("@ez4/utils"),m=require("@ez4/logger");var y=a((n,o)=>{let l=(0,C.toKebabCase)(n),r=o?.keys??{};return new class{async stat(e){
|
|
4
|
+
let t=r[e]??o?.default;return t?{type:(await(0,f.fileTypeFromBuffer)(t))?.mime??
|
|
5
|
+
"application/octet-stream",size:t.byteLength}:void 0}async exists(e){let t=r[e]??
|
|
6
|
+
o?.default;return Promise.resolve(!!t)}async write(e,t){return m.Logger.log(`\u2B06\uFE0F \
|
|
7
|
+
File ${e} uploaded.`),t instanceof g.Readable?r[e]=t.read():r[e]=Buffer.from(t),
|
|
8
|
+
Promise.resolve()}async read(e){let t=r[e]??o?.default;if(!t)throw new Error(`Ke\
|
|
9
|
+
y ${e} not found.`);return m.Logger.log(`\u2B07\uFE0F File ${e} downloaded.`),Promise.
|
|
10
|
+
resolve(Buffer.from(t))}async delete(e){if(!r[e]){if(!o?.default)throw new Error(
|
|
11
|
+
`Key ${e} not found.`);return Promise.resolve()}return m.Logger.log(`\u2139\uFE0F File ${e}\
|
|
12
|
+
deleted.`),delete r[e],Promise.resolve()}async copy(e,t){let c=r[e]??o?.default;
|
|
13
|
+
if(!c)throw new Error(`Key ${e} not found.`);return m.Logger.log(`\u2139\uFE0F File ${e}\
|
|
14
|
+
copied.`),r[t]=c,Promise.resolve()}async*scan(){for(let e in r){let t=r[e];yield Promise.
|
|
15
|
+
resolve({modifiedAt:new Date,size:t.length,key:e})}}async getStatUrl(e,t){return Promise.
|
|
16
|
+
resolve(`http://${l}/${e}`)}async getWriteUrl(e,t){return Promise.resolve(`http:\
|
|
17
|
+
//${l}/${e}`)}async getReadUrl(e,t){return Promise.resolve(`http://${l}/${e}`)}}},
|
|
18
|
+
"createClientMock");var M;(e=>(e.getClient=a(t=>p.Tester.getServiceClient(t),"getClient"),e.getClientMock=
|
|
19
|
+
a((t,c)=>{let i=y(t,c);return s.mock.method(i,"stat"),s.mock.method(i,"exists"),
|
|
20
|
+
s.mock.method(i,"write"),s.mock.method(i,"read"),s.mock.method(i,"delete"),s.mock.
|
|
21
|
+
method(i,"copy"),s.mock.method(i,"scan"),s.mock.method(i,"getStatUrl"),s.mock.method(
|
|
22
|
+
i,"getWriteUrl"),s.mock.method(i,"getReadUrl"),i},"getClientMock"),e.setClientMock=
|
|
23
|
+
a((t,c)=>{p.Tester.mockServiceClient(t,(0,e.getClientMock)(t,c))},"setClientMock"),
|
|
24
|
+
e.restoreClient=a(t=>{p.Tester.restoreServiceClient(t)},"restoreClient")))(M||={});0&&(module.exports={BucketTester});
|
|
20
25
|
//# sourceMappingURL=test.cjs.map
|
package/dist/test.mjs
CHANGED
|
@@ -1,16 +1,23 @@
|
|
|
1
|
-
var
|
|
2
|
-
import{
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
if(!
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
1
|
+
var g=Object.defineProperty;var l=(c,n)=>g(c,"name",{value:n,configurable:!0});import{Tester as d}from"@ez4/project/library";import{mock as i}from"node:test";import{Readable as f}from"node:stream";import{fileTypeFromBuffer as C}from"file-type";
|
|
2
|
+
import{toKebabCase as y}from"@ez4/utils";import{Logger as m}from"@ez4/logger";var p=l((c,n)=>{let a=y(c),o=n?.keys??{};return new class{async stat(e){let t=o[e]??
|
|
3
|
+
n?.default;return t?{type:(await C(t))?.mime??"application/octet-stream",size:t.
|
|
4
|
+
byteLength}:void 0}async exists(e){let t=o[e]??n?.default;return Promise.resolve(
|
|
5
|
+
!!t)}async write(e,t){return m.log(`\u2B06\uFE0F File ${e} uploaded.`),t instanceof
|
|
6
|
+
f?o[e]=t.read():o[e]=Buffer.from(t),Promise.resolve()}async read(e){let t=o[e]??
|
|
7
|
+
n?.default;if(!t)throw new Error(`Key ${e} not found.`);return m.log(`\u2B07\uFE0F File ${e}\
|
|
8
|
+
downloaded.`),Promise.resolve(Buffer.from(t))}async delete(e){if(!o[e]){if(!n?.
|
|
9
|
+
default)throw new Error(`Key ${e} not found.`);return Promise.resolve()}return m.
|
|
10
|
+
log(`\u2139\uFE0F File ${e} deleted.`),delete o[e],Promise.resolve()}async copy(e,t){
|
|
11
|
+
let s=o[e]??n?.default;if(!s)throw new Error(`Key ${e} not found.`);return m.log(
|
|
12
|
+
`\u2139\uFE0F File ${e} copied.`),o[t]=s,Promise.resolve()}async*scan(){for(let e in o){
|
|
13
|
+
let t=o[e];yield Promise.resolve({modifiedAt:new Date,size:t.length,key:e})}}async getStatUrl(e,t){
|
|
14
|
+
return Promise.resolve(`http://${a}/${e}`)}async getWriteUrl(e,t){return Promise.
|
|
15
|
+
resolve(`http://${a}/${e}`)}async getReadUrl(e,t){return Promise.resolve(`http:/\
|
|
16
|
+
/${a}/${e}`)}}},"createClientMock");var M;(e=>(e.getClient=l(t=>d.getServiceClient(t),"getClient"),e.getClientMock=l(
|
|
17
|
+
(t,s)=>{let r=p(t,s);return i.method(r,"stat"),i.method(r,"exists"),i.method(r,"\
|
|
18
|
+
write"),i.method(r,"read"),i.method(r,"delete"),i.method(r,"copy"),i.method(r,"s\
|
|
19
|
+
can"),i.method(r,"getStatUrl"),i.method(r,"getWriteUrl"),i.method(r,"getReadUrl"),
|
|
20
|
+
r},"getClientMock"),e.setClientMock=l((t,s)=>{d.mockServiceClient(t,(0,e.getClientMock)(
|
|
21
|
+
t,s))},"setClientMock"),e.restoreClient=l(t=>{d.restoreServiceClient(t)},"restor\
|
|
22
|
+
eClient")))(M||={});export{M as BucketTester};
|
|
16
23
|
//# sourceMappingURL=test.mjs.map
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ez4/local-storage",
|
|
3
3
|
"description": "EZ4: Local storage emulator",
|
|
4
|
-
"version": "0.
|
|
4
|
+
"version": "0.45.0",
|
|
5
5
|
"author": "Silas B.",
|
|
6
6
|
"license": "MIT",
|
|
7
7
|
"type": "module",
|
|
@@ -27,6 +27,11 @@
|
|
|
27
27
|
"types": "./dist/test.d.ts",
|
|
28
28
|
"require": "./dist/test.cjs",
|
|
29
29
|
"import": "./dist/test.mjs"
|
|
30
|
+
},
|
|
31
|
+
"./run": {
|
|
32
|
+
"types": "./dist/run.d.ts",
|
|
33
|
+
"require": "./dist/run.cjs",
|
|
34
|
+
"import": "./dist/run.mjs"
|
|
30
35
|
}
|
|
31
36
|
},
|
|
32
37
|
"workspaces": [
|
|
@@ -43,11 +48,11 @@
|
|
|
43
48
|
"live:publish": "npm run build && npm publish --access public"
|
|
44
49
|
},
|
|
45
50
|
"dependencies": {
|
|
46
|
-
"@ez4/local-common": "^0.
|
|
47
|
-
"@ez4/logger": "^0.
|
|
48
|
-
"@ez4/project": "^0.
|
|
49
|
-
"@ez4/storage": "^0.
|
|
50
|
-
"@ez4/utils": "^0.
|
|
51
|
+
"@ez4/local-common": "^0.45.0",
|
|
52
|
+
"@ez4/logger": "^0.45.0",
|
|
53
|
+
"@ez4/project": "^0.45.0",
|
|
54
|
+
"@ez4/storage": "^0.45.0",
|
|
55
|
+
"@ez4/utils": "^0.45.0",
|
|
51
56
|
"file-type": "^21.3.0"
|
|
52
57
|
}
|
|
53
58
|
}
|