@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.
Files changed (78) hide show
  1. package/README.md +125 -16
  2. package/dist/agents/exchange.d.ts +10 -2
  3. package/dist/agents/exchange.d.ts.map +1 -0
  4. package/dist/agents/exchange.js +23 -17
  5. package/dist/agents/exchange.js.map +1 -1
  6. package/dist/agents/server-agent.d.ts +1 -0
  7. package/dist/agents/server-agent.d.ts.map +1 -0
  8. package/dist/agents/server-agent.js +21 -3
  9. package/dist/agents/server-agent.js.map +1 -1
  10. package/dist/agents/sessions.d.ts +1 -0
  11. package/dist/agents/sessions.d.ts.map +1 -0
  12. package/dist/agents/user-agent.d.ts +1 -0
  13. package/dist/agents/user-agent.d.ts.map +1 -0
  14. package/dist/constants.d.ts +1 -0
  15. package/dist/constants.d.ts.map +1 -0
  16. package/dist/dpop.d.ts +1 -0
  17. package/dist/dpop.d.ts.map +1 -0
  18. package/dist/dpop.js +3 -0
  19. package/dist/dpop.js.map +1 -1
  20. package/dist/environment.d.ts +11 -7
  21. package/dist/environment.d.ts.map +1 -0
  22. package/dist/environment.js +3 -3
  23. package/dist/environment.js.map +1 -1
  24. package/dist/errors.d.ts +1 -0
  25. package/dist/errors.d.ts.map +1 -0
  26. package/dist/index.d.ts +3 -0
  27. package/dist/index.d.ts.map +1 -0
  28. package/dist/index.js +2 -0
  29. package/dist/index.js.map +1 -1
  30. package/dist/resolvers.d.ts +3 -2
  31. package/dist/resolvers.d.ts.map +1 -0
  32. package/dist/resolvers.js +4 -22
  33. package/dist/resolvers.js.map +1 -1
  34. package/dist/store/db.d.ts +2 -0
  35. package/dist/store/db.d.ts.map +1 -0
  36. package/dist/store/db.js.map +1 -1
  37. package/dist/types/client-assertion.d.ts +21 -0
  38. package/dist/types/client-assertion.d.ts.map +1 -0
  39. package/dist/types/client-assertion.js +3 -0
  40. package/dist/types/client-assertion.js.map +1 -0
  41. package/dist/types/client.d.ts +1 -0
  42. package/dist/types/client.d.ts.map +1 -0
  43. package/dist/types/dpop.d.ts +3 -0
  44. package/dist/types/dpop.d.ts.map +1 -0
  45. package/dist/types/identity.d.ts +13 -5
  46. package/dist/types/identity.d.ts.map +1 -0
  47. package/dist/types/par.d.ts +1 -0
  48. package/dist/types/par.d.ts.map +1 -0
  49. package/dist/types/server.d.ts +1 -0
  50. package/dist/types/server.d.ts.map +1 -0
  51. package/dist/types/store.d.ts +1 -0
  52. package/dist/types/store.d.ts.map +1 -0
  53. package/dist/types/token.d.ts +1 -0
  54. package/dist/types/token.d.ts.map +1 -0
  55. package/dist/utils/identity-resolver.d.ts +8 -0
  56. package/dist/utils/identity-resolver.d.ts.map +1 -0
  57. package/dist/utils/identity-resolver.js +44 -0
  58. package/dist/utils/identity-resolver.js.map +1 -0
  59. package/dist/utils/misc.d.ts +1 -0
  60. package/dist/utils/misc.d.ts.map +1 -0
  61. package/dist/utils/response.d.ts +1 -0
  62. package/dist/utils/response.d.ts.map +1 -0
  63. package/dist/utils/runtime.d.ts +1 -0
  64. package/dist/utils/runtime.d.ts.map +1 -0
  65. package/dist/utils/strings.d.ts +1 -0
  66. package/dist/utils/strings.d.ts.map +1 -0
  67. package/lib/agents/exchange.ts +32 -20
  68. package/lib/agents/server-agent.ts +26 -3
  69. package/lib/dpop.ts +4 -0
  70. package/lib/environment.ts +14 -9
  71. package/lib/index.ts +3 -0
  72. package/lib/resolvers.ts +7 -26
  73. package/lib/store/db.ts +1 -0
  74. package/lib/types/client-assertion.ts +25 -0
  75. package/lib/types/dpop.ts +2 -0
  76. package/lib/types/identity.ts +14 -5
  77. package/lib/utils/identity-resolver.ts +59 -0
  78. package/package.json +8 -8
package/lib/store/db.ts CHANGED
@@ -30,6 +30,7 @@ interface Schema {
30
30
  dpopKey: DPoPKey;
31
31
  metadata: AuthorizationServerMetadata;
32
32
  verifier?: string;
33
+ state?: unknown;
33
34
  };
34
35
  };
35
36
 
@@ -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
@@ -4,4 +4,6 @@ export interface DPoPKey {
4
4
  key: string;
5
5
  /** base64url-encoded jwt token */
6
6
  jwt: string;
7
+ /** JWK thumbprint (RFC 7638) for this key, used for client assertion binding */
8
+ jkt: string | undefined;
7
9
  }
@@ -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 IdentityMetadata {
4
- id: Did;
5
- raw: string;
6
- pds: URL;
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.0-next.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/identity": "^1.1.0",
24
- "@atcute/identity-resolver": "^1.1.3",
25
- "@atcute/client": "^4.0.3",
26
- "@atcute/lexicons": "^1.1.1",
27
- "@atcute/multibase": "^1.1.4",
28
- "@atcute/uint8array": "^1.0.3"
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.2"
31
+ "@atcute/atproto": "^3.1.8"
32
32
  },
33
33
  "scripts": {
34
34
  "build": "tsc --project tsconfig.build.json",