@meistrari/vault-sdk 0.0.1 → 0.0.2
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/authStrategies.d.ts +13 -0
- package/dist/authStrategies.js +23 -0
- package/dist/authStrategies.js.map +1 -0
- package/dist/errors/fetchError.d.ts +4 -0
- package/dist/errors/fetchError.js +9 -0
- package/dist/errors/fetchError.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.js +15 -0
- package/dist/index.js.map +1 -0
- package/dist/vault-file.d.ts +24 -0
- package/dist/vault-file.js +62 -0
- package/dist/vault-file.js.map +1 -0
- package/package.json +1 -1
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface AuthStrategy {
|
|
2
|
+
getHeaders: () => Headers;
|
|
3
|
+
}
|
|
4
|
+
export declare class DataTokenAuthStrategy implements AuthStrategy {
|
|
5
|
+
dataToken: string;
|
|
6
|
+
getHeaders(): Headers;
|
|
7
|
+
constructor(dataToken: string);
|
|
8
|
+
}
|
|
9
|
+
export declare class APIKeyAuthStrategy implements AuthStrategy {
|
|
10
|
+
apiKey: string;
|
|
11
|
+
getHeaders(): Headers;
|
|
12
|
+
constructor(apiKey: string);
|
|
13
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export class DataTokenAuthStrategy {
|
|
2
|
+
dataToken;
|
|
3
|
+
getHeaders() {
|
|
4
|
+
return new Headers({
|
|
5
|
+
'x-data-token': this.dataToken,
|
|
6
|
+
});
|
|
7
|
+
}
|
|
8
|
+
constructor(dataToken) {
|
|
9
|
+
this.dataToken = dataToken;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
export class APIKeyAuthStrategy {
|
|
13
|
+
apiKey;
|
|
14
|
+
getHeaders() {
|
|
15
|
+
return new Headers({
|
|
16
|
+
Authorization: this.apiKey,
|
|
17
|
+
});
|
|
18
|
+
}
|
|
19
|
+
constructor(apiKey) {
|
|
20
|
+
this.apiKey = apiKey;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=authStrategies.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authStrategies.js","sourceRoot":"","sources":["../src/authStrategies.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,qBAAqB;IAC9B,SAAS,CAAQ;IAEjB,UAAU;QACN,OAAO,IAAI,OAAO,CAAC;YACf,cAAc,EAAE,IAAI,CAAC,SAAS;SACjC,CAAC,CAAA;IACN,CAAC;IAED,YAAY,SAAiB;QACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA;IAC9B,CAAC;CACJ;AAED,MAAM,OAAO,kBAAkB;IAC3B,MAAM,CAAQ;IAEd,UAAU;QACN,OAAO,IAAI,OAAO,CAAC;YACf,aAAa,EAAE,IAAI,CAAC,MAAM;SAC7B,CAAC,CAAA;IACN,CAAC;IAED,YAAY,MAAc;QACtB,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACxB,CAAC;CACJ"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fetchError.js","sourceRoot":"","sources":["../../src/errors/fetchError.ts"],"names":[],"mappings":"AAAA,MAAM,OAAO,UAAW,SAAQ,KAAK;IACY;IAA7C,YAAY,OAAe,EAAkB,QAAkB;QAC3D,KAAK,CAAC,OAAO,CAAC,CAAA;QAD2B,aAAQ,GAAR,QAAQ,CAAU;QAE3D,IAAI,CAAC,IAAI,GAAG,YAAY,CAAA;IAC5B,CAAC;CACJ"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { AuthStrategy } from './authStrategies';
|
|
2
|
+
import { VaultFile } from './vault-file';
|
|
3
|
+
import { DataTokenAuthStrategy, APIKeyAuthStrategy } from './authStrategies';
|
|
4
|
+
import { FetchError } from './errors/fetchError';
|
|
5
|
+
export declare function useVault(vaultUrl: string, authStrategy: AuthStrategy): {
|
|
6
|
+
createVaultFile: (name: string) => VaultFile;
|
|
7
|
+
};
|
|
8
|
+
export type { AuthStrategy };
|
|
9
|
+
export { APIKeyAuthStrategy, DataTokenAuthStrategy, FetchError, VaultFile };
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { VaultFile } from './vault-file';
|
|
2
|
+
import { DataTokenAuthStrategy, APIKeyAuthStrategy } from './authStrategies';
|
|
3
|
+
import { FetchError } from './errors/fetchError';
|
|
4
|
+
export function useVault(vaultUrl, authStrategy) {
|
|
5
|
+
function createVaultFile(name) {
|
|
6
|
+
return new VaultFile({
|
|
7
|
+
name,
|
|
8
|
+
authStrategy,
|
|
9
|
+
vaultUrl,
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
return { createVaultFile };
|
|
13
|
+
}
|
|
14
|
+
export { APIKeyAuthStrategy, DataTokenAuthStrategy, FetchError, VaultFile };
|
|
15
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAA;AACxC,OAAO,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,kBAAkB,CAAA;AAC5E,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAA;AAEhD,MAAM,UAAU,QAAQ,CAAC,QAAgB,EAAE,YAA0B;IACjE,SAAS,eAAe,CAAC,IAAY;QACjC,OAAO,IAAI,SAAS,CAAC;YACjB,IAAI;YACJ,YAAY;YACZ,QAAQ;SACX,CAAC,CAAA;IACN,CAAC;IAED,OAAO,EAAE,eAAe,EAAE,CAAA;AAC9B,CAAC;AAGD,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,UAAU,EAAE,SAAS,EAAE,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { AuthStrategy } from './authStrategies';
|
|
2
|
+
type FetchParams = {
|
|
3
|
+
method: 'GET' | 'POST' | 'PUT';
|
|
4
|
+
path: string | URL;
|
|
5
|
+
body?: any;
|
|
6
|
+
ignoreHeaders?: boolean;
|
|
7
|
+
};
|
|
8
|
+
type VaultParams = {
|
|
9
|
+
name: string;
|
|
10
|
+
authStrategy: AuthStrategy;
|
|
11
|
+
vaultUrl: string;
|
|
12
|
+
};
|
|
13
|
+
export declare class VaultFile {
|
|
14
|
+
readonly name: string;
|
|
15
|
+
readonly vaultUrl: string;
|
|
16
|
+
readonly headers: Headers;
|
|
17
|
+
constructor(params: VaultParams);
|
|
18
|
+
getUploadUrl(): Promise<any>;
|
|
19
|
+
getDownloadUrl(): Promise<URL>;
|
|
20
|
+
_fetch(params: FetchParams): Promise<any>;
|
|
21
|
+
upload(file: Blob): Promise<void>;
|
|
22
|
+
download(): Promise<Blob>;
|
|
23
|
+
}
|
|
24
|
+
export {};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { FetchError } from './errors/fetchError';
|
|
2
|
+
export class VaultFile {
|
|
3
|
+
name;
|
|
4
|
+
vaultUrl;
|
|
5
|
+
headers;
|
|
6
|
+
constructor(params) {
|
|
7
|
+
this.name = params.name;
|
|
8
|
+
this.vaultUrl = params.vaultUrl;
|
|
9
|
+
this.headers = params.authStrategy.getHeaders();
|
|
10
|
+
}
|
|
11
|
+
async getUploadUrl() {
|
|
12
|
+
const response = await this._fetch({
|
|
13
|
+
method: 'POST',
|
|
14
|
+
path: `/files/${this.name}`,
|
|
15
|
+
});
|
|
16
|
+
return response.url;
|
|
17
|
+
}
|
|
18
|
+
async getDownloadUrl() {
|
|
19
|
+
const response = await this._fetch({
|
|
20
|
+
method: 'GET',
|
|
21
|
+
path: `/files/${this.name}`,
|
|
22
|
+
});
|
|
23
|
+
return new URL(response.url);
|
|
24
|
+
}
|
|
25
|
+
async _fetch(params) {
|
|
26
|
+
const { method, path, body, ignoreHeaders } = params;
|
|
27
|
+
const url = path instanceof URL ? path.toString() : new URL(path, this.vaultUrl).toString();
|
|
28
|
+
const response = await fetch(url, {
|
|
29
|
+
method,
|
|
30
|
+
body,
|
|
31
|
+
headers: ignoreHeaders ? undefined : this.headers,
|
|
32
|
+
});
|
|
33
|
+
if (!response.ok) {
|
|
34
|
+
throw new FetchError(`Failed to ${method} ${url}: ${response.status} ${response.statusText}`, response);
|
|
35
|
+
}
|
|
36
|
+
const content = await response.json();
|
|
37
|
+
return content;
|
|
38
|
+
}
|
|
39
|
+
async upload(file) {
|
|
40
|
+
const uploadUrl = await this.getUploadUrl();
|
|
41
|
+
const response = await fetch(uploadUrl, {
|
|
42
|
+
method: 'PUT',
|
|
43
|
+
body: file,
|
|
44
|
+
headers: this.headers,
|
|
45
|
+
});
|
|
46
|
+
if (!response.ok) {
|
|
47
|
+
throw new FetchError(`Error uploading file ${this.name}: ${response.status} ${response.statusText}`, response);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
async download() {
|
|
51
|
+
const downloadUrl = await this.getDownloadUrl();
|
|
52
|
+
const response = await fetch(downloadUrl, {
|
|
53
|
+
method: 'GET',
|
|
54
|
+
headers: this.headers,
|
|
55
|
+
});
|
|
56
|
+
if (!response.ok) {
|
|
57
|
+
throw new FetchError(`Error downloading file ${this.name}: ${response.status} ${response.statusText}`, response);
|
|
58
|
+
}
|
|
59
|
+
return response.blob();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=vault-file.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"vault-file.js","sourceRoot":"","sources":["../src/vault-file.ts"],"names":[],"mappings":"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"}
|