@novasamatech/host-papp 0.5.0-18 → 0.5.0-19

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 (133) hide show
  1. package/.papi/descriptors/generated.json +1 -0
  2. package/dist/sso/auth/attestationService.js +1 -1
  3. package/package.json +5 -5
  4. package/dist/adapters/identity/rpc.d.ts +0 -6
  5. package/dist/adapters/identity/rpc.js +0 -101
  6. package/dist/adapters/identity/types.d.ts +0 -10
  7. package/dist/adapters/identity/types.js +0 -1
  8. package/dist/adapters/lazyClient/papi.d.ts +0 -3
  9. package/dist/adapters/lazyClient/papi.js +0 -17
  10. package/dist/adapters/lazyClient/types.d.ts +0 -5
  11. package/dist/adapters/lazyClient/types.js +0 -1
  12. package/dist/adapters/statement/rpc.d.ts +0 -3
  13. package/dist/adapters/statement/rpc.js +0 -93
  14. package/dist/adapters/statement/types.d.ts +0 -9
  15. package/dist/adapters/statement/types.js +0 -1
  16. package/dist/adapters/storage/localStorage.d.ts +0 -2
  17. package/dist/adapters/storage/localStorage.js +0 -34
  18. package/dist/adapters/storage/memory.d.ts +0 -2
  19. package/dist/adapters/storage/memory.js +0 -22
  20. package/dist/adapters/storage/types.d.ts +0 -7
  21. package/dist/adapters/storage/types.js +0 -1
  22. package/dist/adapters/transport/rpc.d.ts +0 -3
  23. package/dist/adapters/transport/rpc.js +0 -51
  24. package/dist/adapters/transport/types.d.ts +0 -6
  25. package/dist/adapters/transport/types.js +0 -1
  26. package/dist/components/auth/codec.d.ts +0 -9
  27. package/dist/components/auth/codec.js +0 -10
  28. package/dist/components/auth/codecs.d.ts +0 -9
  29. package/dist/components/auth/codecs.js +0 -10
  30. package/dist/components/auth/index.d.ts +0 -36
  31. package/dist/components/auth/index.js +0 -150
  32. package/dist/components/auth/types.d.ts +0 -15
  33. package/dist/components/auth/types.js +0 -1
  34. package/dist/components/session.d.ts +0 -34
  35. package/dist/components/session.js +0 -54
  36. package/dist/components/sso/index.d.ts +0 -36
  37. package/dist/components/sso/index.js +0 -150
  38. package/dist/components/sso/scale/handshake.d.ts +0 -9
  39. package/dist/components/sso/scale/handshake.js +0 -10
  40. package/dist/components/sso/types.d.ts +0 -15
  41. package/dist/components/sso/types.js +0 -1
  42. package/dist/components/transport.d.ts +0 -27
  43. package/dist/components/transport.js +0 -57
  44. package/dist/components/user/codec.d.ts +0 -16
  45. package/dist/components/user/codec.js +0 -13
  46. package/dist/components/user/index.d.ts +0 -22
  47. package/dist/components/user/index.js +0 -58
  48. package/dist/components/user/ssoMessageStream.d.ts +0 -10
  49. package/dist/components/user/ssoMessageStream.js +0 -8
  50. package/dist/components/user/ssoSession.d.ts +0 -5
  51. package/dist/components/user/ssoSession.js +0 -5
  52. package/dist/components/user/storage.d.ts +0 -27
  53. package/dist/components/user/storage.js +0 -143
  54. package/dist/components/user/types.d.ts +0 -6
  55. package/dist/components/user/types.js +0 -1
  56. package/dist/components/user/userSessionStorage.d.ts +0 -20
  57. package/dist/components/user/userSessionStorage.js +0 -24
  58. package/dist/components/user.d.ts +0 -74
  59. package/dist/components/user.js +0 -188
  60. package/dist/helpers/result.d.ts +0 -12
  61. package/dist/helpers/result.js +0 -15
  62. package/dist/helpers/result.spec.d.ts +0 -1
  63. package/dist/helpers/result.spec.js +0 -23
  64. package/dist/helpers.d.ts +0 -1
  65. package/dist/helpers.js +0 -3
  66. package/dist/modules/accounts.d.ts +0 -1
  67. package/dist/modules/accounts.js +0 -2
  68. package/dist/modules/crypto.d.ts +0 -23
  69. package/dist/modules/crypto.js +0 -51
  70. package/dist/modules/secretStorage.d.ts +0 -15
  71. package/dist/modules/secretStorage.js +0 -44
  72. package/dist/modules/session/helpers.d.ts +0 -5
  73. package/dist/modules/session/helpers.js +0 -29
  74. package/dist/modules/session/session.d.ts +0 -12
  75. package/dist/modules/session/session.js +0 -50
  76. package/dist/modules/session/types.d.ts +0 -12
  77. package/dist/modules/session/types.js +0 -1
  78. package/dist/modules/signIn.d.ts +0 -67
  79. package/dist/modules/signIn.js +0 -188
  80. package/dist/modules/state.d.ts +0 -16
  81. package/dist/modules/state.js +0 -50
  82. package/dist/modules/statementStore.d.ts +0 -12
  83. package/dist/modules/statementStore.js +0 -22
  84. package/dist/modules/statementTopic.d.ts +0 -34
  85. package/dist/modules/statementTopic.js +0 -46
  86. package/dist/modules/storageView.d.ts +0 -25
  87. package/dist/modules/storageView.js +0 -51
  88. package/dist/modules/syncStorage.d.ts +0 -25
  89. package/dist/modules/syncStorage.js +0 -76
  90. package/dist/modules/transport/codec.d.ts +0 -24
  91. package/dist/modules/transport/codec.js +0 -36
  92. package/dist/modules/transport/crypto.d.ts +0 -2
  93. package/dist/modules/transport/crypto.js +0 -20
  94. package/dist/modules/transport/transport.d.ts +0 -42
  95. package/dist/modules/transport/transport.js +0 -66
  96. package/dist/modules/user.d.ts +0 -67
  97. package/dist/modules/user.js +0 -188
  98. package/dist/modules/userManager.d.ts +0 -15
  99. package/dist/modules/userManager.js +0 -105
  100. package/dist/modules/userStorage.d.ts +0 -19
  101. package/dist/modules/userStorage.js +0 -108
  102. package/dist/modules/userStore.d.ts +0 -15
  103. package/dist/modules/userStore.js +0 -105
  104. package/dist/sso/session/impl.d.ts +0 -23
  105. package/dist/sso/session/impl.js +0 -57
  106. package/dist/sso/session/scale/remoteMessage.d.ts +0 -10
  107. package/dist/sso/session/scale/remoteMessage.js +0 -13
  108. package/dist/sso/session/sessionManager.d.ts +0 -23
  109. package/dist/sso/session/sessionManager.js +0 -58
  110. package/dist/sso/session/ssoSession.d.ts +0 -8
  111. package/dist/sso/session/ssoSession.js +0 -5
  112. package/dist/sso/session/ssoSessionStorage.d.ts +0 -21
  113. package/dist/sso/session/ssoSessionStorage.js +0 -20
  114. package/dist/sso/session/types.d.ts +0 -6
  115. package/dist/sso/session/types.js +0 -1
  116. package/dist/sso/session/userSessionStorage.d.ts +0 -21
  117. package/dist/sso/session/userSessionStorage.js +0 -20
  118. package/dist/sso/sessionManager/attestationService.d.ts +0 -5
  119. package/dist/sso/sessionManager/attestationService.js +0 -15
  120. package/dist/sso/sessionManager/repository/ssoSessionRepository.d.ts +0 -22
  121. package/dist/sso/sessionManager/repository/ssoSessionRepository.js +0 -27
  122. package/dist/sso/sessionManager/scale/signRequest.d.ts +0 -19
  123. package/dist/sso/sessionManager/scale/signRequest.js +0 -19
  124. package/dist/sso/sessionManager/scale/signResponse.d.ts +0 -6
  125. package/dist/sso/sessionManager/scale/signResponse.js +0 -5
  126. package/dist/sso/sessionManager/ssoSession.d.ts +0 -23
  127. package/dist/sso/sessionManager/ssoSession.js +0 -69
  128. package/dist/sso/sessionManager/ssoSessionProver.d.ts +0 -4
  129. package/dist/sso/sessionManager/ssoSessionProver.js +0 -35
  130. package/dist/sso/ssoSessionRepository.d.ts +0 -18
  131. package/dist/sso/ssoSessionRepository.js +0 -27
  132. package/dist/structs.d.ts +0 -24
  133. package/dist/structs.js +0 -36
@@ -1,150 +0,0 @@
1
- import { toHex } from '@polkadot-api/utils';
2
- import { err, errAsync, fromPromise, fromThrowable, ok } from 'neverthrow';
3
- import { AbortError } from '../../helpers/abortError.js';
4
- import { toError } from '../../helpers/utils.js';
5
- import { ENCR_SECRET_SEED_SIZE, SS_SECRET_SEED_SIZE, createEncrSecret, createRandomSeed, createSharedSecret, createSsHardDerivation, createSsSecret, decrypt, getEncrPub, getSsPub, khash, mergeBytes, stringToBytes, } from '../../modules/crypto.js';
6
- import { createAccount } from '../../modules/session/helpers.js';
7
- import { createState, readonly } from '../../modules/state.js';
8
- import { createUserSession } from '../../modules/statementStore.js';
9
- import { HandshakeData, HandshakeResponsePayload, HandshakeResponseSensitiveData } from './codec.js';
10
- export function createAuthComponent({ appId, metadata, transport, userSessionStorage }) {
11
- const authStatus = createState({ step: 'none' });
12
- let authResults = null;
13
- let abort = null;
14
- function handshake(signal) {
15
- try {
16
- authStatus.write({ step: 'initial' });
17
- const { encrSecret, encrPublicKey, ssPublicKey } = getSecretKeys(appId);
18
- const hostAccount = createAccount(ssPublicKey, encrPublicKey);
19
- const handshakePayload = createHandshakePayloadV1({ ssPublicKey, encrPublicKey, metadata }).andTee(payload => authStatus.write({ step: 'pairing', payload: createDeeplink(payload) }));
20
- const handshakeTopic = createHandshakeTopic(hostAccount);
21
- const pappResponse = handshakePayload
22
- .andThen(() => handshakeTopic)
23
- .asyncAndThen(topic => waitForStatements(callback => transport.subscribeSession(topic, callback), signal, (statements, resolve) => {
24
- for (const statement of [...statements].reverse()) {
25
- if (!statement.data)
26
- continue;
27
- const session = retrieveSession({
28
- hostAccount,
29
- encrSecret,
30
- payload: statement.data.asBytes(),
31
- });
32
- resolve(session);
33
- break;
34
- }
35
- }));
36
- const userCreated = pappResponse.andThen(userSessionStorage.add);
37
- return userCreated
38
- .orElse(e => (AbortError.isAbortError(e) ? ok(null) : err(toError(e))))
39
- .andTee(session => {
40
- if (session) {
41
- authStatus.write({ step: 'finished', session });
42
- }
43
- else {
44
- authStatus.write({ step: 'none' });
45
- }
46
- })
47
- .orTee(e => authStatus.write({ step: 'error', message: e.message }));
48
- }
49
- catch (e) {
50
- return errAsync(toError(e));
51
- }
52
- }
53
- const authModule = {
54
- status: readonly(authStatus),
55
- authenticate() {
56
- if (authResults) {
57
- return authResults;
58
- }
59
- abort = new AbortController();
60
- authResults = handshake(abort.signal);
61
- return authResults;
62
- },
63
- abortAuthentication() {
64
- if (abort) {
65
- authResults = null;
66
- authStatus.reset();
67
- abort.abort(new AbortError('Aborted by user.'));
68
- }
69
- },
70
- };
71
- return authModule;
72
- }
73
- const createHandshakeTopic = fromThrowable((account) => khash(account.accountId, mergeBytes(account.publicKey, stringToBytes('topic'))), toError);
74
- const createHandshakePayloadV1 = fromThrowable(({ encrPublicKey, ssPublicKey, metadata, }) => HandshakeData.enc({
75
- tag: 'V1',
76
- value: [ssPublicKey, encrPublicKey, metadata],
77
- }), toError);
78
- function parseHandshakePayload(payload) {
79
- const decoded = HandshakeResponsePayload.dec(payload);
80
- switch (decoded.tag) {
81
- case 'V1':
82
- return {
83
- encrypted: decoded.value[0],
84
- tmpKey: decoded.value[1],
85
- };
86
- default:
87
- throw new Error('Unsupported handshake payload version');
88
- }
89
- }
90
- function retrieveSession({ payload, encrSecret, hostAccount, }) {
91
- const { encrypted, tmpKey } = parseHandshakePayload(payload);
92
- const symmetricKey = createSharedSecret(encrSecret, tmpKey);
93
- const decrypted = decrypt(symmetricKey, encrypted);
94
- const [pappEncrPublicKey, pappAccountId] = HandshakeResponseSensitiveData.dec(decrypted);
95
- const sharedSecret = createSharedSecret(encrSecret, pappEncrPublicKey);
96
- const peerAccount = createAccount(pappAccountId, sharedSecret);
97
- return createUserSession(hostAccount, peerAccount);
98
- }
99
- function getSsKeys(appId) {
100
- const seed = createRandomSeed(appId, SS_SECRET_SEED_SIZE);
101
- const ssSecret = createSsHardDerivation(createSsSecret(seed), '//wallet');
102
- return {
103
- ssSecret: ssSecret,
104
- ssPublicKey: getSsPub(ssSecret),
105
- };
106
- }
107
- function getEncrKeys(appId) {
108
- const seed = createRandomSeed(appId, ENCR_SECRET_SEED_SIZE);
109
- const encrSecret = createEncrSecret(seed);
110
- return {
111
- encrSecret,
112
- encrPublicKey: getEncrPub(encrSecret),
113
- };
114
- }
115
- function getSecretKeys(appId) {
116
- const ss = getSsKeys(appId);
117
- const encr = getEncrKeys(appId);
118
- return {
119
- ...ss,
120
- ...encr,
121
- };
122
- }
123
- function createDeeplink(payload) {
124
- return `polkadotapp://pair?handshake=${toHex(payload)}`;
125
- }
126
- function waitForStatements(subscribe, abortSignal, callback) {
127
- return fromPromise(new Promise((resolve, reject) => {
128
- const unsubscribe = subscribe(statements => {
129
- if (abortSignal?.aborted) {
130
- unsubscribe();
131
- try {
132
- abortSignal.throwIfAborted();
133
- }
134
- catch (e) {
135
- reject(e);
136
- }
137
- }
138
- try {
139
- callback(statements, value => {
140
- unsubscribe();
141
- resolve(value);
142
- });
143
- }
144
- catch (e) {
145
- unsubscribe();
146
- reject(e);
147
- }
148
- });
149
- }), toError);
150
- }
@@ -1,15 +0,0 @@
1
- import type { UserSession } from '../user/userSessionStorage.js';
2
- export type AuthentificationStatus = {
3
- step: 'none';
4
- } | {
5
- step: 'initial';
6
- } | {
7
- step: 'pairing';
8
- payload: string;
9
- } | {
10
- step: 'error';
11
- message: string;
12
- } | {
13
- step: 'finished';
14
- session: UserSession;
15
- };
@@ -1 +0,0 @@
1
- export {};
@@ -1,34 +0,0 @@
1
- import type { CodecType } from 'scale-ts';
2
- import type { StorageAdapter } from '../adapters/storage/types.js';
3
- import type { Account } from '../modules/statementStore.js';
4
- import type { Transport } from '../modules/transport/transport.js';
5
- import type { Callback } from '../types.js';
6
- export type Session<T> = {
7
- subscribe(callback: Callback<T>): VoidFunction;
8
- dispose(): void;
9
- };
10
- export declare const HostRemoteMessageCodec: import("scale-ts").Codec<{
11
- messageId: string;
12
- data: {
13
- tag: "v1";
14
- value: {
15
- tag: "Disconnected";
16
- value: undefined;
17
- } | {
18
- tag: "SigningRequest";
19
- value: Uint8Array<ArrayBufferLike>;
20
- } | {
21
- tag: "SigningResponse";
22
- value: Uint8Array<ArrayBufferLike>;
23
- };
24
- };
25
- }>;
26
- export type SSOSession = Session<CodecType<typeof HostRemoteMessageCodec>>;
27
- type SsoSessionParams = {
28
- ownAccount: Account;
29
- peerAccount: Account;
30
- transport: Transport;
31
- storage: StorageAdapter;
32
- };
33
- export declare function createSSOSession({ ownAccount, peerAccount, transport, storage }: SsoSessionParams): SSOSession;
34
- export {};
@@ -1,54 +0,0 @@
1
- import { fromThrowable, okAsync } from 'neverthrow';
2
- import { toHex } from 'polkadot-api/utils';
3
- import { Bytes, Enum, Struct, _void, str } from 'scale-ts';
4
- import { toError } from '../helpers/utils.js';
5
- import { createSessionId } from '../modules/statementStore.js';
6
- import { storageListView } from '../modules/storageView.js';
7
- // SSO
8
- export const HostRemoteMessageCodec = Struct({
9
- messageId: str,
10
- data: Enum({
11
- v1: Enum({
12
- Disconnected: _void,
13
- // TODO implement
14
- SigningRequest: Bytes(),
15
- // TODO implement
16
- SigningResponse: Bytes(),
17
- }),
18
- }),
19
- });
20
- export function createSSOSession({ ownAccount, peerAccount, transport, storage }) {
21
- const peerSession = createSessionId(peerAccount, ownAccount);
22
- const processedStorage = storageListView({
23
- key: `Session_Processed_${toHex(peerSession)}`,
24
- storage,
25
- initial: [],
26
- from: JSON.parse,
27
- to: JSON.stringify,
28
- });
29
- let subscriptions = [];
30
- return {
31
- subscribe(callback) {
32
- const fn = fromThrowable(callback, toError);
33
- const unsub = transport.handleRequest(ownAccount, peerAccount, HostRemoteMessageCodec, async (message) => {
34
- processedStorage.read().andThen(processed => {
35
- if (processed.includes(message.requestId)) {
36
- return okAsync();
37
- }
38
- return fn(message.data).asyncAndThen(() => processedStorage.mutate(p => p.concat(message.requestId)));
39
- });
40
- });
41
- subscriptions.push(unsub);
42
- return () => {
43
- unsub();
44
- subscriptions = subscriptions.filter(x => x !== unsub);
45
- };
46
- },
47
- dispose() {
48
- for (const unsub of subscriptions) {
49
- unsub();
50
- }
51
- subscriptions = [];
52
- },
53
- };
54
- }
@@ -1,36 +0,0 @@
1
- import type { Transport } from '@novasamatech/statement-store';
2
- import type { ResultAsync } from 'neverthrow';
3
- import type { UserSession, UserSessionStorage } from '../user/userSessionStorage.js';
4
- import type { AuthentificationStatus } from './types.js';
5
- export type AuthComponent = ReturnType<typeof createAuthComponent>;
6
- type Params = {
7
- /**
8
- * Host app Id.
9
- * CAUTION! This value should be stable.
10
- */
11
- appId: string;
12
- /**
13
- * URL for additional metadata that will be displayed during pairing process.
14
- * Content of provided json shound be
15
- * ```ts
16
- * interface Metadata {
17
- * name: string;
18
- * icon: string; // url for icon. Icon should be a rasterized image with min size 256x256 px.
19
- * }
20
- * ```
21
- */
22
- metadata: string;
23
- transport: Transport;
24
- userSessionStorage: UserSessionStorage;
25
- };
26
- export declare function createAuthComponent({ appId, metadata, transport, userSessionStorage }: Params): {
27
- status: {
28
- read: () => AuthentificationStatus;
29
- subscribe: (fn: (value: AuthentificationStatus) => void) => () => void;
30
- onFirstSubscribe: (callback: VoidFunction) => import("nanoevents").Unsubscribe;
31
- onLastUnsubscribe: (callback: VoidFunction) => import("nanoevents").Unsubscribe;
32
- };
33
- authenticate(): ResultAsync<UserSession | null, Error>;
34
- abortAuthentication(): void;
35
- };
36
- export {};
@@ -1,150 +0,0 @@
1
- import { createAccountId, createLocalSessionAccount } from '@novasamatech/statement-store';
2
- import { toHex } from '@polkadot-api/utils';
3
- import { err, errAsync, fromPromise, fromThrowable, ok } from 'neverthrow';
4
- import { AbortError } from '../../helpers/abortError.js';
5
- import { toError } from '../../helpers/utils.js';
6
- import { ENCR_SECRET_SEED_SIZE, SS_SECRET_SEED_SIZE, createEncrSecret, createRandomSeed, createSharedSecret, createSsHardDerivation, createSsSecret, decrypt, getEncrPub, getSsPub, khash, mergeBytes, stringToBytes, } from '../../modules/crypto.js';
7
- import { createState, readonly } from '../../modules/state.js';
8
- import { createUserSession } from '../../modules/statementStore.js';
9
- import { HandshakeData, HandshakeResponsePayload, HandshakeResponseSensitiveData } from './scale/handshake.js';
10
- export function createAuthComponent({ appId, metadata, transport, userSessionStorage }) {
11
- const authStatus = createState({ step: 'none' });
12
- let authResults = null;
13
- let abort = null;
14
- function handshake(signal) {
15
- try {
16
- authStatus.write({ step: 'initial' });
17
- const { encrSecret, encrPublicKey, ssPublicKey } = getSecretKeys(appId);
18
- const localAccount = createLocalSessionAccount(createAccountId(ssPublicKey));
19
- const handshakePayload = createHandshakePayloadV1({ ssPublicKey, encrPublicKey, metadata }).andTee(payload => authStatus.write({ step: 'pairing', payload: createDeeplink(payload) }));
20
- const handshakeTopic = createHandshakeTopic(localAccount, encrPublicKey);
21
- const pappResponse = handshakePayload
22
- .andThen(() => handshakeTopic)
23
- .asyncAndThen(topic => waitForStatements(callback => transport.subscribeSession(topic, callback), signal, (statements, resolve) => {
24
- for (const statement of [...statements].reverse()) {
25
- if (!statement.data)
26
- continue;
27
- const session = retrieveSession({
28
- hostAccount: localAccount,
29
- encrSecret,
30
- payload: statement.data.asBytes(),
31
- });
32
- resolve(session);
33
- break;
34
- }
35
- }));
36
- const userCreated = pappResponse.andThen(userSessionStorage.add);
37
- return userCreated
38
- .orElse(e => (AbortError.isAbortError(e) ? ok(null) : err(toError(e))))
39
- .andTee(session => {
40
- if (session) {
41
- authStatus.write({ step: 'finished', session });
42
- }
43
- else {
44
- authStatus.write({ step: 'none' });
45
- }
46
- })
47
- .orTee(e => authStatus.write({ step: 'error', message: e.message }));
48
- }
49
- catch (e) {
50
- return errAsync(toError(e));
51
- }
52
- }
53
- const authModule = {
54
- status: readonly(authStatus),
55
- authenticate() {
56
- if (authResults) {
57
- return authResults;
58
- }
59
- abort = new AbortController();
60
- authResults = handshake(abort.signal);
61
- return authResults;
62
- },
63
- abortAuthentication() {
64
- if (abort) {
65
- authResults = null;
66
- authStatus.reset();
67
- abort.abort(new AbortError('Aborted by user.'));
68
- }
69
- },
70
- };
71
- return authModule;
72
- }
73
- const createHandshakeTopic = fromThrowable((account, encrPublicKey) => khash(account.accountId, mergeBytes(encrPublicKey, stringToBytes('topic'))), toError);
74
- const createHandshakePayloadV1 = fromThrowable(({ encrPublicKey, ssPublicKey, metadata, }) => HandshakeData.enc({
75
- tag: 'V1',
76
- value: [ssPublicKey, encrPublicKey, metadata],
77
- }), toError);
78
- function parseHandshakePayload(payload) {
79
- const decoded = HandshakeResponsePayload.dec(payload);
80
- switch (decoded.tag) {
81
- case 'V1':
82
- return {
83
- encrypted: decoded.value[0],
84
- tmpKey: decoded.value[1],
85
- };
86
- default:
87
- throw new Error('Unsupported handshake payload version');
88
- }
89
- }
90
- function retrieveSession({ payload, encrSecret, hostAccount, }) {
91
- const { encrypted, tmpKey } = parseHandshakePayload(payload);
92
- const symmetricKey = createSharedSecret(encrSecret, tmpKey);
93
- const decrypted = decrypt(symmetricKey, encrypted);
94
- const [pappEncrPublicKey, pappAccountId] = HandshakeResponseSensitiveData.dec(decrypted);
95
- const sharedSecret = createSharedSecret(encrSecret, pappEncrPublicKey);
96
- const peerAccount = createAccount(pappAccountId, sharedSecret);
97
- return createUserSession(hostAccount, peerAccount);
98
- }
99
- function getSsKeys(appId) {
100
- const seed = createRandomSeed(appId, SS_SECRET_SEED_SIZE);
101
- const ssSecret = createSsHardDerivation(createSsSecret(seed), '//wallet');
102
- return {
103
- ssSecret: ssSecret,
104
- ssPublicKey: getSsPub(ssSecret),
105
- };
106
- }
107
- function getEncrKeys(appId) {
108
- const seed = createRandomSeed(appId, ENCR_SECRET_SEED_SIZE);
109
- const encrSecret = createEncrSecret(seed);
110
- return {
111
- encrSecret,
112
- encrPublicKey: getEncrPub(encrSecret),
113
- };
114
- }
115
- function getSecretKeys(appId) {
116
- const ss = getSsKeys(appId);
117
- const encr = getEncrKeys(appId);
118
- return {
119
- ...ss,
120
- ...encr,
121
- };
122
- }
123
- function createDeeplink(payload) {
124
- return `polkadotapp://pair?handshake=${toHex(payload)}`;
125
- }
126
- function waitForStatements(subscribe, abortSignal, callback) {
127
- return fromPromise(new Promise((resolve, reject) => {
128
- const unsubscribe = subscribe(statements => {
129
- if (abortSignal?.aborted) {
130
- unsubscribe();
131
- try {
132
- abortSignal.throwIfAborted();
133
- }
134
- catch (e) {
135
- reject(e);
136
- }
137
- }
138
- try {
139
- callback(statements, value => {
140
- unsubscribe();
141
- resolve(value);
142
- });
143
- }
144
- catch (e) {
145
- unsubscribe();
146
- reject(e);
147
- }
148
- });
149
- }), toError);
150
- }
@@ -1,9 +0,0 @@
1
- export declare const HandshakeData: import("scale-ts").Codec<{
2
- tag: "V1";
3
- value: [import("../../../modules/crypto.js").SsPublicKey, import("../../../modules/crypto.js").EncrPublicKey, string];
4
- }>;
5
- export declare const HandshakeResponsePayload: import("scale-ts").Codec<{
6
- tag: "V1";
7
- value: [Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>];
8
- }>;
9
- export declare const HandshakeResponseSensitiveData: import("scale-ts").Codec<[Uint8Array<ArrayBufferLike>, Uint8Array<ArrayBufferLike>]>;
@@ -1,10 +0,0 @@
1
- import { Bytes, Enum, Tuple, str } from 'scale-ts';
2
- import { EncrPubKey, SsPubKey } from '../../../modules/crypto.js';
3
- export const HandshakeData = Enum({
4
- V1: Tuple(SsPubKey, EncrPubKey, str),
5
- });
6
- export const HandshakeResponsePayload = Enum({
7
- // [encrypted, tmp_key]
8
- V1: Tuple(Bytes(), Bytes(65)),
9
- });
10
- export const HandshakeResponseSensitiveData = Tuple(Bytes(65), Bytes(32));
@@ -1,15 +0,0 @@
1
- import type { UserSession } from '../user/userSessionStorage.js';
2
- export type AuthentificationStatus = {
3
- step: 'none';
4
- } | {
5
- step: 'initial';
6
- } | {
7
- step: 'pairing';
8
- payload: string;
9
- } | {
10
- step: 'error';
11
- message: string;
12
- } | {
13
- step: 'finished';
14
- session: UserSession;
15
- };
@@ -1 +0,0 @@
1
- export {};
@@ -1,27 +0,0 @@
1
- import type { Statement } from '@polkadot-api/sdk-statement';
2
- import type { Codec } from 'scale-ts';
3
- import type { StatementAdapter } from '../adapters/statement/types.js';
4
- import type { Account } from '../modules/statementStore.js';
5
- import type { TransportError } from '../structs.js';
6
- import type { Callback } from '../types.js';
7
- export type Transport = ReturnType<typeof createTransport>;
8
- type RequestMessage<T> = {
9
- type: 'request';
10
- requestId: string;
11
- data: T;
12
- };
13
- type ResponseMessage = {
14
- type: 'response';
15
- requestId: string;
16
- code: TransportError;
17
- };
18
- type Message<T> = RequestMessage<T> | ResponseMessage;
19
- type Params = {
20
- adapter: StatementAdapter;
21
- };
22
- export declare function createTransport({ adapter }: Params): {
23
- subscribe<T>(ownAccount: Account, peerAccount: Account, codec: Codec<T>, callback: Callback<Message<T>[]>): VoidFunction;
24
- subscribeSession(sessionId: Uint8Array, callback: Callback<Statement[]>): VoidFunction;
25
- handleRequest<T>(ownAccount: Account, peerAccount: Account, codec: Codec<T>, callback: Callback<RequestMessage<T>>): VoidFunction;
26
- };
27
- export {};
@@ -1,57 +0,0 @@
1
- import { fromThrowable, ok } from 'neverthrow';
2
- import { seq } from '../helpers/result.js';
3
- import { nonNullable, toError } from '../helpers/utils.js';
4
- import { decrypt } from '../modules/crypto.js';
5
- import { createSessionId } from '../modules/statementStore.js';
6
- import { StatementData } from '../structs.js';
7
- const decryptResults = fromThrowable(decrypt, toError);
8
- export function createTransport({ adapter }) {
9
- function mapMessage(statementData) {
10
- switch (statementData.tag) {
11
- case 'request':
12
- return statementData.value.data.map((data, index) => ({
13
- type: 'request',
14
- requestId: `${statementData.value.requestId}-${index.toString()}`,
15
- data,
16
- }));
17
- case 'response':
18
- return [
19
- {
20
- type: 'response',
21
- requestId: statementData.value.requestId,
22
- code: statementData.value.responseCode,
23
- },
24
- ];
25
- }
26
- }
27
- const transport = {
28
- subscribe(ownAccount, peerAccount, codec, callback) {
29
- const sessionId = createSessionId(peerAccount, ownAccount);
30
- const statementDataCodec = StatementData(codec);
31
- return adapter.subscribeStatements([sessionId], statements => {
32
- seq(...statements.map(statement => {
33
- if (!statement.data)
34
- return ok(null);
35
- return decryptResults(peerAccount.publicKey, statement.data.asBytes())
36
- .map(statementDataCodec.dec)
37
- .orElse(() => ok(null));
38
- }))
39
- .map(messages => messages.filter(nonNullable).flatMap(mapMessage))
40
- .andTee(messages => {
41
- if (messages.length > 0) {
42
- callback(messages);
43
- }
44
- });
45
- });
46
- },
47
- subscribeSession(sessionId, callback) {
48
- return adapter.subscribeStatements([sessionId], callback);
49
- },
50
- handleRequest(ownAccount, peerAccount, codec, callback) {
51
- return transport.subscribe(ownAccount, peerAccount, codec, messages => {
52
- messages.filter(m => m.type === 'request').forEach(callback);
53
- });
54
- },
55
- };
56
- return transport;
57
- }
@@ -1,16 +0,0 @@
1
- export declare const HostRemoteMessageCodec: import("scale-ts").Codec<{
2
- messageId: string;
3
- data: {
4
- tag: "v1";
5
- value: {
6
- tag: "Disconnected";
7
- value: undefined;
8
- } | {
9
- tag: "SigningRequest";
10
- value: Uint8Array<ArrayBufferLike>;
11
- } | {
12
- tag: "SigningResponse";
13
- value: Uint8Array<ArrayBufferLike>;
14
- };
15
- };
16
- }>;
@@ -1,13 +0,0 @@
1
- import { Bytes, Enum, Struct, _void, str } from 'scale-ts';
2
- export const HostRemoteMessageCodec = Struct({
3
- messageId: str,
4
- data: Enum({
5
- v1: Enum({
6
- Disconnected: _void,
7
- // TODO implement
8
- SigningRequest: Bytes(),
9
- // TODO implement
10
- SigningResponse: Bytes(),
11
- }),
12
- }),
13
- });
@@ -1,22 +0,0 @@
1
- import type { StorageAdapter } from '../../adapters/storage/types.js';
2
- import type { Transport } from '../../modules/transport/transport.js';
3
- import type { UserSession, UserSessionStorage } from './userSessionStorage.js';
4
- export type UserSessionsComponent = ReturnType<typeof createUserSessionsComponent>;
5
- type Params = {
6
- transport: Transport;
7
- storage: StorageAdapter;
8
- userSessionStorage: UserSessionStorage;
9
- };
10
- export declare function createUserSessionsComponent({ userSessionStorage, storage, transport }: Params): {
11
- sessions: {
12
- add(value: UserSession): import("neverthrow").ResultAsync<UserSession, Error>;
13
- mutate(fn: (value: UserSession[]) => UserSession[]): import("neverthrow").ResultAsync<UserSession[], Error>;
14
- read(): any;
15
- write(value: UserSession[]): any;
16
- clear(): any;
17
- subscribe(fn: (value: UserSession[]) => void): () => void;
18
- };
19
- disconnect: (session: UserSession) => import("neverthrow").ResultAsync<undefined, Error>;
20
- destroy(): void;
21
- };
22
- export {};