@opentdf/sdk 0.4.0-beta.19 → 0.4.0-beta.4
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/cjs/src/access.js +1 -16
- package/dist/cjs/src/auth/oidc-refreshtoken-provider.js +1 -15
- package/dist/cjs/src/index.js +2 -4
- package/dist/cjs/src/opentdf.js +12 -64
- package/dist/cjs/src/platform.js +3 -14
- package/dist/cjs/src/seekable.js +1 -32
- package/dist/cjs/src/utils.js +3 -57
- package/dist/types/src/access.d.ts +0 -15
- package/dist/types/src/access.d.ts.map +1 -1
- package/dist/types/src/auth/oidc-refreshtoken-provider.d.ts +0 -14
- package/dist/types/src/auth/oidc-refreshtoken-provider.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +0 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/opentdf.d.ts +6 -126
- package/dist/types/src/opentdf.d.ts.map +1 -1
- package/dist/types/src/platform.d.ts +0 -16
- package/dist/types/src/platform.d.ts.map +1 -1
- package/dist/types/src/seekable.d.ts +0 -31
- package/dist/types/src/seekable.d.ts.map +1 -1
- package/dist/types/src/utils.d.ts +2 -56
- package/dist/types/src/utils.d.ts.map +1 -1
- package/dist/web/src/access.js +1 -16
- package/dist/web/src/auth/oidc-refreshtoken-provider.js +1 -15
- package/dist/web/src/index.js +1 -2
- package/dist/web/src/opentdf.js +12 -64
- package/dist/web/src/platform.js +3 -14
- package/dist/web/src/seekable.js +1 -32
- package/dist/web/src/utils.js +3 -57
- package/package.json +3 -5
- package/src/access.ts +0 -15
- package/src/auth/oidc-refreshtoken-provider.ts +0 -14
- package/src/index.ts +0 -1
- package/src/opentdf.ts +71 -147
- package/src/platform.ts +5 -17
- package/src/seekable.ts +0 -31
- package/src/utils.ts +2 -56
package/dist/web/src/utils.js
CHANGED
|
@@ -32,32 +32,15 @@ export function validateSecureUrl(url) {
|
|
|
32
32
|
}
|
|
33
33
|
return true;
|
|
34
34
|
}
|
|
35
|
-
/**
|
|
36
|
-
* Pads a URL with a trailing slash if it does not already have one.
|
|
37
|
-
* This is useful for ensuring that URLs are in a consistent format.
|
|
38
|
-
* @param u The URL to pad.
|
|
39
|
-
* @returns The padded URL.
|
|
40
|
-
*/
|
|
41
35
|
export function padSlashToUrl(u) {
|
|
42
36
|
if (u.endsWith('/')) {
|
|
43
37
|
return u;
|
|
44
38
|
}
|
|
45
39
|
return `${u}/`;
|
|
46
40
|
}
|
|
47
|
-
/**
|
|
48
|
-
* Checks if the current environment is a browser.
|
|
49
|
-
* This is useful for determining if certain APIs or features are available.
|
|
50
|
-
* @returns true if running in a browser, false otherwise.
|
|
51
|
-
*/
|
|
52
41
|
export function isBrowser() {
|
|
53
42
|
return typeof window !== 'undefined'; // eslint-disable-line
|
|
54
43
|
}
|
|
55
|
-
/**
|
|
56
|
-
* Removes trailing characters from a string.
|
|
57
|
-
* @param str The string to trim.
|
|
58
|
-
* @param suffix The suffix to remove (default is a single space).
|
|
59
|
-
* @returns The trimmed string.
|
|
60
|
-
*/
|
|
61
44
|
export const rstrip = (str, suffix = ' ') => {
|
|
62
45
|
while (str && suffix && str.endsWith(suffix)) {
|
|
63
46
|
str = str.slice(0, -suffix.length);
|
|
@@ -98,15 +81,6 @@ export const estimateSkewFromHeaders = (headers, dateNowBefore) => {
|
|
|
98
81
|
const deltaAfter = serverUnixTime - localUnixTimeAfter;
|
|
99
82
|
return Math.round((deltaBefore + deltaAfter) / 2);
|
|
100
83
|
};
|
|
101
|
-
/**
|
|
102
|
-
* Adds new lines to a string every 64 characters.
|
|
103
|
-
* @param str A string to add new lines to.
|
|
104
|
-
* This function takes a string and adds new lines every 64 characters.
|
|
105
|
-
* If the string is empty or undefined, it returns the original string.
|
|
106
|
-
* This is useful for formatting long strings, such as public keys or certificates,
|
|
107
|
-
* to ensure they are properly formatted for PEM encoding.
|
|
108
|
-
* @returns The formatted string with new lines added.
|
|
109
|
-
*/
|
|
110
84
|
export function addNewLines(str) {
|
|
111
85
|
if (!str) {
|
|
112
86
|
return str;
|
|
@@ -119,11 +93,6 @@ export function addNewLines(str) {
|
|
|
119
93
|
}
|
|
120
94
|
return finalString;
|
|
121
95
|
}
|
|
122
|
-
/**
|
|
123
|
-
* Creates a PEM-encoded string from a public key.
|
|
124
|
-
* @param publicKey The public key to convert.
|
|
125
|
-
* @returns A promise that resolves to a PEM-encoded string.
|
|
126
|
-
*/
|
|
127
96
|
export async function cryptoPublicToPem(publicKey) {
|
|
128
97
|
if (publicKey.type !== 'public') {
|
|
129
98
|
throw new ConfigurationError('incorrect key type');
|
|
@@ -133,11 +102,6 @@ export async function cryptoPublicToPem(publicKey) {
|
|
|
133
102
|
const pem = addNewLines(b64);
|
|
134
103
|
return `-----BEGIN PUBLIC KEY-----\r\n${pem}-----END PUBLIC KEY-----`;
|
|
135
104
|
}
|
|
136
|
-
/**
|
|
137
|
-
* Converts a PEM-encoded public key to a CryptoKey.
|
|
138
|
-
* @param pem The PEM-encoded public key.
|
|
139
|
-
* @returns A promise that resolves to a CryptoKey.
|
|
140
|
-
*/
|
|
141
105
|
export async function pemToCryptoPublicKey(pem) {
|
|
142
106
|
if (/-----BEGIN PUBLIC KEY-----/.test(pem)) {
|
|
143
107
|
return pemPublicToCrypto(pem);
|
|
@@ -150,15 +114,6 @@ export async function pemToCryptoPublicKey(pem) {
|
|
|
150
114
|
// - When converting between PEM and CryptoKey formats for user provided session keys (e.g. for DPoP)
|
|
151
115
|
throw new TypeError(`unsupported pem type [${pem}]`);
|
|
152
116
|
}
|
|
153
|
-
/**
|
|
154
|
-
* Extracts the PEM-encoded public key from a key string.
|
|
155
|
-
* @param keyString A string containing a public key or certificate.
|
|
156
|
-
* This function extracts the PEM-encoded public key from a given key string.
|
|
157
|
-
* If the key string contains a certificate, it imports the certificate and exports
|
|
158
|
-
* the public key in PEM format. If the key string is already in PEM format, it returns
|
|
159
|
-
* the key string as is.
|
|
160
|
-
* @returns A promise that resolves to a PEM-encoded public key.
|
|
161
|
-
*/
|
|
162
117
|
export async function extractPemFromKeyString(keyString) {
|
|
163
118
|
let pem = keyString;
|
|
164
119
|
// Skip the public key extraction if we find that the KAS url provides a
|
|
@@ -171,12 +126,6 @@ export async function extractPemFromKeyString(keyString) {
|
|
|
171
126
|
}
|
|
172
127
|
/**
|
|
173
128
|
* Extracts the error message from an RPC catch error.
|
|
174
|
-
* @param error An error object, typically from a network request.
|
|
175
|
-
* This function extracts the error message from a ConnectError or a generic Error.
|
|
176
|
-
* If the error is a ConnectError or a standard Error, it returns the message.
|
|
177
|
-
* If the error is of an unknown type, it returns a default message indicating
|
|
178
|
-
* that an unknown network error occurred.
|
|
179
|
-
* @returns The extracted error message.
|
|
180
129
|
*/
|
|
181
130
|
export function extractRpcErrorMessage(error) {
|
|
182
131
|
if (error instanceof ConnectError || error instanceof Error) {
|
|
@@ -186,11 +135,8 @@ export function extractRpcErrorMessage(error) {
|
|
|
186
135
|
}
|
|
187
136
|
/**
|
|
188
137
|
* Converts a KAS endpoint URL to a platform URL.
|
|
189
|
-
*
|
|
190
|
-
*
|
|
191
|
-
* It removes any trailing slashes and specific path segments related to rewrap or kas.
|
|
192
|
-
* This is useful for obtaining the base URL for further API requests.
|
|
193
|
-
* @returns The base URL of the platform.
|
|
138
|
+
* If the KAS endpoint ends with '/kas', it returns the host url
|
|
139
|
+
* Otherwise, it returns the original KAS endpoint.
|
|
194
140
|
*/
|
|
195
141
|
export function getPlatformUrlFromKasEndpoint(endpoint) {
|
|
196
142
|
let result = endpoint || '';
|
|
@@ -205,4 +151,4 @@ export function getPlatformUrlFromKasEndpoint(endpoint) {
|
|
|
205
151
|
}
|
|
206
152
|
return result;
|
|
207
153
|
}
|
|
208
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFOUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxlQUFlLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMzRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRW5EOzs7Ozs7Ozs7Ozs7O0dBYUc7QUFDSCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsR0FBVztJQUMzQyxNQUFNLFVBQVUsR0FBRyxTQUFTLENBQUM7SUFDN0IsSUFBSSx3REFBd0QsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUN2RSxPQUFPLENBQUMsSUFBSSxDQUFDLDhCQUE4QixHQUFHLEdBQUcsQ0FBQyxDQUFDO0lBQ3JELENBQUM7U0FBTSxJQUNMLHNEQUFzRCxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUM7UUFDaEUseURBQXlELENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUNuRSxDQUFDO1FBQ0QsT0FBTyxDQUFDLElBQUksQ0FBQywyQkFBMkIsR0FBRyxHQUFHLENBQUMsQ0FBQztJQUNsRCxDQUFDO1NBQU0sSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUNqQyxPQUFPLENBQUMsS0FBSyxDQUFDLHNFQUFzRSxHQUFHLEdBQUcsQ0FBQyxDQUFDO1FBQzVGLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUNELE9BQU8sSUFBSSxDQUFDO0FBQ2QsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhLENBQUMsQ0FBUztJQUNy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
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@opentdf/sdk",
|
|
3
|
-
"version": "0.4.0-beta.
|
|
3
|
+
"version": "0.4.0-beta.4",
|
|
4
4
|
"description": "OpenTDF for the Web",
|
|
5
5
|
"homepage": "https://github.com/opentdf/web-sdk",
|
|
6
6
|
"bugs": {
|
|
@@ -69,8 +69,7 @@
|
|
|
69
69
|
"build:watch": "tsc --watch",
|
|
70
70
|
"clean": "rm -rf {build,coverage,dist,tests/mocha/dist}",
|
|
71
71
|
"coverage:merge": "for x in mocha wtr; do cp coverage/$x/coverage-final.json coverage/$x.json; done; nyc report --reporter text --reporter lcov -t coverage --lines 75 --statements 75 --branches 70 --functions 65 --check-coverage >coverage/coverage.txt",
|
|
72
|
-
"doc": "typedoc --out dist/docs src/index.ts
|
|
73
|
-
"doc:md": "typedoc --plugin typedoc-plugin-markdown --out dist/docs-md src/index.ts",
|
|
72
|
+
"doc": "typedoc --out dist/docs src/index.ts",
|
|
74
73
|
"format": "prettier --write \"{src,tdf3,tests}/**/*.ts\"",
|
|
75
74
|
"license-check": "license-checker-rseidelsohn --production --onlyAllow 'Apache-2.0; BSD; CC-BY-4.0; ISC; MIT'",
|
|
76
75
|
"lint": "eslint ./src/**/*.ts ./tdf3/**/*.ts ./tests/**/*.ts",
|
|
@@ -134,8 +133,7 @@
|
|
|
134
133
|
"process": "^0.11.10",
|
|
135
134
|
"sinon": "~19.0.2",
|
|
136
135
|
"tsconfig-paths": "^4.2.0",
|
|
137
|
-
"typedoc": "^0.
|
|
138
|
-
"typedoc-plugin-markdown": "^4.7.0",
|
|
136
|
+
"typedoc": "^0.27.9",
|
|
139
137
|
"typescript": "^5.8.2",
|
|
140
138
|
"typescript-eslint": "^8.26.0",
|
|
141
139
|
"webpack": "^5.98.0",
|
package/src/access.ts
CHANGED
|
@@ -136,12 +136,6 @@ export async function noteInvalidPublicKey(url: URL, r: Promise<CryptoKey>): Pro
|
|
|
136
136
|
}
|
|
137
137
|
}
|
|
138
138
|
|
|
139
|
-
/**
|
|
140
|
-
* Fetches the key access servers for a given platform URL.
|
|
141
|
-
* @param platformUrl The platform URL to fetch key access servers for.
|
|
142
|
-
* @param authProvider The authentication provider to use for the request.
|
|
143
|
-
* @returns A promise that resolves to an OriginAllowList.
|
|
144
|
-
*/
|
|
145
139
|
export async function fetchKeyAccessServers(
|
|
146
140
|
platformUrl: string,
|
|
147
141
|
authProvider: AuthProvider
|
|
@@ -196,15 +190,6 @@ const origin = (u: string): string => {
|
|
|
196
190
|
}
|
|
197
191
|
};
|
|
198
192
|
|
|
199
|
-
/**
|
|
200
|
-
* Manages a list of origins that are allowed to access the Key Access Server (KAS).
|
|
201
|
-
* @origins A list of origins that are allowed to access the KAS.
|
|
202
|
-
* @allowAll If true, all origins are allowed to access the KAS.
|
|
203
|
-
* If false, only the origins in the list are allowed to access the KAS.
|
|
204
|
-
* @description This class is used to manage a list of origins that are allowed to access the KAS.
|
|
205
|
-
* It validates the URLs and provides a method to check if a given URL is allowed.
|
|
206
|
-
* It is used to ensure that only authorized origins can access the KAS.
|
|
207
|
-
*/
|
|
208
193
|
export class OriginAllowList {
|
|
209
194
|
origins: string[];
|
|
210
195
|
allowAll: boolean;
|
|
@@ -2,20 +2,6 @@ import { ConfigurationError } from '../errors.js';
|
|
|
2
2
|
import { type AuthProvider, type HttpRequest } from './auth.js';
|
|
3
3
|
import { AccessToken, type RefreshTokenCredentials } from './oidc.js';
|
|
4
4
|
|
|
5
|
-
/**
|
|
6
|
-
* An AuthProvider that uses an OIDC refresh token to obtain an access token.
|
|
7
|
-
* It exchanges the refresh token for an access token and uses that to augment HTTP requests with credentials.
|
|
8
|
-
* @example
|
|
9
|
-
* ```ts
|
|
10
|
-
* import { OIDCRefreshTokenProvider } from '@opentdf/sdk';
|
|
11
|
-
* await AuthProviders.refreshAuthProvider({
|
|
12
|
-
clientId: 'my-client-id',
|
|
13
|
-
exchange: 'refresh',
|
|
14
|
-
refreshToken: 'refresh-token-from-oidc-provider',
|
|
15
|
-
oidcOrigin: 'https://example.oidc.provider.com',
|
|
16
|
-
});
|
|
17
|
-
```
|
|
18
|
-
*/
|
|
19
5
|
export class OIDCRefreshTokenProvider implements AuthProvider {
|
|
20
6
|
oidcAuth: AccessToken;
|
|
21
7
|
refreshToken?: string;
|
package/src/index.ts
CHANGED
|
@@ -2,7 +2,6 @@ export { type AuthProvider, type HttpMethod, HttpRequest, withHeaders } from './
|
|
|
2
2
|
export * as AuthProviders from './auth/providers.js';
|
|
3
3
|
export { attributeFQNsAsValues } from './policy/api.js';
|
|
4
4
|
export { version, clientType, tdfSpecVersion } from './version.js';
|
|
5
|
-
export { PlatformClient, type PlatformClientOptions, type PlatformServices } from './platform.js';
|
|
6
5
|
export * from './opentdf.js';
|
|
7
6
|
export * from './seekable.js';
|
|
8
7
|
export * from '../tdf3/src/models/index.js';
|