@pomade/core 0.0.12 → 0.1.0
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/client.d.ts +141 -19
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +70 -184
- package/dist/client.js.map +1 -1
- package/dist/message.d.ts +26 -259
- package/dist/message.d.ts.map +1 -1
- package/dist/message.js +1 -127
- package/dist/message.js.map +1 -1
- package/dist/pomade-signer.d.ts +0 -1
- package/dist/pomade-signer.d.ts.map +1 -1
- package/dist/pomade-signer.js +1 -4
- package/dist/pomade-signer.js.map +1 -1
- package/dist/rpc.d.ts +6 -46
- package/dist/rpc.d.ts.map +1 -1
- package/dist/rpc.js +31 -187
- package/dist/rpc.js.map +1 -1
- package/dist/schema.d.ts +78 -126
- package/dist/schema.d.ts.map +1 -1
- package/dist/schema.js +67 -105
- package/dist/schema.js.map +1 -1
- package/dist/signer.d.ts +26 -43
- package/dist/signer.d.ts.map +1 -1
- package/dist/signer.js +224 -368
- package/dist/signer.js.map +1 -1
- package/dist/storage.d.ts +2 -5
- package/dist/storage.d.ts.map +1 -1
- package/dist/storage.js +1 -1
- package/dist/storage.js.map +1 -1
- package/dist/util.d.ts +4 -26
- package/dist/util.d.ts.map +1 -1
- package/dist/util.js +13 -57
- package/dist/util.js.map +1 -1
- package/package.json +1 -1
package/dist/schema.js
CHANGED
|
@@ -1,28 +1,4 @@
|
|
|
1
1
|
import * as z from "zod";
|
|
2
|
-
export var Method;
|
|
3
|
-
(function (Method) {
|
|
4
|
-
Method["ChallengeRequest"] = "challenge/request";
|
|
5
|
-
Method["EcdhRequest"] = "ecdh/request";
|
|
6
|
-
Method["EcdhResult"] = "ecdh/result";
|
|
7
|
-
Method["LoginStart"] = "login/start";
|
|
8
|
-
Method["LoginOptions"] = "login/options";
|
|
9
|
-
Method["LoginSelect"] = "login/select";
|
|
10
|
-
Method["LoginResult"] = "login/result";
|
|
11
|
-
Method["RecoveryStart"] = "recovery/start";
|
|
12
|
-
Method["RecoveryOptions"] = "recovery/options";
|
|
13
|
-
Method["RecoverySelect"] = "recovery/select";
|
|
14
|
-
Method["RecoveryResult"] = "recovery/result";
|
|
15
|
-
Method["RecoverySetup"] = "recovery/setup";
|
|
16
|
-
Method["RecoverySetupResult"] = "recovery/setup/result";
|
|
17
|
-
Method["RegisterRequest"] = "register/request";
|
|
18
|
-
Method["RegisterResult"] = "register/result";
|
|
19
|
-
Method["SessionDelete"] = "session/delete";
|
|
20
|
-
Method["SessionDeleteResult"] = "session/delete/result";
|
|
21
|
-
Method["SessionList"] = "session/list";
|
|
22
|
-
Method["SessionListResult"] = "session/list/result";
|
|
23
|
-
Method["SignRequest"] = "sign/request";
|
|
24
|
-
Method["SignResult"] = "sign/result";
|
|
25
|
-
})(Method || (Method = {}));
|
|
26
2
|
// Security limits to prevent DoS attacks via unbounded payloads
|
|
27
3
|
const MAX_HASHES_PER_REQUEST = 10; // Maximum number of hashes in a single signature request
|
|
28
4
|
const MAX_HASH_VECTORS = 10; // Maximum number of hash vectors per request
|
|
@@ -59,15 +35,6 @@ const sighash_vec = z
|
|
|
59
35
|
.refine(arr => arr.length <= MAX_HASHES_PER_REQUEST, {
|
|
60
36
|
message: `Maximum ${MAX_HASHES_PER_REQUEST} hashes allowed per request`,
|
|
61
37
|
});
|
|
62
|
-
const event = z.object({
|
|
63
|
-
sig: hex,
|
|
64
|
-
id: hex32,
|
|
65
|
-
pubkey: hex32,
|
|
66
|
-
kind: z.int().nonnegative(),
|
|
67
|
-
tags: z.string().array().array(),
|
|
68
|
-
content: z.string(),
|
|
69
|
-
created_at: z.int().positive(),
|
|
70
|
-
});
|
|
71
38
|
const sessionItem = z.object({
|
|
72
39
|
pubkey: hex32,
|
|
73
40
|
client: hex32,
|
|
@@ -90,121 +57,116 @@ const auth = z.union([passwordAuth, otpAuth]);
|
|
|
90
57
|
export const isPasswordAuth = (auth) => Boolean(auth.password_hash);
|
|
91
58
|
export const isOTPAuth = (auth) => Boolean(auth.otp);
|
|
92
59
|
export const Schema = {
|
|
60
|
+
registerRequest: z.object({
|
|
61
|
+
share: share,
|
|
62
|
+
group: group,
|
|
63
|
+
recovery: z.boolean(),
|
|
64
|
+
}),
|
|
65
|
+
registerResponse: z.object({
|
|
66
|
+
ok: z.boolean(),
|
|
67
|
+
message: z.string(),
|
|
68
|
+
}),
|
|
69
|
+
signRequest: z.object({
|
|
70
|
+
request: z.object({
|
|
71
|
+
content: z.string().nullable(),
|
|
72
|
+
hashes: sighash_vec.array().max(MAX_HASH_VECTORS),
|
|
73
|
+
members: z.number().array().max(MAX_MEMBERS),
|
|
74
|
+
stamp: z.number(),
|
|
75
|
+
type: z.string(),
|
|
76
|
+
gid: hex32,
|
|
77
|
+
sid: hex32,
|
|
78
|
+
}),
|
|
79
|
+
}),
|
|
80
|
+
signResponse: z.object({
|
|
81
|
+
ok: z.boolean(),
|
|
82
|
+
message: z.string(),
|
|
83
|
+
result: z
|
|
84
|
+
.object({
|
|
85
|
+
idx: z.number(),
|
|
86
|
+
psigs: psig_entry.array(),
|
|
87
|
+
pubkey: hex33,
|
|
88
|
+
sid: hex32,
|
|
89
|
+
})
|
|
90
|
+
.optional(),
|
|
91
|
+
}),
|
|
93
92
|
ecdhRequest: z.object({
|
|
94
93
|
idx: z.number(),
|
|
95
94
|
members: z.number().array().max(MAX_MEMBERS),
|
|
96
95
|
ecdh_pk: hex32,
|
|
97
96
|
}),
|
|
98
|
-
|
|
99
|
-
|
|
97
|
+
ecdhResponse: z.object({
|
|
98
|
+
ok: z.boolean(),
|
|
99
|
+
message: z.string(),
|
|
100
|
+
result: z
|
|
101
|
+
.object({
|
|
100
102
|
idx: z.number(),
|
|
101
103
|
keyshare: hex,
|
|
102
104
|
members: z.number().array().max(MAX_MEMBERS),
|
|
103
105
|
ecdh_pk: hex,
|
|
104
|
-
})
|
|
106
|
+
})
|
|
107
|
+
.optional(),
|
|
108
|
+
}),
|
|
109
|
+
recoverySetupRequest: z.object({
|
|
110
|
+
email: z.string().email(),
|
|
111
|
+
password_hash: z.string(),
|
|
112
|
+
}),
|
|
113
|
+
recoverySetupResponse: z.object({
|
|
105
114
|
ok: z.boolean(),
|
|
106
115
|
message: z.string(),
|
|
107
|
-
prev: hex32,
|
|
108
116
|
}),
|
|
109
117
|
challengeRequest: z.object({
|
|
110
118
|
prefix: z.string().regex(/^\d{2}$/),
|
|
111
119
|
email_hash: z.string(),
|
|
112
120
|
}),
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
}),
|
|
116
|
-
loginOptions: z.object({
|
|
117
|
-
items: z.array(sessionItem).optional(),
|
|
118
|
-
ok: z.boolean(),
|
|
119
|
-
message: z.string(),
|
|
120
|
-
prev: hex32,
|
|
121
|
-
}),
|
|
122
|
-
loginSelect: z.object({
|
|
123
|
-
client: hex32,
|
|
124
|
-
}),
|
|
125
|
-
loginResult: z.object({
|
|
126
|
-
group: group.optional(),
|
|
127
|
-
ok: z.boolean(),
|
|
121
|
+
challengeResponse: z.object({
|
|
122
|
+
ok: z.literal(true),
|
|
128
123
|
message: z.string(),
|
|
129
|
-
prev: hex32,
|
|
130
124
|
}),
|
|
131
|
-
|
|
125
|
+
loginStartRequest: z.object({
|
|
132
126
|
auth,
|
|
133
127
|
}),
|
|
134
|
-
|
|
135
|
-
items: z.array(sessionItem).optional(),
|
|
128
|
+
loginStartResponse: z.object({
|
|
136
129
|
ok: z.boolean(),
|
|
137
130
|
message: z.string(),
|
|
138
|
-
|
|
131
|
+
items: z.array(sessionItem).optional(),
|
|
139
132
|
}),
|
|
140
|
-
|
|
133
|
+
loginSelectRequest: z.object({
|
|
141
134
|
client: hex32,
|
|
142
135
|
}),
|
|
143
|
-
|
|
144
|
-
share: share.optional(),
|
|
145
|
-
group: group.optional(),
|
|
136
|
+
loginSelectResponse: z.object({
|
|
146
137
|
ok: z.boolean(),
|
|
147
138
|
message: z.string(),
|
|
148
|
-
|
|
149
|
-
}),
|
|
150
|
-
recoverySetup: z.object({
|
|
151
|
-
email: z.string().email(),
|
|
152
|
-
password_hash: z.string(),
|
|
153
|
-
}),
|
|
154
|
-
recoverySetupResult: z.object({
|
|
155
|
-
ok: z.boolean(),
|
|
156
|
-
message: z.string(),
|
|
157
|
-
prev: hex32,
|
|
139
|
+
group: group.optional(),
|
|
158
140
|
}),
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
group: group,
|
|
162
|
-
recovery: z.boolean(),
|
|
141
|
+
recoveryStartRequest: z.object({
|
|
142
|
+
auth,
|
|
163
143
|
}),
|
|
164
|
-
|
|
144
|
+
recoveryStartResponse: z.object({
|
|
165
145
|
ok: z.boolean(),
|
|
166
146
|
message: z.string(),
|
|
167
|
-
|
|
147
|
+
items: z.array(sessionItem).optional(),
|
|
168
148
|
}),
|
|
169
|
-
|
|
149
|
+
recoverySelectRequest: z.object({
|
|
170
150
|
client: hex32,
|
|
171
|
-
auth: event,
|
|
172
151
|
}),
|
|
173
|
-
|
|
152
|
+
recoverySelectResponse: z.object({
|
|
174
153
|
ok: z.boolean(),
|
|
175
154
|
message: z.string(),
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
sessionList: z.object({
|
|
179
|
-
auth: event,
|
|
155
|
+
share: share.optional(),
|
|
156
|
+
group: group.optional(),
|
|
180
157
|
}),
|
|
181
|
-
|
|
182
|
-
|
|
158
|
+
sessionListRequest: z.object({}),
|
|
159
|
+
sessionListResponse: z.object({
|
|
183
160
|
ok: z.boolean(),
|
|
184
161
|
message: z.string(),
|
|
185
|
-
|
|
162
|
+
items: z.array(sessionItem),
|
|
186
163
|
}),
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
content: z.string().nullable(),
|
|
190
|
-
hashes: sighash_vec.array().max(MAX_HASH_VECTORS),
|
|
191
|
-
members: z.number().array().max(MAX_MEMBERS),
|
|
192
|
-
stamp: z.number(),
|
|
193
|
-
type: z.string(),
|
|
194
|
-
gid: hex32,
|
|
195
|
-
sid: hex32,
|
|
196
|
-
}),
|
|
164
|
+
sessionDeleteRequest: z.object({
|
|
165
|
+
client: hex32,
|
|
197
166
|
}),
|
|
198
|
-
|
|
199
|
-
result: z.optional(z.object({
|
|
200
|
-
idx: z.number(),
|
|
201
|
-
psigs: psig_entry.array(),
|
|
202
|
-
pubkey: hex33,
|
|
203
|
-
sid: hex32,
|
|
204
|
-
})),
|
|
167
|
+
sessionDeleteResponse: z.object({
|
|
205
168
|
ok: z.boolean(),
|
|
206
169
|
message: z.string(),
|
|
207
|
-
prev: hex32,
|
|
208
170
|
}),
|
|
209
171
|
};
|
|
210
172
|
//# sourceMappingURL=schema.js.map
|
package/dist/schema.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../src/schema.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,KAAK,CAAA;AAExB,
|
|
1
|
+
{"version":3,"file":"schema.js","sourceRoot":"","sources":["../src/schema.ts"],"names":[],"mappings":"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"}
|
package/dist/signer.d.ts
CHANGED
|
@@ -1,17 +1,18 @@
|
|
|
1
|
+
import * as z from "zod";
|
|
1
2
|
import type { GroupPackage, SharePackage } from "@frostr/bifrost";
|
|
2
|
-
import type {
|
|
3
|
+
import type { SignedEvent } from "@welshman/util";
|
|
3
4
|
import type { ISigner } from "@welshman/signer";
|
|
4
|
-
import {
|
|
5
|
-
import { RPC, WithEvent } from "./rpc.js";
|
|
5
|
+
import { Auth } from "./schema.js";
|
|
6
6
|
import { IStorage, ICollection } from "./storage.js";
|
|
7
|
-
import { ChallengeRequest,
|
|
7
|
+
import { RegisterRequest, RegisterResponse, RecoverySetupRequest, RecoverySetupResponse, ChallengeRequest, ChallengeResponse, LoginStartRequest, LoginStartResponse, LoginSelectRequest, LoginSelectResponse, RecoveryStartRequest, RecoveryStartResponse, RecoverySelectRequest, RecoverySelectResponse, SessionListResponse, SessionDeleteRequest, SessionDeleteResponse, SignRequest, SignResponse, EcdhRequest, EcdhResponse } from "./message.js";
|
|
8
8
|
import { RateLimitBucket } from "./ratelimit.js";
|
|
9
|
+
type Handler<T, R> = (pubkey: SignedEvent, data: T) => Promise<R>;
|
|
9
10
|
export type SignerSession = {
|
|
10
11
|
client: string;
|
|
11
12
|
share: SharePackage;
|
|
12
13
|
group: GroupPackage;
|
|
13
14
|
recovery: boolean;
|
|
14
|
-
|
|
15
|
+
created_at: number;
|
|
15
16
|
last_activity: number;
|
|
16
17
|
email?: string;
|
|
17
18
|
email_hash?: string;
|
|
@@ -26,15 +27,15 @@ export type SignerRecoverOption = {
|
|
|
26
27
|
threshold: number;
|
|
27
28
|
};
|
|
28
29
|
export type SignerRecovery = {
|
|
29
|
-
|
|
30
|
+
created_at: number;
|
|
30
31
|
clients: string[];
|
|
31
32
|
};
|
|
32
33
|
export type SignerLogin = {
|
|
33
|
-
|
|
34
|
+
created_at: number;
|
|
34
35
|
clients: string[];
|
|
35
36
|
};
|
|
36
37
|
export type SignerChallenge = {
|
|
37
|
-
|
|
38
|
+
created_at: number;
|
|
38
39
|
otp: string;
|
|
39
40
|
};
|
|
40
41
|
export type ChallengePayload = {
|
|
@@ -42,14 +43,13 @@ export type ChallengePayload = {
|
|
|
42
43
|
otp: string;
|
|
43
44
|
};
|
|
44
45
|
export type SignerOptions = {
|
|
46
|
+
url: string;
|
|
45
47
|
signer: ISigner;
|
|
46
|
-
relays: string[];
|
|
47
48
|
storage: IStorage;
|
|
48
49
|
sendChallenge: (payload: ChallengePayload) => Promise<void>;
|
|
49
50
|
};
|
|
50
51
|
export declare class Signer {
|
|
51
52
|
private options;
|
|
52
|
-
rpc: RPC;
|
|
53
53
|
intervals: number[];
|
|
54
54
|
logins: ICollection<SignerLogin>;
|
|
55
55
|
sessions: ICollection<SignerSession>;
|
|
@@ -60,42 +60,25 @@ export declare class Signer {
|
|
|
60
60
|
rateLimitByClient: ICollection<RateLimitBucket>;
|
|
61
61
|
constructor(options: SignerOptions);
|
|
62
62
|
stop(): void;
|
|
63
|
+
_parseAuth(header?: string, path?: string): SignedEvent | undefined;
|
|
63
64
|
_checkAndRecordRateLimit(client: string): Promise<boolean>;
|
|
64
65
|
_getAuthenticatedSessions(auth: Auth): Promise<SignerSession[]>;
|
|
65
|
-
|
|
66
|
-
_checkKeyReuse(event: TrustedEvent): Promise<{
|
|
67
|
-
abort: () => void;
|
|
68
|
-
res: Promise<import("@welshman/net").PublishResultsByRelay>;
|
|
69
|
-
ok: Promise<boolean>;
|
|
70
|
-
receive: <T>(handler: import("./rpc.js").MessageHandlerWithCallback<T>) => Promise<import("@welshman/lib").Maybe<T>>;
|
|
71
|
-
} | undefined>;
|
|
66
|
+
_checkKeyReuse(client: string): Promise<boolean>;
|
|
72
67
|
_addSession(client: string, session: SignerSession): Promise<void>;
|
|
73
68
|
_deleteSession(client: string): Promise<void>;
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
res: Promise<import("@welshman/net").PublishResultsByRelay>;
|
|
88
|
-
ok: Promise<boolean>;
|
|
89
|
-
receive: <T>(handler: import("./rpc.js").MessageHandlerWithCallback<T>) => Promise<import("@welshman/lib").Maybe<T>>;
|
|
90
|
-
} | undefined>;
|
|
91
|
-
handleSignRequest({ payload, event }: WithEvent<SignRequest>): Promise<unknown>;
|
|
92
|
-
handleEcdhRequest({ payload, event }: WithEvent<EcdhRequest>): Promise<unknown>;
|
|
93
|
-
handleSessionList({ payload, event }: WithEvent<SessionList>): Promise<{
|
|
94
|
-
abort: () => void;
|
|
95
|
-
res: Promise<import("@welshman/net").PublishResultsByRelay>;
|
|
96
|
-
ok: Promise<boolean>;
|
|
97
|
-
receive: <T>(handler: import("./rpc.js").MessageHandlerWithCallback<T>) => Promise<import("@welshman/lib").Maybe<T>>;
|
|
98
|
-
} | undefined>;
|
|
99
|
-
handleSessionDelete({ payload, event }: WithEvent<SessionDelete>): Promise<unknown>;
|
|
69
|
+
_handleRegister(auth: SignedEvent, data: RegisterRequest): Promise<RegisterResponse>;
|
|
70
|
+
_handleRecoverySetup({ pubkey: client }: SignedEvent, data: RecoverySetupRequest): Promise<RecoverySetupResponse>;
|
|
71
|
+
_handleChallenge(_auth: SignedEvent, data: ChallengeRequest): Promise<ChallengeResponse>;
|
|
72
|
+
_handleRecoveryStart({ pubkey: client }: SignedEvent, data: RecoveryStartRequest): Promise<RecoveryStartResponse>;
|
|
73
|
+
_handleRecoverySelect({ pubkey: client }: SignedEvent, data: RecoverySelectRequest): Promise<RecoverySelectResponse>;
|
|
74
|
+
_handleLoginStart({ pubkey: client }: SignedEvent, data: LoginStartRequest): Promise<LoginStartResponse>;
|
|
75
|
+
_handleLoginSelect({ pubkey: client }: SignedEvent, data: LoginSelectRequest): Promise<LoginSelectResponse>;
|
|
76
|
+
_handleSign({ pubkey: client }: SignedEvent, data: SignRequest): Promise<SignResponse>;
|
|
77
|
+
_handleEcdh({ pubkey: client }: SignedEvent, { members, ecdh_pk }: EcdhRequest): Promise<EcdhResponse>;
|
|
78
|
+
_handleSessionList({ pubkey }: SignedEvent, _data: Record<string, never>): Promise<SessionListResponse>;
|
|
79
|
+
_handleSessionDelete({ pubkey }: SignedEvent, data: SessionDeleteRequest): Promise<SessionDeleteResponse>;
|
|
80
|
+
_handle<T>(auth: SignedEvent, body: Record<string, unknown>, schema: z.ZodType<T>, handler: Handler<T, unknown>): Promise<unknown>;
|
|
81
|
+
handle(path: string, authHeader: string, body: Record<string, unknown>): Promise<unknown>;
|
|
100
82
|
}
|
|
83
|
+
export {};
|
|
101
84
|
//# sourceMappingURL=signer.d.ts.map
|
package/dist/signer.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../src/signer.ts"],"names":[],"mappings":"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"}
|