@atcute/oauth-browser-client 2.0.0-next.0 → 2.0.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/README.md +125 -16
- package/dist/agents/exchange.d.ts +10 -2
- package/dist/agents/exchange.d.ts.map +1 -0
- package/dist/agents/exchange.js +23 -17
- package/dist/agents/exchange.js.map +1 -1
- package/dist/agents/server-agent.d.ts +1 -0
- package/dist/agents/server-agent.d.ts.map +1 -0
- package/dist/agents/server-agent.js +21 -3
- package/dist/agents/server-agent.js.map +1 -1
- package/dist/agents/sessions.d.ts +1 -0
- package/dist/agents/sessions.d.ts.map +1 -0
- package/dist/agents/user-agent.d.ts +1 -0
- package/dist/agents/user-agent.d.ts.map +1 -0
- package/dist/constants.d.ts +1 -0
- package/dist/constants.d.ts.map +1 -0
- package/dist/dpop.d.ts +1 -0
- package/dist/dpop.d.ts.map +1 -0
- package/dist/dpop.js +3 -0
- package/dist/dpop.js.map +1 -1
- package/dist/environment.d.ts +11 -7
- package/dist/environment.d.ts.map +1 -0
- package/dist/environment.js +3 -3
- package/dist/environment.js.map +1 -1
- package/dist/errors.d.ts +1 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/resolvers.d.ts +3 -2
- package/dist/resolvers.d.ts.map +1 -0
- package/dist/resolvers.js +4 -22
- package/dist/resolvers.js.map +1 -1
- package/dist/store/db.d.ts +2 -0
- package/dist/store/db.d.ts.map +1 -0
- package/dist/store/db.js.map +1 -1
- package/dist/types/client-assertion.d.ts +21 -0
- package/dist/types/client-assertion.d.ts.map +1 -0
- package/dist/types/client-assertion.js +3 -0
- package/dist/types/client-assertion.js.map +1 -0
- package/dist/types/client.d.ts +1 -0
- package/dist/types/client.d.ts.map +1 -0
- package/dist/types/dpop.d.ts +3 -0
- package/dist/types/dpop.d.ts.map +1 -0
- package/dist/types/identity.d.ts +13 -5
- package/dist/types/identity.d.ts.map +1 -0
- package/dist/types/par.d.ts +1 -0
- package/dist/types/par.d.ts.map +1 -0
- package/dist/types/server.d.ts +1 -0
- package/dist/types/server.d.ts.map +1 -0
- package/dist/types/store.d.ts +1 -0
- package/dist/types/store.d.ts.map +1 -0
- package/dist/types/token.d.ts +1 -0
- package/dist/types/token.d.ts.map +1 -0
- package/dist/utils/identity-resolver.d.ts +8 -0
- package/dist/utils/identity-resolver.d.ts.map +1 -0
- package/dist/utils/identity-resolver.js +44 -0
- package/dist/utils/identity-resolver.js.map +1 -0
- package/dist/utils/misc.d.ts +1 -0
- package/dist/utils/misc.d.ts.map +1 -0
- package/dist/utils/response.d.ts +1 -0
- package/dist/utils/response.d.ts.map +1 -0
- package/dist/utils/runtime.d.ts +1 -0
- package/dist/utils/runtime.d.ts.map +1 -0
- package/dist/utils/strings.d.ts +1 -0
- package/dist/utils/strings.d.ts.map +1 -0
- package/lib/agents/exchange.ts +32 -20
- package/lib/agents/server-agent.ts +26 -3
- package/lib/dpop.ts +4 -0
- package/lib/environment.ts +14 -9
- package/lib/index.ts +3 -0
- package/lib/resolvers.ts +7 -26
- package/lib/store/db.ts +1 -0
- package/lib/types/client-assertion.ts +25 -0
- package/lib/types/dpop.ts +2 -0
- package/lib/types/identity.ts +14 -5
- package/lib/utils/identity-resolver.ts +59 -0
- package/package.json +8 -8
package/lib/store/db.ts
CHANGED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
const CLIENT_ASSERTION_TYPE_JWT_BEARER = 'urn:ietf:params:oauth:client-assertion-type:jwt-bearer';
|
|
2
|
+
|
|
3
|
+
export interface ClientAssertionCredentials {
|
|
4
|
+
client_assertion: string;
|
|
5
|
+
client_assertion_type: typeof CLIENT_ASSERTION_TYPE_JWT_BEARER;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export interface FetchClientAssertionParams {
|
|
9
|
+
/** JWK thumbprint of the DPoP key to bind the assertion to */
|
|
10
|
+
jkt: string;
|
|
11
|
+
/** authorization server issuer (audience for the assertion) */
|
|
12
|
+
aud: string;
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* create a DPoP proof to prove you possess the key for the claimed jkt.
|
|
16
|
+
*
|
|
17
|
+
* @param htu origin and pathname to your backend
|
|
18
|
+
* @returns DPoP proof that can be included in the assertion
|
|
19
|
+
*/
|
|
20
|
+
createDpopProof: (htu: string) => Promise<string>;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export type ClientAssertionFetcher = (
|
|
24
|
+
params: FetchClientAssertionParams,
|
|
25
|
+
) => Promise<ClientAssertionCredentials>;
|
package/lib/types/dpop.ts
CHANGED
package/lib/types/identity.ts
CHANGED
|
@@ -1,7 +1,16 @@
|
|
|
1
|
-
import type { Did } from '@atcute/lexicons';
|
|
1
|
+
import type { ActorIdentifier, Did, Handle } from '@atcute/lexicons';
|
|
2
2
|
|
|
3
|
-
export interface
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
pds:
|
|
3
|
+
export interface ResolvedIdentity {
|
|
4
|
+
did: Did;
|
|
5
|
+
handle: Handle;
|
|
6
|
+
pds: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export interface ResolveIdentityOptions {
|
|
10
|
+
signal?: AbortSignal;
|
|
11
|
+
noCache?: boolean;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export interface IdentityResolver {
|
|
15
|
+
resolve(actor: ActorIdentifier, options?: ResolveIdentityOptions): Promise<ResolvedIdentity>;
|
|
7
16
|
}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import { getAtprotoHandle, getPdsEndpoint } from '@atcute/identity';
|
|
2
|
+
import type { DidDocumentResolver, HandleResolver } from '@atcute/identity-resolver';
|
|
3
|
+
import type { ActorIdentifier, Did, Handle } from '@atcute/lexicons';
|
|
4
|
+
import { isDid } from '@atcute/lexicons/syntax';
|
|
5
|
+
|
|
6
|
+
import { ResolverError } from '../errors.js';
|
|
7
|
+
import type { IdentityResolver, ResolvedIdentity, ResolveIdentityOptions } from '../types/identity.js';
|
|
8
|
+
|
|
9
|
+
export interface DefaultIdentityResolverOptions {
|
|
10
|
+
handleResolver: HandleResolver;
|
|
11
|
+
didDocumentResolver: DidDocumentResolver;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export const defaultIdentityResolver = ({
|
|
15
|
+
handleResolver,
|
|
16
|
+
didDocumentResolver,
|
|
17
|
+
}: DefaultIdentityResolverOptions): IdentityResolver => {
|
|
18
|
+
return {
|
|
19
|
+
async resolve(actor: ActorIdentifier, options?: ResolveIdentityOptions): Promise<ResolvedIdentity> {
|
|
20
|
+
const identifierIsDid = isDid(actor);
|
|
21
|
+
|
|
22
|
+
let did: Did;
|
|
23
|
+
if (identifierIsDid) {
|
|
24
|
+
did = actor;
|
|
25
|
+
} else {
|
|
26
|
+
did = await handleResolver.resolve(actor, options);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const doc = await didDocumentResolver.resolve(did, options);
|
|
30
|
+
|
|
31
|
+
const pds = getPdsEndpoint(doc);
|
|
32
|
+
if (!pds) {
|
|
33
|
+
throw new ResolverError(`missing pds endpoint`);
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
let handle: Handle = 'handle.invalid';
|
|
37
|
+
if (identifierIsDid) {
|
|
38
|
+
const writtenHandle = getAtprotoHandle(doc);
|
|
39
|
+
if (writtenHandle) {
|
|
40
|
+
try {
|
|
41
|
+
const resolved = await handleResolver.resolve(writtenHandle, options);
|
|
42
|
+
|
|
43
|
+
if (resolved === did) {
|
|
44
|
+
handle = writtenHandle;
|
|
45
|
+
}
|
|
46
|
+
} catch {}
|
|
47
|
+
}
|
|
48
|
+
} else if (getAtprotoHandle(doc) === actor) {
|
|
49
|
+
handle = actor;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return {
|
|
53
|
+
did: did,
|
|
54
|
+
handle: handle,
|
|
55
|
+
pds: new URL(pds).href,
|
|
56
|
+
};
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
};
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"type": "module",
|
|
3
3
|
"name": "@atcute/oauth-browser-client",
|
|
4
|
-
"version": "2.0.
|
|
4
|
+
"version": "2.0.1",
|
|
5
5
|
"description": "minimal OAuth browser client implementation for AT Protocol",
|
|
6
6
|
"license": "0BSD",
|
|
7
7
|
"repository": {
|
|
@@ -20,15 +20,15 @@
|
|
|
20
20
|
"sideEffects": false,
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"nanoid": "^5.1.5",
|
|
23
|
-
"@atcute/
|
|
24
|
-
"@atcute/identity
|
|
25
|
-
"@atcute/
|
|
26
|
-
"@atcute/lexicons": "^1.
|
|
27
|
-
"@atcute/multibase": "^1.1.
|
|
28
|
-
"@atcute/uint8array": "^1.0.
|
|
23
|
+
"@atcute/client": "^4.0.5",
|
|
24
|
+
"@atcute/identity": "^1.1.1",
|
|
25
|
+
"@atcute/identity-resolver": "^1.1.4",
|
|
26
|
+
"@atcute/lexicons": "^1.2.2",
|
|
27
|
+
"@atcute/multibase": "^1.1.6",
|
|
28
|
+
"@atcute/uint8array": "^1.0.5"
|
|
29
29
|
},
|
|
30
30
|
"devDependencies": {
|
|
31
|
-
"@atcute/atproto": "^3.1.
|
|
31
|
+
"@atcute/atproto": "^3.1.8"
|
|
32
32
|
},
|
|
33
33
|
"scripts": {
|
|
34
34
|
"build": "tsc --project tsconfig.build.json",
|