@streamlayer/sdk-web-anonymous-auth 0.2.0 → 0.2.1
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/package.json +1 -1
- package/src/index.d.ts +1 -1
- package/src/index.js +8 -5
- package/src/index.js.map +1 -1
package/package.json
CHANGED
package/src/index.d.ts
CHANGED
|
@@ -4,4 +4,4 @@ declare module '@streamlayer/sdk-web' {
|
|
|
4
4
|
anonymousAuthorization: () => Promise<void>;
|
|
5
5
|
}
|
|
6
6
|
}
|
|
7
|
-
export declare const anonymous: (instance: StreamLayerContext, opts:
|
|
7
|
+
export declare const anonymous: (instance: StreamLayerContext, opts: unknown, done: () => void) => void;
|
package/src/index.js
CHANGED
|
@@ -5,15 +5,18 @@ const anonymousAuth = async (instance, opts)=>{
|
|
|
5
5
|
schemaName: 'slra',
|
|
6
6
|
issuer: 'sdk-web'
|
|
7
7
|
} || opts;
|
|
8
|
-
const organization = await instance.
|
|
9
|
-
|
|
8
|
+
const organization = await instance.stores.organizationSettings.getValue();
|
|
9
|
+
if (!organization) {
|
|
10
|
+
throw new Error('unknown organization');
|
|
11
|
+
}
|
|
12
|
+
const userKey = `${organization.pub?.kid}`;
|
|
10
13
|
const schema = `${schemaName}:${organization.id}`;
|
|
11
|
-
const anonymous = await queries.bypassAuth(instance.
|
|
14
|
+
const anonymous = await queries.bypassAuth(instance.transport, {
|
|
12
15
|
userKey,
|
|
13
16
|
schema,
|
|
14
17
|
init: true
|
|
15
18
|
});
|
|
16
|
-
const token = anonymous.meta
|
|
19
|
+
const token = anonymous.meta?.token;
|
|
17
20
|
const pubKey = organization.pub;
|
|
18
21
|
const pub = await importJWK({
|
|
19
22
|
...pubKey
|
|
@@ -23,7 +26,7 @@ const anonymousAuth = async (instance, opts)=>{
|
|
|
23
26
|
['device-id']: deviceId,
|
|
24
27
|
totp: token
|
|
25
28
|
}).setProtectedHeader({
|
|
26
|
-
alg: pubKey.alg,
|
|
29
|
+
alg: pubKey.alg || '',
|
|
27
30
|
enc: 'A256CBC-HS512',
|
|
28
31
|
kid: pubKey.kid
|
|
29
32
|
}).setIssuedAt().setIssuer(issuer).setAudience(organization.id).setExpirationTime('2m').encrypt(pub);
|
package/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../../packages/sdk-web-anonymous-auth/src/index.ts"],"sourcesContent":["import { StreamLayerContext } from '@streamlayer/sdk-web'\nimport { queries } from '@streamlayer/sdk-web-api'\n\nimport { importJWK, JWK, EncryptJWT } from 'jose'\n\ndeclare module '@streamlayer/sdk-web' {\n interface StreamLayerSDK {\n anonymousAuthorization: () => Promise<void>\n }\n}\n\nconst anonymousAuth = async (instance: StreamLayerContext, opts) => {\n const { schemaName, issuer } =\n {\n schemaName: 'slra',\n issuer: 'sdk-web',\n } || opts\n\n const organization = await instance.
|
|
1
|
+
{"version":3,"sources":["../../../../packages/sdk-web-anonymous-auth/src/index.ts"],"sourcesContent":["import { StreamLayerContext } from '@streamlayer/sdk-web'\nimport { queries } from '@streamlayer/sdk-web-api'\n\nimport { importJWK, JWK, EncryptJWT } from 'jose'\n\ndeclare module '@streamlayer/sdk-web' {\n interface StreamLayerSDK {\n anonymousAuthorization: () => Promise<void>\n }\n}\n\nconst anonymousAuth = async (instance: StreamLayerContext, opts: unknown) => {\n const { schemaName, issuer } =\n {\n schemaName: 'slra',\n issuer: 'sdk-web',\n } || opts\n\n const organization = await instance.stores.organizationSettings.getValue()\n\n if (!organization) {\n throw new Error('unknown organization')\n }\n\n const userKey = `${organization.pub?.kid}`\n const schema = `${schemaName}:${organization.id}`\n\n const anonymous = await queries.bypassAuth(instance.transport, { userKey, schema, init: true })\n const token = anonymous.meta?.token\n\n const pubKey = organization.pub as unknown as JWK\n\n const pub = await importJWK({ ...pubKey })\n\n const deviceId = window.crypto.randomUUID()\n const jwe = await new EncryptJWT({ ['device-id']: deviceId, totp: token })\n .setProtectedHeader({ alg: pubKey.alg || '', enc: 'A256CBC-HS512', kid: pubKey.kid })\n .setIssuedAt()\n .setIssuer(issuer)\n .setAudience(organization.id)\n .setExpirationTime('2m')\n .encrypt(pub)\n\n return instance.sdk.authorizationBypass(schema, jwe)\n}\n\nexport const anonymous = (instance: StreamLayerContext, opts: unknown, done: () => void) => {\n instance.sdk.anonymousAuthorization = async () => {\n await anonymousAuth(instance, opts)\n }\n\n done()\n}\n"],"names":["queries","importJWK","EncryptJWT","anonymousAuth","instance","opts","schemaName","issuer","organization","stores","organizationSettings","getValue","Error","userKey","pub","kid","schema","id","anonymous","bypassAuth","transport","init","token","meta","pubKey","deviceId","window","crypto","randomUUID","jwe","totp","setProtectedHeader","alg","enc","setIssuedAt","setIssuer","setAudience","setExpirationTime","encrypt","sdk","authorizationBypass","done","anonymousAuthorization"],"mappings":"AACA,SAASA,OAAO,QAAQ,2BAA0B;AAElD,SAASC,SAAS,EAAOC,UAAU,QAAQ,OAAM;AAQjD,MAAMC,gBAAgB,OAAOC,UAA8BC;IACzD,MAAM,EAAEC,UAAU,EAAEC,MAAM,EAAE,GAC1B;QACED,YAAY;QACZC,QAAQ;IACV,KAAKF;IAEP,MAAMG,eAAe,MAAMJ,SAASK,MAAM,CAACC,oBAAoB,CAACC,QAAQ;IAExE,IAAI,CAACH,cAAc;QACjB,MAAM,IAAII,MAAM;IAClB;IAEA,MAAMC,UAAU,CAAC,EAAEL,aAAaM,GAAG,EAAEC,IAAI,CAAC;IAC1C,MAAMC,SAAS,CAAC,EAAEV,WAAW,CAAC,EAAEE,aAAaS,EAAE,CAAC,CAAC;IAEjD,MAAMC,YAAY,MAAMlB,QAAQmB,UAAU,CAACf,SAASgB,SAAS,EAAE;QAAEP;QAASG;QAAQK,MAAM;IAAK;IAC7F,MAAMC,QAAQJ,UAAUK,IAAI,EAAED;IAE9B,MAAME,SAAShB,aAAaM,GAAG;IAE/B,MAAMA,MAAM,MAAMb,UAAU;QAAE,GAAGuB,MAAM;IAAC;IAExC,MAAMC,WAAWC,OAAOC,MAAM,CAACC,UAAU;IACzC,MAAMC,MAAM,MAAM,IAAI3B,WAAW;QAAE,CAAC,YAAY,EAAEuB;QAAUK,MAAMR;IAAM,GACrES,kBAAkB,CAAC;QAAEC,KAAKR,OAAOQ,GAAG,IAAI;QAAIC,KAAK;QAAiBlB,KAAKS,OAAOT,GAAG;IAAC,GAClFmB,WAAW,GACXC,SAAS,CAAC5B,QACV6B,WAAW,CAAC5B,aAAaS,EAAE,EAC3BoB,iBAAiB,CAAC,MAClBC,OAAO,CAACxB;IAEX,OAAOV,SAASmC,GAAG,CAACC,mBAAmB,CAACxB,QAAQa;AAClD;AAEA,OAAO,MAAMX,YAAY,CAACd,UAA8BC,MAAeoC;IACrErC,SAASmC,GAAG,CAACG,sBAAsB,GAAG;QACpC,MAAMvC,cAAcC,UAAUC;IAChC;IAEAoC;AACF,EAAC"}
|