@aztec/accounts 0.47.0 → 0.48.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.
Files changed (50) hide show
  1. package/artifacts/EcdsaKAccount.json +1 -0
  2. package/artifacts/EcdsaRAccount.d.json.ts +3 -0
  3. package/artifacts/EcdsaRAccount.json +1 -0
  4. package/artifacts/SchnorrAccount.json +1 -1
  5. package/artifacts/SchnorrSingleKeyAccount.json +1 -1
  6. package/dest/ecdsa/{account_contract.d.ts → ecdsa_k/account_contract.d.ts} +2 -2
  7. package/dest/ecdsa/ecdsa_k/account_contract.d.ts.map +1 -0
  8. package/dest/ecdsa/ecdsa_k/account_contract.js +33 -0
  9. package/dest/ecdsa/ecdsa_k/artifact.d.ts +2 -0
  10. package/dest/ecdsa/ecdsa_k/artifact.d.ts.map +1 -0
  11. package/dest/ecdsa/ecdsa_k/artifact.js +4 -0
  12. package/dest/ecdsa/ecdsa_k/index.d.ts +31 -0
  13. package/dest/ecdsa/ecdsa_k/index.d.ts.map +1 -0
  14. package/dest/ecdsa/ecdsa_k/index.js +32 -0
  15. package/dest/ecdsa/index.d.ts +2 -30
  16. package/dest/ecdsa/index.d.ts.map +1 -1
  17. package/dest/ecdsa/index.js +3 -32
  18. package/dest/ecdsa/ssh_ecdsa_r/account_contract.d.ts +18 -0
  19. package/dest/ecdsa/ssh_ecdsa_r/account_contract.d.ts.map +1 -0
  20. package/dest/ecdsa/ssh_ecdsa_r/account_contract.js +76 -0
  21. package/dest/ecdsa/ssh_ecdsa_r/artifact.d.ts +2 -0
  22. package/dest/ecdsa/ssh_ecdsa_r/artifact.d.ts.map +1 -0
  23. package/dest/ecdsa/ssh_ecdsa_r/artifact.js +4 -0
  24. package/dest/ecdsa/ssh_ecdsa_r/index.d.ts +31 -0
  25. package/dest/ecdsa/ssh_ecdsa_r/index.d.ts.map +1 -0
  26. package/dest/ecdsa/ssh_ecdsa_r/index.js +32 -0
  27. package/dest/utils/index.d.ts +2 -0
  28. package/dest/utils/index.d.ts.map +1 -0
  29. package/dest/utils/index.js +2 -0
  30. package/dest/utils/ssh_agent.d.ts +35 -0
  31. package/dest/utils/ssh_agent.d.ts.map +1 -0
  32. package/dest/utils/ssh_agent.js +109 -0
  33. package/package.json +10 -9
  34. package/src/ecdsa/{account_contract.ts → ecdsa_k/account_contract.ts} +6 -6
  35. package/src/ecdsa/ecdsa_k/artifact.ts +5 -0
  36. package/src/ecdsa/ecdsa_k/index.ts +37 -0
  37. package/src/ecdsa/index.ts +2 -37
  38. package/src/ecdsa/ssh_ecdsa_r/account_contract.ts +88 -0
  39. package/src/ecdsa/ssh_ecdsa_r/artifact.ts +5 -0
  40. package/src/ecdsa/ssh_ecdsa_r/index.ts +37 -0
  41. package/src/utils/index.ts +1 -0
  42. package/src/utils/ssh_agent.ts +136 -0
  43. package/artifacts/EcdsaAccount.json +0 -1
  44. package/dest/ecdsa/account_contract.d.ts.map +0 -1
  45. package/dest/ecdsa/account_contract.js +0 -33
  46. package/dest/ecdsa/artifact.d.ts +0 -2
  47. package/dest/ecdsa/artifact.d.ts.map +0 -1
  48. package/dest/ecdsa/artifact.js +0 -4
  49. package/src/ecdsa/artifact.ts +0 -5
  50. /package/artifacts/{EcdsaAccount.d.json.ts → EcdsaKAccount.d.json.ts} +0 -0
@@ -1,12 +1,12 @@
1
1
  /// <reference types="node" resolution-mode="require"/>
2
2
  import { type AuthWitnessProvider } from '@aztec/aztec.js/account';
3
3
  import { type CompleteAddress } from '@aztec/circuit-types';
4
- import { DefaultAccountContract } from '../defaults/account_contract.js';
4
+ import { DefaultAccountContract } from '../../defaults/account_contract.js';
5
5
  /**
6
6
  * Account contract that authenticates transactions using ECDSA signatures
7
7
  * verified against a secp256k1 public key stored in an immutable encrypted note.
8
8
  */
9
- export declare class EcdsaAccountContract extends DefaultAccountContract {
9
+ export declare class EcdsaKAccountContract extends DefaultAccountContract {
10
10
  private signingPrivateKey;
11
11
  constructor(signingPrivateKey: Buffer);
12
12
  getDeploymentArgs(): Buffer[];
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account_contract.d.ts","sourceRoot":"","sources":["../../../src/ecdsa/ecdsa_k/account_contract.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAe,KAAK,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAKzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAG5E;;;GAGG;AACH,qBAAa,qBAAsB,SAAQ,sBAAsB;IACnD,OAAO,CAAC,iBAAiB;gBAAjB,iBAAiB,EAAE,MAAM;IAI7C,iBAAiB;IAKjB,sBAAsB,CAAC,QAAQ,EAAE,eAAe,GAAG,mBAAmB;CAGvE"}
@@ -0,0 +1,33 @@
1
+ import { AuthWitness } from '@aztec/circuit-types';
2
+ import { Ecdsa } from '@aztec/circuits.js/barretenberg';
3
+ import { DefaultAccountContract } from '../../defaults/account_contract.js';
4
+ import { EcdsaKAccountContractArtifact } from './artifact.js';
5
+ /**
6
+ * Account contract that authenticates transactions using ECDSA signatures
7
+ * verified against a secp256k1 public key stored in an immutable encrypted note.
8
+ */
9
+ export class EcdsaKAccountContract extends DefaultAccountContract {
10
+ constructor(signingPrivateKey) {
11
+ super(EcdsaKAccountContractArtifact);
12
+ this.signingPrivateKey = signingPrivateKey;
13
+ }
14
+ getDeploymentArgs() {
15
+ const signingPublicKey = new Ecdsa().computePublicKey(this.signingPrivateKey);
16
+ return [signingPublicKey.subarray(0, 32), signingPublicKey.subarray(32, 64)];
17
+ }
18
+ getAuthWitnessProvider(_address) {
19
+ return new EcdsaKAuthWitnessProvider(this.signingPrivateKey);
20
+ }
21
+ }
22
+ /** Creates auth witnesses using ECDSA signatures. */
23
+ class EcdsaKAuthWitnessProvider {
24
+ constructor(signingPrivateKey) {
25
+ this.signingPrivateKey = signingPrivateKey;
26
+ }
27
+ createAuthWit(messageHash) {
28
+ const ecdsa = new Ecdsa();
29
+ const signature = ecdsa.constructSignature(messageHash.toBuffer(), this.signingPrivateKey);
30
+ return Promise.resolve(new AuthWitness(messageHash, [...signature.r, ...signature.s]));
31
+ }
32
+ }
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudF9jb250cmFjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lY2RzYS9lY2RzYV9rL2FjY291bnRfY29udHJhY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBd0IsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFJeEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDNUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTlEOzs7R0FHRztBQUNILE1BQU0sT0FBTyxxQkFBc0IsU0FBUSxzQkFBc0I7SUFDL0QsWUFBb0IsaUJBQXlCO1FBQzNDLEtBQUssQ0FBQyw2QkFBaUQsQ0FBQyxDQUFDO1FBRHZDLHNCQUFpQixHQUFqQixpQkFBaUIsQ0FBUTtJQUU3QyxDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLEtBQUssRUFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1FBQzlFLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxFQUFFLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUMvRSxDQUFDO0lBRUQsc0JBQXNCLENBQUMsUUFBeUI7UUFDOUMsT0FBTyxJQUFJLHlCQUF5QixDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQy9ELENBQUM7Q0FDRjtBQUVELHFEQUFxRDtBQUNyRCxNQUFNLHlCQUF5QjtJQUM3QixZQUFvQixpQkFBeUI7UUFBekIsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFRO0lBQUcsQ0FBQztJQUVqRCxhQUFhLENBQUMsV0FBZTtRQUMzQixNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssRUFBRSxDQUFDO1FBQzFCLE1BQU0sU0FBUyxHQUFHLEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLEVBQUUsSUFBSSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDM0YsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksV0FBVyxDQUFDLFdBQVcsRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDLENBQUMsRUFBRSxHQUFHLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDekYsQ0FBQztDQUNGIn0=
@@ -0,0 +1,2 @@
1
+ export declare const EcdsaKAccountContractArtifact: import("@aztec/aztec.js").ContractArtifact;
2
+ //# sourceMappingURL=artifact.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"artifact.d.ts","sourceRoot":"","sources":["../../../src/ecdsa/ecdsa_k/artifact.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,4CAA0E,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { loadContractArtifact } from '@aztec/aztec.js';
2
+ import EcdsaKAccountContractJson from '../../../artifacts/EcdsaKAccount.json' assert { type: 'json' };
3
+ export const EcdsaKAccountContractArtifact = loadContractArtifact(EcdsaKAccountContractJson);
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWNkc2EvZWNkc2Ffay9hcnRpZmFjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQTZCLG9CQUFvQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFbEYsT0FBTyx5QkFBeUIsTUFBTSx1Q0FBdUMsQ0FBQyxTQUFTLElBQUksRUFBRSxNQUFNLEVBQUUsQ0FBQztBQUV0RyxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBRyxvQkFBb0IsQ0FBQyx5QkFBaUQsQ0FBQyxDQUFDIn0=
@@ -0,0 +1,31 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ /**
3
+ * The `@aztec/accounts/ecdsa` export provides an ECDSA account contract implementation, that uses an ECDSA private key for authentication, and a Grumpkin key for encryption.
4
+ * Consider using this account type when working with integrations with Ethereum wallets.
5
+ *
6
+ * @packageDocumentation
7
+ */
8
+ import { AccountManager, type Salt } from '@aztec/aztec.js/account';
9
+ import { type AccountWallet } from '@aztec/aztec.js/wallet';
10
+ import { type PXE } from '@aztec/circuit-types';
11
+ import { type AztecAddress, type Fr } from '@aztec/circuits.js';
12
+ import { EcdsaKAccountContract } from './account_contract.js';
13
+ export { EcdsaKAccountContractArtifact } from './artifact.js';
14
+ export { EcdsaKAccountContract };
15
+ /**
16
+ * Creates an Account that relies on an ECDSA signing key for authentication.
17
+ * @param pxe - An PXE server instance.
18
+ * @param secretKey - Secret key used to derive all the keystore keys.
19
+ * @param signingPrivateKey - Secp256k1 key used for signing transactions.
20
+ * @param salt - Deployment salt.
21
+ */
22
+ export declare function getEcdsaKAccount(pxe: PXE, secretKey: Fr, signingPrivateKey: Buffer, salt?: Salt): AccountManager;
23
+ /**
24
+ * Gets a wallet for an already registered account using ECDSA signatures.
25
+ * @param pxe - An PXE server instance.
26
+ * @param address - Address for the account.
27
+ * @param signingPrivateKey - ECDSA key used for signing transactions.
28
+ * @returns A wallet for this account that can be used to interact with a contract instance.
29
+ */
30
+ export declare function getEcdsaKWallet(pxe: PXE, address: AztecAddress, signingPrivateKey: Buffer): Promise<AccountWallet>;
31
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ecdsa/ecdsa_k/index.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;AACH,OAAO,EAAE,cAAc,EAAE,KAAK,IAAI,EAAE,MAAM,yBAAyB,CAAC;AACpE,OAAO,EAAE,KAAK,aAAa,EAAa,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,EAAE,EAAE,MAAM,oBAAoB,CAAC;AAEhE,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAE9D,OAAO,EAAE,6BAA6B,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,qBAAqB,EAAE,CAAC;AAEjC;;;;;;GAMG;AACH,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE,iBAAiB,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,cAAc,CAEhH;AAED;;;;;;GAMG;AACH,wBAAgB,eAAe,CAAC,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAElH"}
@@ -0,0 +1,32 @@
1
+ /**
2
+ * The `@aztec/accounts/ecdsa` export provides an ECDSA account contract implementation, that uses an ECDSA private key for authentication, and a Grumpkin key for encryption.
3
+ * Consider using this account type when working with integrations with Ethereum wallets.
4
+ *
5
+ * @packageDocumentation
6
+ */
7
+ import { AccountManager } from '@aztec/aztec.js/account';
8
+ import { getWallet } from '@aztec/aztec.js/wallet';
9
+ import { EcdsaKAccountContract } from './account_contract.js';
10
+ export { EcdsaKAccountContractArtifact } from './artifact.js';
11
+ export { EcdsaKAccountContract };
12
+ /**
13
+ * Creates an Account that relies on an ECDSA signing key for authentication.
14
+ * @param pxe - An PXE server instance.
15
+ * @param secretKey - Secret key used to derive all the keystore keys.
16
+ * @param signingPrivateKey - Secp256k1 key used for signing transactions.
17
+ * @param salt - Deployment salt.
18
+ */
19
+ export function getEcdsaKAccount(pxe, secretKey, signingPrivateKey, salt) {
20
+ return new AccountManager(pxe, secretKey, new EcdsaKAccountContract(signingPrivateKey), salt);
21
+ }
22
+ /**
23
+ * Gets a wallet for an already registered account using ECDSA signatures.
24
+ * @param pxe - An PXE server instance.
25
+ * @param address - Address for the account.
26
+ * @param signingPrivateKey - ECDSA key used for signing transactions.
27
+ * @returns A wallet for this account that can be used to interact with a contract instance.
28
+ */
29
+ export function getEcdsaKWallet(pxe, address, signingPrivateKey) {
30
+ return getWallet(pxe, address, new EcdsaKAccountContract(signingPrivateKey));
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWNkc2EvZWNkc2Ffay9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7R0FLRztBQUNILE9BQU8sRUFBRSxjQUFjLEVBQWEsTUFBTSx5QkFBeUIsQ0FBQztBQUNwRSxPQUFPLEVBQXNCLFNBQVMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBSXZFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTlELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsQ0FBQztBQUVqQzs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCLENBQUMsR0FBUSxFQUFFLFNBQWEsRUFBRSxpQkFBeUIsRUFBRSxJQUFXO0lBQzlGLE9BQU8sSUFBSSxjQUFjLENBQUMsR0FBRyxFQUFFLFNBQVMsRUFBRSxJQUFJLHFCQUFxQixDQUFDLGlCQUFpQixDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUM7QUFDaEcsQ0FBQztBQUVEOzs7Ozs7R0FNRztBQUNILE1BQU0sVUFBVSxlQUFlLENBQUMsR0FBUSxFQUFFLE9BQXFCLEVBQUUsaUJBQXlCO0lBQ3hGLE9BQU8sU0FBUyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUsSUFBSSxxQkFBcUIsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDLENBQUM7QUFDL0UsQ0FBQyJ9
@@ -1,31 +1,3 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- /**
3
- * The `@aztec/accounts/ecdsa` export provides an ECDSA account contract implementation, that uses an ECDSA private key for authentication, and a Grumpkin key for encryption.
4
- * Consider using this account type when working with integrations with Ethereum wallets.
5
- *
6
- * @packageDocumentation
7
- */
8
- import { AccountManager, type Salt } from '@aztec/aztec.js/account';
9
- import { type AccountWallet } from '@aztec/aztec.js/wallet';
10
- import { type PXE } from '@aztec/circuit-types';
11
- import { type AztecAddress, type Fr } from '@aztec/circuits.js';
12
- import { EcdsaAccountContract } from './account_contract.js';
13
- export { EcdsaAccountContractArtifact } from './artifact.js';
14
- export { EcdsaAccountContract };
15
- /**
16
- * Creates an Account that relies on an ECDSA signing key for authentication.
17
- * @param pxe - An PXE server instance.
18
- * @param secretKey - Secret key used to derive all the keystore keys.
19
- * @param signingPrivateKey - Secp256k1 key used for signing transactions.
20
- * @param salt - Deployment salt.
21
- */
22
- export declare function getEcdsaAccount(pxe: PXE, secretKey: Fr, signingPrivateKey: Buffer, salt?: Salt): AccountManager;
23
- /**
24
- * Gets a wallet for an already registered account using ECDSA signatures.
25
- * @param pxe - An PXE server instance.
26
- * @param address - Address for the account.
27
- * @param signingPrivateKey - ECDSA key used for signing transactions.
28
- * @returns A wallet for this account that can be used to interact with a contract instance.
29
- */
30
- export declare function getEcdsaWallet(pxe: PXE, address: AztecAddress, signingPrivateKey: Buffer): Promise<AccountWallet>;
1
+ export * from './ecdsa_k/index.js';
2
+ export * from './ssh_ecdsa_r/index.js';
31
3
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ecdsa/index.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;AACH,OAAO,EAAE,cAAc,EAAE,KAAK,IAAI,EAAE,MAAM,yBAAyB,CAAC;AACpE,OAAO,EAAE,KAAK,aAAa,EAAa,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,EAAE,EAAE,MAAM,oBAAoB,CAAC;AAEhE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAE7D,OAAO,EAAE,4BAA4B,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,oBAAoB,EAAE,CAAC;AAEhC;;;;;;GAMG;AACH,wBAAgB,eAAe,CAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE,iBAAiB,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,cAAc,CAE/G;AAED;;;;;;GAMG;AACH,wBAAgB,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAEjH"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/ecdsa/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC"}
@@ -1,32 +1,3 @@
1
- /**
2
- * The `@aztec/accounts/ecdsa` export provides an ECDSA account contract implementation, that uses an ECDSA private key for authentication, and a Grumpkin key for encryption.
3
- * Consider using this account type when working with integrations with Ethereum wallets.
4
- *
5
- * @packageDocumentation
6
- */
7
- import { AccountManager } from '@aztec/aztec.js/account';
8
- import { getWallet } from '@aztec/aztec.js/wallet';
9
- import { EcdsaAccountContract } from './account_contract.js';
10
- export { EcdsaAccountContractArtifact } from './artifact.js';
11
- export { EcdsaAccountContract };
12
- /**
13
- * Creates an Account that relies on an ECDSA signing key for authentication.
14
- * @param pxe - An PXE server instance.
15
- * @param secretKey - Secret key used to derive all the keystore keys.
16
- * @param signingPrivateKey - Secp256k1 key used for signing transactions.
17
- * @param salt - Deployment salt.
18
- */
19
- export function getEcdsaAccount(pxe, secretKey, signingPrivateKey, salt) {
20
- return new AccountManager(pxe, secretKey, new EcdsaAccountContract(signingPrivateKey), salt);
21
- }
22
- /**
23
- * Gets a wallet for an already registered account using ECDSA signatures.
24
- * @param pxe - An PXE server instance.
25
- * @param address - Address for the account.
26
- * @param signingPrivateKey - ECDSA key used for signing transactions.
27
- * @returns A wallet for this account that can be used to interact with a contract instance.
28
- */
29
- export function getEcdsaWallet(pxe, address, signingPrivateKey) {
30
- return getWallet(pxe, address, new EcdsaAccountContract(signingPrivateKey));
31
- }
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZWNkc2EvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxPQUFPLEVBQUUsY0FBYyxFQUFhLE1BQU0seUJBQXlCLENBQUM7QUFDcEUsT0FBTyxFQUFzQixTQUFTLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUl2RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUU3RCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLENBQUM7QUFFaEM7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLGVBQWUsQ0FBQyxHQUFRLEVBQUUsU0FBYSxFQUFFLGlCQUF5QixFQUFFLElBQVc7SUFDN0YsT0FBTyxJQUFJLGNBQWMsQ0FBQyxHQUFHLEVBQUUsU0FBUyxFQUFFLElBQUksb0JBQW9CLENBQUMsaUJBQWlCLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztBQUMvRixDQUFDO0FBRUQ7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLGNBQWMsQ0FBQyxHQUFRLEVBQUUsT0FBcUIsRUFBRSxpQkFBeUI7SUFDdkYsT0FBTyxTQUFTLENBQUMsR0FBRyxFQUFFLE9BQU8sRUFBRSxJQUFJLG9CQUFvQixDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztBQUM5RSxDQUFDIn0=
1
+ export * from './ecdsa_k/index.js';
2
+ export * from './ssh_ecdsa_r/index.js';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZWNkc2EvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLHdCQUF3QixDQUFDIn0=
@@ -0,0 +1,18 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ import { type AuthWitnessProvider } from '@aztec/aztec.js/account';
3
+ import { type CompleteAddress } from '@aztec/circuit-types';
4
+ import { DefaultAccountContract } from '../../defaults/account_contract.js';
5
+ /**
6
+ * Account contract that authenticates transactions using ECDSA signatures
7
+ * verified against a secp256r1 public key stored in an immutable encrypted note.
8
+ * Since this implementation relays signatures to an SSH agent, we provide the
9
+ * public key here not for signature verification, but to identify actual identity
10
+ * that will be used to sign authwitnesses.
11
+ */
12
+ export declare class EcdsaRSSHAccountContract extends DefaultAccountContract {
13
+ private signingPublicKey;
14
+ constructor(signingPublicKey: Buffer);
15
+ getDeploymentArgs(): Buffer[];
16
+ getAuthWitnessProvider(_address: CompleteAddress): AuthWitnessProvider;
17
+ }
18
+ //# sourceMappingURL=account_contract.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"account_contract.d.ts","sourceRoot":"","sources":["../../../src/ecdsa/ssh_ecdsa_r/account_contract.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AACnE,OAAO,EAAe,KAAK,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAKzE,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAK5E;;;;;;GAMG;AACH,qBAAa,wBAAyB,SAAQ,sBAAsB;IACtD,OAAO,CAAC,gBAAgB;gBAAhB,gBAAgB,EAAE,MAAM;IAI5C,iBAAiB;IAIjB,sBAAsB,CAAC,QAAQ,EAAE,eAAe,GAAG,mBAAmB;CAGvE"}
@@ -0,0 +1,76 @@
1
+ var _SSHEcdsaRAuthWitnessProvider_instances, _SSHEcdsaRAuthWitnessProvider_parseECDSASignature;
2
+ import { __classPrivateFieldGet } from "tslib";
3
+ import { AuthWitness } from '@aztec/circuit-types';
4
+ import { EcdsaSignature } from '@aztec/circuits.js/barretenberg';
5
+ import { DefaultAccountContract } from '../../defaults/account_contract.js';
6
+ import { signWithAgent } from '../../utils/ssh_agent.js';
7
+ import { EcdsaRAccountContractArtifact } from './artifact.js';
8
+ const secp256r1N = 115792089210356248762697446949407573529996955224135760342422259061068512044369n;
9
+ /**
10
+ * Account contract that authenticates transactions using ECDSA signatures
11
+ * verified against a secp256r1 public key stored in an immutable encrypted note.
12
+ * Since this implementation relays signatures to an SSH agent, we provide the
13
+ * public key here not for signature verification, but to identify actual identity
14
+ * that will be used to sign authwitnesses.
15
+ */
16
+ export class EcdsaRSSHAccountContract extends DefaultAccountContract {
17
+ constructor(signingPublicKey) {
18
+ super(EcdsaRAccountContractArtifact);
19
+ this.signingPublicKey = signingPublicKey;
20
+ }
21
+ getDeploymentArgs() {
22
+ return [this.signingPublicKey.subarray(0, 32), this.signingPublicKey.subarray(32, 64)];
23
+ }
24
+ getAuthWitnessProvider(_address) {
25
+ return new SSHEcdsaRAuthWitnessProvider(this.signingPublicKey);
26
+ }
27
+ }
28
+ /** Creates auth witnesses using ECDSA signatures. */
29
+ class SSHEcdsaRAuthWitnessProvider {
30
+ constructor(signingPublicKey) {
31
+ _SSHEcdsaRAuthWitnessProvider_instances.add(this);
32
+ this.signingPublicKey = signingPublicKey;
33
+ }
34
+ async createAuthWit(messageHash) {
35
+ // Key type and curve name
36
+ const keyType = Buffer.from('ecdsa-sha2-nistp256');
37
+ const curveName = Buffer.from('nistp256');
38
+ const data = await signWithAgent(keyType, curveName, this.signingPublicKey, messageHash.toBuffer());
39
+ const signature = __classPrivateFieldGet(this, _SSHEcdsaRAuthWitnessProvider_instances, "m", _SSHEcdsaRAuthWitnessProvider_parseECDSASignature).call(this, data);
40
+ return new AuthWitness(messageHash, [...signature.r, ...signature.s]);
41
+ }
42
+ }
43
+ _SSHEcdsaRAuthWitnessProvider_instances = new WeakSet(), _SSHEcdsaRAuthWitnessProvider_parseECDSASignature = function _SSHEcdsaRAuthWitnessProvider_parseECDSASignature(data) {
44
+ // Extract ECDSA signature components
45
+ let offset = 0;
46
+ const sigTypeLen = data.readUInt32BE(offset);
47
+ offset += 4;
48
+ const sigType = data.subarray(offset, offset + sigTypeLen).toString();
49
+ offset += sigTypeLen;
50
+ if (sigType !== 'ecdsa-sha2-nistp256') {
51
+ throw new Error(`Unexpected signature type: ${sigType}`);
52
+ }
53
+ offset += 4;
54
+ const rLen = data.readUInt32BE(offset);
55
+ offset += 4;
56
+ let r = data.subarray(offset, offset + rLen);
57
+ offset += rLen;
58
+ const sLen = data.readUInt32BE(offset);
59
+ offset += 4;
60
+ let s = data.subarray(offset, offset + sLen);
61
+ // R and S are encoded using ASN.1 DER format, which may include a leading zero byte to avoid interpreting the value as negative
62
+ if (r.length > 32) {
63
+ r = Buffer.from(Uint8Array.prototype.slice.call(r, 1));
64
+ }
65
+ if (s.length > 32) {
66
+ s = Buffer.from(Uint8Array.prototype.slice.call(s, 1));
67
+ }
68
+ const maybeHighS = BigInt(`0x${s.toString('hex')}`);
69
+ // ECDSA signatures must have a low S value so they can be used as a nullifier. BB forces a value of 27 for v, so
70
+ // only one PublicKey can verify the signature (and not its negated counterpart) https://ethereum.stackexchange.com/a/55728
71
+ if (maybeHighS > secp256r1N / 2n + 1n) {
72
+ s = Buffer.from((secp256r1N - maybeHighS).toString(16), 'hex');
73
+ }
74
+ return new EcdsaSignature(r, s, Buffer.from([0]));
75
+ };
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNjb3VudF9jb250cmFjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lY2RzYS9zc2hfZWNkc2Ffci9hY2NvdW50X2NvbnRyYWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQ0EsT0FBTyxFQUFFLFdBQVcsRUFBd0IsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFJakUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDNUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3pELE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU5RCxNQUFNLFVBQVUsR0FBRywrRUFBK0UsQ0FBQztBQUNuRzs7Ozs7O0dBTUc7QUFDSCxNQUFNLE9BQU8sd0JBQXlCLFNBQVEsc0JBQXNCO0lBQ2xFLFlBQW9CLGdCQUF3QjtRQUMxQyxLQUFLLENBQUMsNkJBQWlELENBQUMsQ0FBQztRQUR2QyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQVE7SUFFNUMsQ0FBQztJQUVELGlCQUFpQjtRQUNmLE9BQU8sQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsUUFBUSxDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQ3pGLENBQUM7SUFFRCxzQkFBc0IsQ0FBQyxRQUF5QjtRQUM5QyxPQUFPLElBQUksNEJBQTRCLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUM7SUFDakUsQ0FBQztDQUNGO0FBRUQscURBQXFEO0FBQ3JELE1BQU0sNEJBQTRCO0lBQ2hDLFlBQW9CLGdCQUF3Qjs7UUFBeEIscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFRO0lBQUcsQ0FBQztJQTRDaEQsS0FBSyxDQUFD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
@@ -0,0 +1,2 @@
1
+ export declare const EcdsaRAccountContractArtifact: import("@aztec/aztec.js").ContractArtifact;
2
+ //# sourceMappingURL=artifact.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"artifact.d.ts","sourceRoot":"","sources":["../../../src/ecdsa/ssh_ecdsa_r/artifact.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,6BAA6B,4CAA0E,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { loadContractArtifact } from '@aztec/aztec.js';
2
+ import EcdsaRAccountContractJson from '../../../artifacts/EcdsaRAccount.json' assert { type: 'json' };
3
+ export const EcdsaRAccountContractArtifact = loadContractArtifact(EcdsaRAccountContractJson);
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJ0aWZhY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWNkc2Evc3NoX2VjZHNhX3IvYXJ0aWZhY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUE2QixvQkFBb0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRWxGLE9BQU8seUJBQXlCLE1BQU0sdUNBQXVDLENBQUMsU0FBUyxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUM7QUFFdEcsTUFBTSxDQUFDLE1BQU0sNkJBQTZCLEdBQUcsb0JBQW9CLENBQUMseUJBQWlELENBQUMsQ0FBQyJ9
@@ -0,0 +1,31 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ /**
3
+ * The `@aztec/accounts/ecdsa` export provides an ECDSA account contract implementation, that uses an ECDSA private key for authentication, and a Grumpkin key for encryption.
4
+ * Consider using this account type when working with integrations with Ethereum wallets.
5
+ *
6
+ * @packageDocumentation
7
+ */
8
+ import { AccountManager, type Salt } from '@aztec/aztec.js/account';
9
+ import { type AccountWallet } from '@aztec/aztec.js/wallet';
10
+ import { type PXE } from '@aztec/circuit-types';
11
+ import { type AztecAddress, type Fr } from '@aztec/circuits.js';
12
+ import { EcdsaRSSHAccountContract } from './account_contract.js';
13
+ export { EcdsaRAccountContractArtifact } from './artifact.js';
14
+ export { EcdsaRSSHAccountContract };
15
+ /**
16
+ * Creates an Account that relies on an ECDSA signing key for authentication.
17
+ * @param pxe - An PXE server instance.
18
+ * @param secretKey - Secret key used to derive all the keystore keys.
19
+ * @param signingPublicKey - Secp2561 key used to identify its corresponding private key in the SSH Agent.
20
+ * @param salt - Deployment salt.
21
+ */
22
+ export declare function getEcdsaRSSHAccount(pxe: PXE, secretKey: Fr, signingPublicKey: Buffer, salt?: Salt): AccountManager;
23
+ /**
24
+ * Gets a wallet for an already registered account using ECDSA signatures.
25
+ * @param pxe - An PXE server instance.
26
+ * @param address - Address for the account.
27
+ * @param signingPrivateKey - ECDSA key used for signing transactions.
28
+ * @returns A wallet for this account that can be used to interact with a contract instance.
29
+ */
30
+ export declare function getEcdsaRSSHWallet(pxe: PXE, address: AztecAddress, signingPublicKey: Buffer): Promise<AccountWallet>;
31
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/ecdsa/ssh_ecdsa_r/index.ts"],"names":[],"mappings":";AAAA;;;;;GAKG;AACH,OAAO,EAAE,cAAc,EAAE,KAAK,IAAI,EAAE,MAAM,yBAAyB,CAAC;AACpE,OAAO,EAAE,KAAK,aAAa,EAAa,MAAM,wBAAwB,CAAC;AACvE,OAAO,EAAE,KAAK,GAAG,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,EAAE,EAAE,MAAM,oBAAoB,CAAC;AAEhE,OAAO,EAAE,wBAAwB,EAAE,MAAM,uBAAuB,CAAC;AAEjE,OAAO,EAAE,6BAA6B,EAAE,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAE,wBAAwB,EAAE,CAAC;AAEpC;;;;;;GAMG;AACH,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,EAAE,EAAE,gBAAgB,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,IAAI,GAAG,cAAc,CAElH;AAED;;;;;;GAMG;AACH,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,CAAC,CAEpH"}
@@ -0,0 +1,32 @@
1
+ /**
2
+ * The `@aztec/accounts/ecdsa` export provides an ECDSA account contract implementation, that uses an ECDSA private key for authentication, and a Grumpkin key for encryption.
3
+ * Consider using this account type when working with integrations with Ethereum wallets.
4
+ *
5
+ * @packageDocumentation
6
+ */
7
+ import { AccountManager } from '@aztec/aztec.js/account';
8
+ import { getWallet } from '@aztec/aztec.js/wallet';
9
+ import { EcdsaRSSHAccountContract } from './account_contract.js';
10
+ export { EcdsaRAccountContractArtifact } from './artifact.js';
11
+ export { EcdsaRSSHAccountContract };
12
+ /**
13
+ * Creates an Account that relies on an ECDSA signing key for authentication.
14
+ * @param pxe - An PXE server instance.
15
+ * @param secretKey - Secret key used to derive all the keystore keys.
16
+ * @param signingPublicKey - Secp2561 key used to identify its corresponding private key in the SSH Agent.
17
+ * @param salt - Deployment salt.
18
+ */
19
+ export function getEcdsaRSSHAccount(pxe, secretKey, signingPublicKey, salt) {
20
+ return new AccountManager(pxe, secretKey, new EcdsaRSSHAccountContract(signingPublicKey), salt);
21
+ }
22
+ /**
23
+ * Gets a wallet for an already registered account using ECDSA signatures.
24
+ * @param pxe - An PXE server instance.
25
+ * @param address - Address for the account.
26
+ * @param signingPrivateKey - ECDSA key used for signing transactions.
27
+ * @returns A wallet for this account that can be used to interact with a contract instance.
28
+ */
29
+ export function getEcdsaRSSHWallet(pxe, address, signingPublicKey) {
30
+ return getWallet(pxe, address, new EcdsaRSSHAccountContract(signingPublicKey));
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWNkc2Evc3NoX2VjZHNhX3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7O0dBS0c7QUFDSCxPQUFPLEVBQUUsY0FBYyxFQUFhLE1BQU0seUJBQXlCLENBQUM7QUFDcEUsT0FBTyxFQUFzQixTQUFTLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUl2RSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVqRSxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLENBQUM7QUFFcEM7Ozs7OztHQU1HO0FBQ0gsTUFBTSxVQUFVLG1CQUFtQixDQUFDLEdBQVEsRUFBRSxTQUFhLEVBQUUsZ0JBQXdCLEVBQUUsSUFBVztJQUNoRyxPQUFPLElBQUksY0FBYyxDQUFDLEdBQUcsRUFBRSxTQUFTLEVBQUUsSUFBSSx3QkFBd0IsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0FBQ2xHLENBQUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxNQUFNLFVBQVUsa0JBQWtCLENBQUMsR0FBUSxFQUFFLE9BQXFCLEVBQUUsZ0JBQXdCO0lBQzFGLE9BQU8sU0FBUyxDQUFDLEdBQUcsRUFBRSxPQUFPLEVBQUUsSUFBSSx3QkFBd0IsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQUM7QUFDakYsQ0FBQyJ9
@@ -0,0 +1,2 @@
1
+ export * from './ssh_agent.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './ssh_agent.js';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxnQkFBZ0IsQ0FBQyJ9
@@ -0,0 +1,35 @@
1
+ /// <reference types="node" resolution-mode="require"/>
2
+ /// <reference types="node" resolution-mode="require"/>
3
+ import { Buffer } from 'buffer';
4
+ import net from 'net';
5
+ /**
6
+ * Connect to the SSH agent via a TCP socket using the standard env variable
7
+ */
8
+ export declare function connectToAgent(): net.Socket;
9
+ /**
10
+ * Type representing a stored key in the SSH agent.
11
+ */
12
+ type StoredKey = {
13
+ /**
14
+ * Type of the key.
15
+ */
16
+ type: string;
17
+ /**
18
+ * Public key in base64 encoding.
19
+ */
20
+ publicKey: string;
21
+ /**
22
+ * Comment associated with the key.
23
+ */
24
+ comment: string;
25
+ };
26
+ /**
27
+ * Retrieve the identities stored in the SSH agent.
28
+ */
29
+ export declare function getIdentities(): Promise<StoredKey[]>;
30
+ /**
31
+ * Sign data using a key stored in the SSH agent. The private signing key is identified by its corresponding public key.
32
+ */
33
+ export declare function signWithAgent(keyType: Buffer, curveName: Buffer, publicKey: Buffer, data: Buffer): Promise<Buffer>;
34
+ export {};
35
+ //# sourceMappingURL=ssh_agent.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ssh_agent.d.ts","sourceRoot":"","sources":["../../src/utils/ssh_agent.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,GAAG,MAAM,KAAK,CAAC;AAOtB;;GAEG;AACH,wBAAgB,cAAc,eAM7B;AAED;;GAEG;AACH,KAAK,SAAS,GAAG;IACf;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;OAEG;IACH,SAAS,EAAE,MAAM,CAAC;IAClB;;OAEG;IACH,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF;;GAEG;AACH,wBAAgB,aAAa,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC,CAkDpD;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,mBAwChG"}
@@ -0,0 +1,109 @@
1
+ import { Buffer } from 'buffer';
2
+ import net from 'net';
3
+ const SSH_AGENT_IDENTITIES_REQUEST = 11;
4
+ const SSH_AGENT_IDENTITIES_RESPONSE = 12;
5
+ const SSH_AGENT_SIGN_REQUEST = 13;
6
+ const SSH_AGENT_SIGN_RESPONSE = 14;
7
+ /**
8
+ * Connect to the SSH agent via a TCP socket using the standard env variable
9
+ */
10
+ export function connectToAgent() {
11
+ const socketPath = process.env.SSH_AUTH_SOCK;
12
+ if (!socketPath) {
13
+ throw new Error('SSH_AUTH_SOCK is not set');
14
+ }
15
+ return net.connect(socketPath);
16
+ }
17
+ /**
18
+ * Retrieve the identities stored in the SSH agent.
19
+ */
20
+ export function getIdentities() {
21
+ return new Promise((resolve, reject) => {
22
+ const stream = connectToAgent();
23
+ stream.on('connect', () => {
24
+ const request = Buffer.concat([
25
+ Buffer.from([0, 0, 0, 5 + 4]), // length
26
+ Buffer.from([SSH_AGENT_IDENTITIES_REQUEST]),
27
+ Buffer.from([0, 0, 0, 0]), // flags
28
+ ]);
29
+ stream.write(request);
30
+ });
31
+ stream.on('data', data => {
32
+ const responseType = data[4];
33
+ if (responseType === SSH_AGENT_IDENTITIES_RESPONSE) {
34
+ let offset = 5;
35
+ const numKeys = data.readUInt32BE(offset);
36
+ offset += 4;
37
+ const keys = [];
38
+ for (let i = 0; i < numKeys; i++) {
39
+ const keyLength = data.readUInt32BE(offset);
40
+ offset += 4;
41
+ const key = data.subarray(offset, offset + keyLength);
42
+ offset += keyLength;
43
+ const commentLength = data.readUInt32BE(offset);
44
+ offset += 4;
45
+ const comment = data.subarray(offset, offset + commentLength);
46
+ offset += commentLength;
47
+ let keyOffset = 0;
48
+ const typeLen = key.readUInt32BE(keyOffset);
49
+ keyOffset += 4;
50
+ const type = key.subarray(keyOffset, keyOffset + typeLen);
51
+ keys.push({
52
+ type: type.toString('ascii'),
53
+ publicKey: key.toString('base64'),
54
+ comment: comment.toString('utf8'),
55
+ });
56
+ }
57
+ stream.end();
58
+ resolve(keys);
59
+ }
60
+ else {
61
+ stream.end();
62
+ reject(`Unexpected response type: ${responseType}`);
63
+ }
64
+ });
65
+ });
66
+ }
67
+ /**
68
+ * Sign data using a key stored in the SSH agent. The private signing key is identified by its corresponding public key.
69
+ */
70
+ export function signWithAgent(keyType, curveName, publicKey, data) {
71
+ return new Promise((resolve, reject) => {
72
+ const stream = connectToAgent();
73
+ stream.on('connect', () => {
74
+ // Construct the key blob
75
+ const keyBlob = Buffer.concat([
76
+ Buffer.from([0, 0, 0, keyType.length]),
77
+ keyType,
78
+ Buffer.from([0, 0, 0, curveName.length]),
79
+ curveName,
80
+ Buffer.from([0, 0, 0, publicKey.length + 1, 4]),
81
+ publicKey,
82
+ ]);
83
+ const request = Buffer.concat([
84
+ Buffer.from([0, 0, 0, 5 + keyBlob.length + 4 + data.length + 4]), // length
85
+ Buffer.from([SSH_AGENT_SIGN_REQUEST]),
86
+ Buffer.from([0, 0, 0, keyBlob.length]), // key blob length
87
+ keyBlob,
88
+ Buffer.from([0, 0, 0, data.length]), // data length
89
+ data,
90
+ Buffer.from([0, 0, 0, 0]), // flags
91
+ ]);
92
+ stream.write(request);
93
+ });
94
+ stream.on('data', data => {
95
+ const type = data[4];
96
+ if (type === SSH_AGENT_SIGN_RESPONSE) {
97
+ const signatureLength = data.readUInt32BE(5);
98
+ const signature = data.subarray(9, 9 + signatureLength);
99
+ stream.end();
100
+ resolve(signature);
101
+ }
102
+ else {
103
+ stream.end();
104
+ reject(`Unexpected response type: ${type}`);
105
+ }
106
+ });
107
+ });
108
+ }
109
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3NoX2FnZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3V0aWxzL3NzaF9hZ2VudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBQ2hDLE9BQU8sR0FBRyxNQUFNLEtBQUssQ0FBQztBQUV0QixNQUFNLDRCQUE0QixHQUFHLEVBQUUsQ0FBQztBQUN4QyxNQUFNLDZCQUE2QixHQUFHLEVBQUUsQ0FBQztBQUN6QyxNQUFNLHNCQUFzQixHQUFHLEVBQUUsQ0FBQztBQUNsQyxNQUFNLHVCQUF1QixHQUFHLEVBQUUsQ0FBQztBQUVuQzs7R0FFRztBQUNILE1BQU0sVUFBVSxjQUFjO0lBQzVCLE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDO0lBQzdDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNoQixNQUFNLElBQUksS0FBSyxDQUFDLDBCQUEwQixDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUNELE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsQ0FBQztBQUNqQyxDQUFDO0FBb0JEOztHQUVHO0FBQ0gsTUFBTSxVQUFVLGFBQWE7SUFDM0IsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUNyQyxNQUFNLE1BQU0sR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUNoQyxNQUFNLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUU7WUFDeEIsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQztnQkFDNUIsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLFNBQVM7Z0JBQ3hDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyw0QkFBNEIsQ0FBQyxDQUFDO2dCQUMzQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRO2FBQ3BDLENBQUMsQ0FBQztZQUVILE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDeEIsQ0FBQyxDQUFDLENBQUM7UUFFSCxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRTtZQUN2QixNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDN0IsSUFBSSxZQUFZLEtBQUssNkJBQTZCLEVBQUUsQ0FBQztnQkFDbkQsSUFBSSxNQUFNLEdBQUcsQ0FBQyxDQUFDO2dCQUNmLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQzFDLE1BQU0sSUFBSSxDQUFDLENBQUM7Z0JBRVosTUFBTSxJQUFJLEdBQUcsRUFBRSxDQUFDO2dCQUNoQixLQUFLLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsT0FBTyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUM7b0JBQ2pDLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLENBQUM7b0JBQzVDLE1BQU0sSUFBSSxDQUFDLENBQUM7b0JBQ1osTUFBTSxHQUFHLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsTUFBTSxHQUFHLFNBQVMsQ0FBQyxDQUFDO29CQUN0RCxNQUFNLElBQUksU0FBUyxDQUFDO29CQUNwQixNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxDQUFDO29CQUNoRCxNQUFNLElBQUksQ0FBQyxDQUFDO29CQUNaLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxhQUFhLENBQUMsQ0FBQztvQkFDOUQsTUFBTSxJQUFJLGFBQWEsQ0FBQztvQkFFeEIsSUFBSSxTQUFTLEdBQUcsQ0FBQyxDQUFDO29CQUNsQixNQUFNLE9BQU8sR0FBRyxHQUFHLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxDQUFDO29CQUM1QyxTQUFTLElBQUksQ0FBQyxDQUFDO29CQUNmLE1BQU0sSUFBSSxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLFNBQVMsR0FBRyxPQUFPLENBQUMsQ0FBQztvQkFFMUQsSUFBSSxDQUFDLElBQUksQ0FBQzt3QkFDUixJQUFJLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUM7d0JBQzVCLFNBQVMsRUFBRSxHQUFHLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQzt3QkFDakMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDO3FCQUNsQyxDQUFDLENBQUM7Z0JBQ0wsQ0FBQztnQkFDRCxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUM7Z0JBQ2IsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQ2hCLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLENBQUMsR0FBRyxFQUFFLENBQUM7Z0JBQ2IsTUFBTSxDQUFDLDZCQUE2QixZQUFZLEVBQUUsQ0FBQyxDQUFDO1lBQ3RELENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxVQUFVLGFBQWEsQ0FBQyxPQUFlLEVBQUUsU0FBaUIsRUFBRSxTQUFpQixFQUFFLElBQVk7SUFDL0YsT0FBTyxJQUFJLE9BQU8sQ0FBUyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUM3QyxNQUFNLE1BQU0sR0FBRyxjQUFjLEVBQUUsQ0FBQztRQUNoQyxNQUFNLENBQUMsRUFBRSxDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUU7WUFDeEIseUJBQXlCO1lBQ3pCLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7Z0JBQzVCLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQ3RDLE9BQU87Z0JBQ1AsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFDeEMsU0FBUztnQkFDVCxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsU0FBUyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7Z0JBQy9DLFNBQVM7YUFDVixDQUFDLENBQUM7WUFDSCxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO2dCQUM1QixNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxTQUFTO2dCQUMzRSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsc0JBQXNCLENBQUMsQ0FBQztnQkFDckMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLGtCQUFrQjtnQkFDMUQsT0FBTztnQkFDUCxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsY0FBYztnQkFDbkQsSUFBSTtnQkFDSixNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRO2FBQ3BDLENBQUMsQ0FBQztZQUVILE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDeEIsQ0FBQyxDQUFDLENBQUM7UUFFSCxNQUFNLENBQUMsRUFBRSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsRUFBRTtZQUN2QixNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFFckIsSUFBSSxJQUFJLEtBQUssdUJBQXVCLEVBQUUsQ0FBQztnQkFDckMsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDN0MsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLGVBQWUsQ0FBQyxDQUFDO2dCQUN4RCxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUM7Z0JBQ2IsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3JCLENBQUM7aUJBQU0sQ0FBQztnQkFDTixNQUFNLENBQUMsR0FBRyxFQUFFLENBQUM7Z0JBQ2IsTUFBTSxDQUFDLDZCQUE2QixJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBQzlDLENBQUM7UUFDSCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUMsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyJ9
package/package.json CHANGED
@@ -2,14 +2,15 @@
2
2
  "name": "@aztec/accounts",
3
3
  "homepage": "https://github.com/AztecProtocol/aztec-packages/tree/master/yarn-project/accounts",
4
4
  "description": "Implementation of sample account contracts for Aztec Network",
5
- "version": "0.47.0",
5
+ "version": "0.48.0",
6
6
  "type": "module",
7
7
  "exports": {
8
8
  "./defaults": "./dest/defaults/index.js",
9
9
  "./ecdsa": "./dest/ecdsa/index.js",
10
10
  "./schnorr": "./dest/schnorr/index.js",
11
11
  "./single_key": "./dest/single_key/index.js",
12
- "./testing": "./dest/testing/index.js"
12
+ "./testing": "./dest/testing/index.js",
13
+ "./utils": "./dest/utils/index.js"
13
14
  },
14
15
  "typedocOptions": {
15
16
  "entryPoints": [
@@ -69,13 +70,13 @@
69
70
  ]
70
71
  },
71
72
  "dependencies": {
72
- "@aztec/aztec.js": "0.47.0",
73
- "@aztec/circuit-types": "0.47.0",
74
- "@aztec/circuits.js": "0.47.0",
75
- "@aztec/entrypoints": "0.47.0",
76
- "@aztec/ethereum": "0.47.0",
77
- "@aztec/foundation": "0.47.0",
78
- "@aztec/types": "0.47.0",
73
+ "@aztec/aztec.js": "0.48.0",
74
+ "@aztec/circuit-types": "0.48.0",
75
+ "@aztec/circuits.js": "0.48.0",
76
+ "@aztec/entrypoints": "0.48.0",
77
+ "@aztec/ethereum": "0.48.0",
78
+ "@aztec/foundation": "0.48.0",
79
+ "@aztec/types": "0.48.0",
79
80
  "tslib": "^2.4.0"
80
81
  },
81
82
  "devDependencies": {