@meistrari/vault-sdk 0.0.1 → 0.0.3
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/index.d.mts +47 -0
- package/dist/index.d.ts +47 -0
- package/dist/index.mjs +116 -0
- package/package.json +17 -11
package/dist/index.d.mts
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
interface AuthStrategy {
|
|
2
|
+
getHeaders: () => Headers;
|
|
3
|
+
}
|
|
4
|
+
declare class DataTokenAuthStrategy implements AuthStrategy {
|
|
5
|
+
dataToken: string;
|
|
6
|
+
getHeaders(): Headers;
|
|
7
|
+
constructor(dataToken: string);
|
|
8
|
+
}
|
|
9
|
+
declare class APIKeyAuthStrategy implements AuthStrategy {
|
|
10
|
+
apiKey: string;
|
|
11
|
+
getHeaders(): Headers;
|
|
12
|
+
constructor(apiKey: string);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
type FetchParams = {
|
|
16
|
+
method: 'GET' | 'POST' | 'PUT';
|
|
17
|
+
path: string | URL;
|
|
18
|
+
body?: any;
|
|
19
|
+
ignoreHeaders?: boolean;
|
|
20
|
+
};
|
|
21
|
+
type VaultParams = {
|
|
22
|
+
name: string;
|
|
23
|
+
authStrategy: AuthStrategy;
|
|
24
|
+
vaultUrl: string;
|
|
25
|
+
};
|
|
26
|
+
declare class VaultFile {
|
|
27
|
+
readonly name: string;
|
|
28
|
+
readonly vaultUrl: string;
|
|
29
|
+
readonly headers: Headers;
|
|
30
|
+
constructor(params: VaultParams);
|
|
31
|
+
getUploadUrl(): Promise<any>;
|
|
32
|
+
getDownloadUrl(): Promise<URL>;
|
|
33
|
+
_fetch(params: FetchParams): Promise<any>;
|
|
34
|
+
upload(file: Blob): Promise<void>;
|
|
35
|
+
download(): Promise<Blob>;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
declare class FetchError extends Error {
|
|
39
|
+
readonly response: Response;
|
|
40
|
+
constructor(message: string, response: Response);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
declare function useVault(vaultUrl: string, authStrategy: AuthStrategy): {
|
|
44
|
+
createVaultFile: (name: string) => VaultFile;
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export { APIKeyAuthStrategy, type AuthStrategy, DataTokenAuthStrategy, FetchError, VaultFile, useVault };
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
interface AuthStrategy {
|
|
2
|
+
getHeaders: () => Headers;
|
|
3
|
+
}
|
|
4
|
+
declare class DataTokenAuthStrategy implements AuthStrategy {
|
|
5
|
+
dataToken: string;
|
|
6
|
+
getHeaders(): Headers;
|
|
7
|
+
constructor(dataToken: string);
|
|
8
|
+
}
|
|
9
|
+
declare class APIKeyAuthStrategy implements AuthStrategy {
|
|
10
|
+
apiKey: string;
|
|
11
|
+
getHeaders(): Headers;
|
|
12
|
+
constructor(apiKey: string);
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
type FetchParams = {
|
|
16
|
+
method: 'GET' | 'POST' | 'PUT';
|
|
17
|
+
path: string | URL;
|
|
18
|
+
body?: any;
|
|
19
|
+
ignoreHeaders?: boolean;
|
|
20
|
+
};
|
|
21
|
+
type VaultParams = {
|
|
22
|
+
name: string;
|
|
23
|
+
authStrategy: AuthStrategy;
|
|
24
|
+
vaultUrl: string;
|
|
25
|
+
};
|
|
26
|
+
declare class VaultFile {
|
|
27
|
+
readonly name: string;
|
|
28
|
+
readonly vaultUrl: string;
|
|
29
|
+
readonly headers: Headers;
|
|
30
|
+
constructor(params: VaultParams);
|
|
31
|
+
getUploadUrl(): Promise<any>;
|
|
32
|
+
getDownloadUrl(): Promise<URL>;
|
|
33
|
+
_fetch(params: FetchParams): Promise<any>;
|
|
34
|
+
upload(file: Blob): Promise<void>;
|
|
35
|
+
download(): Promise<Blob>;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
declare class FetchError extends Error {
|
|
39
|
+
readonly response: Response;
|
|
40
|
+
constructor(message: string, response: Response);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
declare function useVault(vaultUrl: string, authStrategy: AuthStrategy): {
|
|
44
|
+
createVaultFile: (name: string) => VaultFile;
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
export { APIKeyAuthStrategy, type AuthStrategy, DataTokenAuthStrategy, FetchError, VaultFile, useVault };
|
package/dist/index.mjs
ADDED
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
class FetchError extends Error {
|
|
2
|
+
constructor(message, response) {
|
|
3
|
+
super(message);
|
|
4
|
+
this.response = response;
|
|
5
|
+
this.name = "FetchError";
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
var __defProp$1 = Object.defineProperty;
|
|
10
|
+
var __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
11
|
+
var __publicField$1 = (obj, key, value) => {
|
|
12
|
+
__defNormalProp$1(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
13
|
+
return value;
|
|
14
|
+
};
|
|
15
|
+
class VaultFile {
|
|
16
|
+
constructor(params) {
|
|
17
|
+
__publicField$1(this, "name");
|
|
18
|
+
__publicField$1(this, "vaultUrl");
|
|
19
|
+
__publicField$1(this, "headers");
|
|
20
|
+
this.name = params.name;
|
|
21
|
+
this.vaultUrl = params.vaultUrl;
|
|
22
|
+
this.headers = params.authStrategy.getHeaders();
|
|
23
|
+
}
|
|
24
|
+
async getUploadUrl() {
|
|
25
|
+
const response = await this._fetch({
|
|
26
|
+
method: "POST",
|
|
27
|
+
path: `/files/${this.name}`
|
|
28
|
+
});
|
|
29
|
+
return response.url;
|
|
30
|
+
}
|
|
31
|
+
async getDownloadUrl() {
|
|
32
|
+
const response = await this._fetch({
|
|
33
|
+
method: "GET",
|
|
34
|
+
path: `/files/${this.name}`
|
|
35
|
+
});
|
|
36
|
+
return new URL(response.url);
|
|
37
|
+
}
|
|
38
|
+
async _fetch(params) {
|
|
39
|
+
const { method, path, body, ignoreHeaders } = params;
|
|
40
|
+
const url = path instanceof URL ? path.toString() : new URL(path, this.vaultUrl).toString();
|
|
41
|
+
const response = await fetch(url, {
|
|
42
|
+
method,
|
|
43
|
+
body,
|
|
44
|
+
headers: ignoreHeaders ? void 0 : this.headers
|
|
45
|
+
});
|
|
46
|
+
if (!response.ok) {
|
|
47
|
+
throw new FetchError(`Failed to ${method} ${url}: ${response.status} ${response.statusText}`, response);
|
|
48
|
+
}
|
|
49
|
+
const content = await response.json();
|
|
50
|
+
return content;
|
|
51
|
+
}
|
|
52
|
+
async upload(file) {
|
|
53
|
+
const uploadUrl = await this.getUploadUrl();
|
|
54
|
+
const response = await fetch(uploadUrl, {
|
|
55
|
+
method: "PUT",
|
|
56
|
+
body: file,
|
|
57
|
+
headers: this.headers
|
|
58
|
+
});
|
|
59
|
+
if (!response.ok) {
|
|
60
|
+
throw new FetchError(`Error uploading file ${this.name}: ${response.status} ${response.statusText}`, response);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
async download() {
|
|
64
|
+
const downloadUrl = await this.getDownloadUrl();
|
|
65
|
+
const response = await fetch(downloadUrl, {
|
|
66
|
+
method: "GET",
|
|
67
|
+
headers: this.headers
|
|
68
|
+
});
|
|
69
|
+
if (!response.ok) {
|
|
70
|
+
throw new FetchError(`Error downloading file ${this.name}: ${response.status} ${response.statusText}`, response);
|
|
71
|
+
}
|
|
72
|
+
return response.blob();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
var __defProp = Object.defineProperty;
|
|
77
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
78
|
+
var __publicField = (obj, key, value) => {
|
|
79
|
+
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
80
|
+
return value;
|
|
81
|
+
};
|
|
82
|
+
class DataTokenAuthStrategy {
|
|
83
|
+
constructor(dataToken) {
|
|
84
|
+
__publicField(this, "dataToken");
|
|
85
|
+
this.dataToken = dataToken;
|
|
86
|
+
}
|
|
87
|
+
getHeaders() {
|
|
88
|
+
return new Headers({
|
|
89
|
+
"x-data-token": this.dataToken
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
class APIKeyAuthStrategy {
|
|
94
|
+
constructor(apiKey) {
|
|
95
|
+
__publicField(this, "apiKey");
|
|
96
|
+
this.apiKey = apiKey;
|
|
97
|
+
}
|
|
98
|
+
getHeaders() {
|
|
99
|
+
return new Headers({
|
|
100
|
+
Authorization: this.apiKey
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
function useVault(vaultUrl, authStrategy) {
|
|
106
|
+
function createVaultFile(name) {
|
|
107
|
+
return new VaultFile({
|
|
108
|
+
name,
|
|
109
|
+
authStrategy,
|
|
110
|
+
vaultUrl
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
return { createVaultFile };
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
export { APIKeyAuthStrategy, DataTokenAuthStrategy, FetchError, VaultFile, useVault };
|
package/package.json
CHANGED
|
@@ -1,35 +1,41 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@meistrari/vault-sdk",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.3",
|
|
4
|
+
"license": "UNLICENSED",
|
|
4
5
|
"repository": {
|
|
5
6
|
"type": "git",
|
|
6
7
|
"url": "https://github.com/meistrari/vault.git"
|
|
7
8
|
},
|
|
8
9
|
"exports": {
|
|
9
|
-
".":
|
|
10
|
+
".": {
|
|
11
|
+
"types": "./dist/index.d.ts",
|
|
12
|
+
"import": "./dist/index.mjs"
|
|
13
|
+
}
|
|
10
14
|
},
|
|
11
|
-
"main": "dist/index.
|
|
15
|
+
"main": "dist/index.mjs",
|
|
12
16
|
"types": "dist/index.d.ts",
|
|
13
17
|
"files": [
|
|
14
18
|
"dist"
|
|
15
19
|
],
|
|
20
|
+
"scripts": {
|
|
21
|
+
"test": "vitest",
|
|
22
|
+
"build": "unbuild",
|
|
23
|
+
"lint": "eslint .",
|
|
24
|
+
"check": "bun run lint && bun tsc --noEmit"
|
|
25
|
+
},
|
|
16
26
|
"dependencies": {
|
|
17
27
|
"ofetch": "1.4.1",
|
|
18
|
-
"vitest": "
|
|
28
|
+
"vitest": "2.1.8"
|
|
19
29
|
},
|
|
20
30
|
"devDependencies": {
|
|
21
31
|
"@types/bun": "latest",
|
|
22
|
-
"msw": "2.6.8"
|
|
32
|
+
"msw": "2.6.8",
|
|
33
|
+
"unbuild": "2.0.0"
|
|
23
34
|
},
|
|
24
35
|
"peerDependencies": {
|
|
25
36
|
"typescript": "^5.0.0"
|
|
26
37
|
},
|
|
27
38
|
"publishConfig": {
|
|
28
39
|
"access": "public"
|
|
29
|
-
},
|
|
30
|
-
"scripts": {
|
|
31
|
-
"test": "vitest",
|
|
32
|
-
"build": "tsc",
|
|
33
|
-
"lint:ts": "tsc --noEmit"
|
|
34
40
|
}
|
|
35
|
-
}
|
|
41
|
+
}
|