@fivenorth/loop-sdk 0.9.0 → 0.11.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/README.md CHANGED
@@ -142,6 +142,7 @@ try {
142
142
  const result = await provider.submitTransaction(damlCommand, {
143
143
  // Optional: show a custom message in the wallet prompt
144
144
  message: 'Transfer 10 CC to RetailStore',
145
+ estimateTraffic: true, // optional: return estimated traffic in submission response
145
146
  });
146
147
  console.log('Transaction successful:', result);
147
148
  } catch (error) {
@@ -186,19 +187,19 @@ try {
186
187
  ```javascript
187
188
  await loop.wallet.transfer(
188
189
  'receiver::fingerprint',
189
- '5', // amount (string or number)
190
+ '5',
190
191
  {
191
- // Optional overrides. Defaults to Amulet/DSO if omitted.
192
- instrument_admin: 'issuer::fingerprint', // optional
193
- instrument_id: 'Amulet', // optional
192
+ instrument_admin: 'issuer::fingerprint', // optional: DSO (default)
193
+ instrument_id: 'Amulet', // optional: Amulet (default)
194
194
  },
195
195
  {
196
- // Optional: show a custom message in the wallet prompt
197
- message: 'Send 5 CC to Alice',
196
+ message: 'Send 5 CC to Alice', // optional: show a custom message in the wallet prompt
197
+ memo: 'optional memo for the transfer', // optional: stored as transfer metadata
198
198
  executionMode: 'wait', // optional: 'async' (default) or 'wait'
199
199
  requestedAt: new Date().toISOString(), // optional
200
200
  executeBefore: new Date(Date.now() + 24*60*60*1000).toISOString(), // optional
201
201
  requestTimeout: 5 * 60 * 1000, // optional (ms), defaults to 5 minutes
202
+ estimateTraffic: true, // optional: return estimated traffic in submission response
202
203
  },
203
204
  );
204
205
  ```
@@ -206,7 +207,6 @@ await loop.wallet.transfer(
206
207
  Notes:
207
208
  - You must have spendable holdings for the specified instrument (admin + id). If left blank, the SDK defaults to the native token.
208
209
  - The helper handles fetching holdings, building the transfer factory payload, and submitting via Wallet Connect.
209
- - Requests time out after 5 minutes by default; override with `requestTimeout` in milliseconds.
210
210
 
211
211
  Common instrument overrides (pass into the `instrument` argument above):
212
212
 
@@ -237,6 +237,15 @@ Notes:
237
237
 
238
238
  Coming soon
239
239
 
240
+ ## Loop Server Signing API
241
+
242
+ Loop SDK also supports a server-side signing flow. Instead of a wallet popup, your backend signs and submits transactions directly using the user's private key.
243
+
244
+ Example ideas:
245
+ - List pending transfers
246
+ - Accept a pending transfer
247
+
248
+
240
249
  # Development Guide
241
250
 
242
251
  This section is only if you want to actively develop the SDK itself. To use the SDK, follow the `#Usage Guide` section
@@ -0,0 +1,40 @@
1
+ import type { Network, Account, Holding, TransferRequest, PreparedTransferPayload, ExchangeApiKeyResponse, TransactionPayload, PreparedSubmissionResponse, ExecuteSubmissionResquest } from './types';
2
+ import { SessionInfo } from './session';
3
+ export declare class Connection {
4
+ walletUrl: string;
5
+ apiUrl: string;
6
+ ws: WebSocket | null;
7
+ private network;
8
+ private ticketId;
9
+ private onMessageHandler;
10
+ private reconnectPromise;
11
+ private status;
12
+ constructor({ network, walletUrl, apiUrl }: {
13
+ network?: Network;
14
+ walletUrl?: string;
15
+ apiUrl?: string;
16
+ });
17
+ connectInProgress(): boolean;
18
+ getTicket(appName: string, sessionId: string, version: string): Promise<{
19
+ ticket_id: string;
20
+ }>;
21
+ getHolding(authToken: string): Promise<Holding[]>;
22
+ getActiveContracts(authToken: string, params?: {
23
+ templateId?: string;
24
+ interfaceId?: string;
25
+ }): Promise<any[]>;
26
+ prepareTransfer(authToken: string, params: TransferRequest): Promise<PreparedTransferPayload>;
27
+ verifySession(authToken: string): Promise<Account>;
28
+ connectWebSocket(ticketId: string, onMessage: (event: MessageEvent) => void): void;
29
+ reconnect(): Promise<void>;
30
+ exchangeApiKey({ publicKey, signature, epoch }: {
31
+ publicKey: string;
32
+ signature: string;
33
+ epoch: number;
34
+ }): Promise<ExchangeApiKeyResponse>;
35
+ prepareTransaction(session: SessionInfo, params: TransactionPayload): Promise<PreparedSubmissionResponse>;
36
+ executeTransaction(session: SessionInfo, params: ExecuteSubmissionResquest): Promise<PreparedSubmissionResponse>;
37
+ private websocketUrl;
38
+ private attachWebSocket;
39
+ }
40
+ //# sourceMappingURL=connection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"connection.d.ts","sourceRoot":"","sources":["../src/connection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,OAAO,EACP,OAAO,EACP,OAAO,EACP,eAAe,EACf,uBAAuB,EAEvB,sBAAsB,EACtB,kBAAkB,EAClB,0BAA0B,EAC1B,yBAAyB,EAC5B,MAAM,SAAS,CAAC;AAEjB,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAC;AAGxC,qBAAa,UAAU;IACZ,SAAS,EAAE,MAAM,CAA4B;IAC7C,MAAM,EAAE,MAAM,CAA4B;IAC1C,EAAE,EAAE,SAAS,GAAG,IAAI,CAAQ;IACnC,OAAO,CAAC,OAAO,CAAmB;IAClC,OAAO,CAAC,QAAQ,CAAuB;IACvC,OAAO,CAAC,gBAAgB,CAAgD;IACxE,OAAO,CAAC,gBAAgB,CAA8B;IACtD,OAAO,CAAC,MAAM,CAA+D;gBAEjE,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,EAAE;QAAE,OAAO,CAAC,EAAE,OAAO,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAA;KAAE;IAmCtG,iBAAiB,IAAI,OAAO;IAItB,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC;IAoB9F,UAAU,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;IAgBjD,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;IAwB7G,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,GAAG,OAAO,CAAC,uBAAuB,CAAC;IA4C7F,aAAa,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAmCxD,gBAAgB,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,YAAY,KAAK,IAAI;IAwB3E,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC;IA+BpB,cAAc,CAAC,EAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAC,EAAE;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAC,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAqB3I,kBAAkB,CAAC,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,kBAAkB,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAenG,kBAAkB,CAAC,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,yBAAyB,GAAG,OAAO,CAAC,0BAA0B,CAAC;IAwBtH,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,eAAe;CAqC1B"}
@@ -0,0 +1,13 @@
1
+ export declare class RequestTimeoutError extends Error {
2
+ constructor(timeout: number);
3
+ }
4
+ export declare class RejectRequestError extends Error {
5
+ constructor();
6
+ }
7
+ export declare class UnauthorizedError extends Error {
8
+ code?: string;
9
+ constructor(code?: string);
10
+ }
11
+ export declare function extractErrorCode(message: any): string | null;
12
+ export declare function isUnauthCode(code: string | null | undefined): code is string;
13
+ //# sourceMappingURL=errors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"errors.d.ts","sourceRoot":"","sources":["../src/errors.ts"],"names":[],"mappings":"AAAA,qBAAa,mBAAoB,SAAQ,KAAK;gBAC9B,OAAO,EAAE,MAAM;CAG9B;AAED,qBAAa,kBAAmB,SAAQ,KAAK;;CAI5C;AAED,qBAAa,iBAAkB,SAAQ,KAAK;IACjC,IAAI,CAAC,EAAE,MAAM,CAAC;gBACT,IAAI,CAAC,EAAE,MAAM;CAI5B;AAID,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,GAAG,GAAG,MAAM,GAAG,IAAI,CAQ5D;AAED,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI,IAAI,MAAM,CAK5E"}
@@ -0,0 +1,11 @@
1
+ import type { WithdrawOptions, UsdcBridgeExtension, WithdrawUsdcRequest, PreparedWithdrawPayload } from './types';
2
+ import type { Provider } from '../../provider';
3
+ import type { Connection } from '../../connection';
4
+ export declare class UsdcBridge implements UsdcBridgeExtension {
5
+ private getProvider;
6
+ constructor(getProvider: () => Provider | null);
7
+ private requireProvider;
8
+ withdrawalUSDCxToEthereum(recipient: string, amount: string | number, options?: WithdrawOptions): Promise<any>;
9
+ }
10
+ export declare function prepareUsdcWithdraw(connection: Connection, authToken: string, params: WithdrawUsdcRequest): Promise<PreparedWithdrawPayload>;
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/extensions/usdc/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,uBAAuB,EAA2B,MAAM,SAAS,CAAC;AAC3I,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAEnD,qBAAa,UAAW,YAAW,mBAAmB;IACpD,OAAO,CAAC,WAAW,CAAwB;gBAE/B,WAAW,EAAE,MAAM,QAAQ,GAAG,IAAI;IAI9C,OAAO,CAAC,eAAe;IAQvB,yBAAyB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC;CAwB/G;AAED,wBAAsB,mBAAmB,CAAC,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,mBAAmB,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAyBlJ"}
@@ -0,0 +1,25 @@
1
+ export type WithdrawUsdcRequest = {
2
+ recipient: string;
3
+ amount: string;
4
+ reference?: string;
5
+ };
6
+ export type PreparedWithdrawPayload = {
7
+ actAs: string[];
8
+ readAs: string[];
9
+ synchronizerId: string;
10
+ commands: any[];
11
+ disclosedContracts: any[];
12
+ packageIdSelectionPreference: string[];
13
+ };
14
+ export type ConnectWithdrawResponse = {
15
+ payload: PreparedWithdrawPayload;
16
+ };
17
+ export type WithdrawOptions = {
18
+ reference?: string;
19
+ requestTimeout?: number;
20
+ message?: string;
21
+ };
22
+ export interface UsdcBridgeExtension {
23
+ withdrawalUSDCxToEthereum(recipient: string, amount: string | number, options?: WithdrawOptions): Promise<any>;
24
+ }
25
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/extensions/usdc/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,mBAAmB,GAAG;IAChC,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,cAAc,EAAE,MAAM,CAAC;IACvB,QAAQ,EAAE,GAAG,EAAE,CAAC;IAChB,kBAAkB,EAAE,GAAG,EAAE,CAAC;IAC1B,4BAA4B,EAAE,MAAM,EAAE,CAAC;CACxC,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG;IACpC,OAAO,EAAE,uBAAuB,CAAC;CAClC,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,WAAW,mBAAmB;IAClC,yBAAyB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;CAChH"}
@@ -0,0 +1,53 @@
1
+ import { Provider } from "./provider";
2
+ import type { Network, Wallet, RunTransactionResponse } from "./types";
3
+ declare class LoopSDK {
4
+ private version;
5
+ private appName;
6
+ private connection;
7
+ private session;
8
+ private provider;
9
+ private openMode;
10
+ private requestSigningMode;
11
+ private popupWindow;
12
+ private redirectUrl?;
13
+ private onAccept;
14
+ private onReject;
15
+ private onTransactionUpdate;
16
+ private overlay;
17
+ wallet: Wallet;
18
+ constructor();
19
+ init({ appName, network, walletUrl, apiUrl, onAccept, onReject, onTransactionUpdate, options, }: {
20
+ appName: string;
21
+ network?: Network;
22
+ walletUrl?: string;
23
+ apiUrl?: string;
24
+ onAccept?: (provider: Provider) => void;
25
+ onReject?: () => void;
26
+ onTransactionUpdate?: (payload: RunTransactionResponse, message: any) => void;
27
+ options?: {
28
+ openMode?: "popup" | "tab";
29
+ requestSigningMode?: "popup" | "tab";
30
+ redirectUrl?: string;
31
+ };
32
+ }): void;
33
+ private loadSessionInfo;
34
+ autoConnect(): Promise<void>;
35
+ connect(): Promise<void>;
36
+ private handleWebSocketMessage;
37
+ getConnectUrl(): string;
38
+ private buildConnectUrl;
39
+ private buildDashboardUrl;
40
+ private openRequestUi;
41
+ private closePopupIfExists;
42
+ private openWallet;
43
+ private injectModalStyles;
44
+ private showQrCode;
45
+ private hideQrCode;
46
+ logout(): void;
47
+ private requireProvider;
48
+ private createProviderHooks;
49
+ }
50
+ export declare const loop: LoopSDK;
51
+ export * from "./extensions/usdc/types";
52
+ export * from "./types";
53
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAIA,OAAO,EAAqB,QAAQ,EAAE,MAAM,YAAY,CAAC;AAEzD,OAAO,KAAK,EAGX,OAAO,EAEP,MAAM,EACN,sBAAsB,EACtB,MAAM,SAAS,CAAC;AAIjB,cAAM,OAAO;IACZ,OAAO,CAAC,OAAO,CAAmB;IAElC,OAAO,CAAC,OAAO,CAAqB;IACpC,OAAO,CAAC,UAAU,CAA2B;IAC7C,OAAO,CAAC,OAAO,CAA4B;IAC3C,OAAO,CAAC,QAAQ,CAAyB;IACzC,OAAO,CAAC,QAAQ,CAA4B;IAC5C,OAAO,CAAC,kBAAkB,CAA4B;IACtD,OAAO,CAAC,WAAW,CAAuB;IAC1C,OAAO,CAAC,WAAW,CAAC,CAAS;IAE7B,OAAO,CAAC,QAAQ,CAA+C;IAC/D,OAAO,CAAC,QAAQ,CAA6B;IAC3C,OAAO,CAAC,mBAAmB,CAA0E;IACvG,OAAO,CAAC,OAAO,CAA+B;IACvC,MAAM,EAAE,MAAM,CAAC;;IAMtB,IAAI,CAAC,EACJ,OAAO,EACP,OAAO,EACP,SAAS,EACT,MAAM,EACN,QAAQ,EACR,QAAQ,EACR,mBAAmB,EACnB,OAAO,GACP,EAAE;QACF,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,QAAQ,CAAC,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,IAAI,CAAC;QACxC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;QACtB,mBAAmB,CAAC,EAAE,CAAC,OAAO,EAAE,sBAAsB,EAAE,OAAO,EAAE,GAAG,KAAK,IAAI,CAAC;QAC9E,OAAO,CAAC,EAAE;YACT,QAAQ,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YAC3B,kBAAkB,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YACrC,WAAW,CAAC,EAAE,MAAM,CAAC;SACrB,CAAC;KACF;YAiCa,eAAe;IA6CvB,WAAW,IAAI,OAAO,CAAC,IAAI,CAAC;IA8B5B,OAAO;IA2Cb,OAAO,CAAC,sBAAsB;IA8DvB,aAAa,IAAI,MAAM;IAO9B,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,aAAa;IAqBrB,OAAO,CAAC,kBAAkB;IAW1B,OAAO,CAAC,UAAU;IAuClB,OAAO,CAAC,iBAAiB;IAyIzB,OAAO,CAAC,UAAU;IAoFlB,OAAO,CAAC,UAAU;IAOlB,MAAM;IAQN,OAAO,CAAC,eAAe;IASvB,OAAO,CAAC,mBAAmB;CAe3B;AAED,eAAO,MAAM,IAAI,SAAgB,CAAC;AAClC,cAAc,yBAAyB,CAAC;AACxC,cAAc,SAAS,CAAC"}