aoform-toolkit 1.0.4 → 1.0.5

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
@@ -25,10 +25,14 @@ npx aoform --help
25
25
  npx aoform init
26
26
  ```
27
27
 
28
- 2. Set wallet JSON:
28
+ 2. Provide a wallet (any one of these):
29
29
 
30
30
  ```bash
31
- export WALLET_JSON="$(cat ~/.aos.json)"
31
+ # Option A: explicit env var
32
+ WALLET_JSON="your_wallet_json"
33
+
34
+ # Option B: local wallet.json in your project
35
+ ./wallet.json #at the root of your project
32
36
  ```
33
37
 
34
38
  3. Deploy processes:
@@ -49,6 +53,7 @@ npx aoform deploy
49
53
  - `-f, --file <path>` custom YAML file path.
50
54
  - `-u, --url <url>` custom HyperBEAM node URL.
51
55
  - `-s, --scheduler <scheduler>` custom scheduler.
56
+ - `--wallet-path <path>` custom wallet JSON file path.
52
57
 
53
58
  ## Configuration (`processes.yaml`)
54
59
 
@@ -71,9 +76,13 @@ Fields:
71
76
  - `module` (optional): AO module id.
72
77
  - `tags` (optional): spawn tags as `{ name, value }`.
73
78
 
74
- ## Environment Variables
79
+ ## Wallet Resolution Order
80
+
81
+ When running `aoform deploy`, wallet JSON is resolved in this order:
75
82
 
76
- - `WALLET_JSON` (required): wallet JSON string used for signing.
83
+ 1. `--wallet-path <path>`
84
+ 2. `./wallet.json` in the current working directory
85
+ 3. `WALLET_JSON` environment variable
77
86
 
78
87
  Example:
79
88
 
@@ -1 +1 @@
1
- {"version":3,"file":"createProgram.d.ts","sourceRoot":"","sources":["../../../src/cli/createProgram.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,wBAAgB,aAAa,YA4B5B"}
1
+ {"version":3,"file":"createProgram.d.ts","sourceRoot":"","sources":["../../../src/cli/createProgram.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,wBAAgB,aAAa,YA6B5B"}
@@ -18,6 +18,7 @@ export function createProgram() {
18
18
  .option('-f, --file <path>', 'Specify a custom processes.yaml file')
19
19
  .option('-u, --url <url>', 'Specify a HyperBEAM node URL')
20
20
  .option('-s, --scheduler <scheduler>', 'Specify a scheduler')
21
+ .option('--wallet-path <path>', 'Specify a custom path to the wallet file')
21
22
  .action(async (options) => {
22
23
  const { deployCommand } = await import('../commands/deploy.js');
23
24
  await deployCommand(options);
@@ -1 +1 @@
1
- {"version":3,"file":"createProgram.js","sourceRoot":"","sources":["../../../src/cli/createProgram.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,MAAM,UAAU,aAAa;IAC3B,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;IAE9B,OAAO;SACJ,IAAI,CAAC,QAAQ,CAAC;SACd,WAAW,CAAC,qCAAqC,CAAC,CAAA;IAErD,OAAO;SACJ,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,sCAAsC,CAAC;SACnD,MAAM,CAAC,mBAAmB,EAAE,8CAA8C,CAAC;SAC3E,MAAM,CAAC,KAAK,EAAE,OAAqB,EAAE,EAAE;QACtC,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC5D,MAAM,WAAW,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEL,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,4BAA4B,CAAC;SACzC,MAAM,CAAC,mBAAmB,EAAE,sCAAsC,CAAC;SACnE,MAAM,CAAC,iBAAiB,EAAE,8BAA8B,CAAC;SACzD,MAAM,CAAC,6BAA6B,EAAE,qBAAqB,CAAC;SAC5D,MAAM,CAAC,KAAK,EAAE,OAAqB,EAAE,EAAE;QACtC,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;QAChE,MAAM,aAAa,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEL,OAAO,OAAO,CAAC;AACjB,CAAC"}
1
+ {"version":3,"file":"createProgram.js","sourceRoot":"","sources":["../../../src/cli/createProgram.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAGpC,MAAM,UAAU,aAAa;IAC3B,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAC;IAE9B,OAAO;SACJ,IAAI,CAAC,QAAQ,CAAC;SACd,WAAW,CAAC,qCAAqC,CAAC,CAAA;IAErD,OAAO;SACJ,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,sCAAsC,CAAC;SACnD,MAAM,CAAC,mBAAmB,EAAE,8CAA8C,CAAC;SAC3E,MAAM,CAAC,KAAK,EAAE,OAAqB,EAAE,EAAE;QACtC,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC5D,MAAM,WAAW,CAAC,OAAO,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEL,OAAO;SACJ,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,4BAA4B,CAAC;SACzC,MAAM,CAAC,mBAAmB,EAAE,sCAAsC,CAAC;SACnE,MAAM,CAAC,iBAAiB,EAAE,8BAA8B,CAAC;SACzD,MAAM,CAAC,6BAA6B,EAAE,qBAAqB,CAAC;SAC5D,MAAM,CAAC,sBAAsB,EAAE,0CAA0C,CAAC;SAC1E,MAAM,CAAC,KAAK,EAAE,OAAqB,EAAE,EAAE;QACtC,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,MAAM,CAAC,uBAAuB,CAAC,CAAC;QAChE,MAAM,aAAa,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEL,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"deploy.d.ts","sourceRoot":"","sources":["../../../src/commands/deploy.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAE9C,eAAO,MAAM,aAAa,GAAU,SAAS,YAAY,mBASxD,CAAC"}
1
+ {"version":3,"file":"deploy.d.ts","sourceRoot":"","sources":["../../../src/commands/deploy.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAG9C,eAAO,MAAM,aAAa,GAAU,SAAS,YAAY,mBA4BxD,CAAC"}
@@ -1,7 +1,27 @@
1
1
  import { deployProcesses } from '../core/deploy/index.js';
2
+ import { readFile, access } from 'node:fs/promises';
2
3
  export const deployCommand = async (options) => {
3
4
  try {
4
- await deployProcesses({ file: options.file, url: options.url, scheduler: options.scheduler });
5
+ const walletPath = options.walletPath;
6
+ let walletJson;
7
+ if (walletPath) {
8
+ walletJson = await readFile(walletPath, 'utf-8');
9
+ }
10
+ else {
11
+ try {
12
+ await access('wallet.json');
13
+ walletJson = await readFile('wallet.json', 'utf-8');
14
+ }
15
+ catch {
16
+ // If wallet.json is missing, deploy core will use existing WALLET_JSON env or throw.
17
+ }
18
+ }
19
+ await deployProcesses({
20
+ file: options.file,
21
+ url: options.url,
22
+ scheduler: options.scheduler,
23
+ walletJson
24
+ });
5
25
  process.exit(0);
6
26
  }
7
27
  catch (err) {
@@ -1 +1 @@
1
- {"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../../src/commands/deploy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAG1D,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;IAE3D,IAAI,CAAC;QACH,MAAM,eAAe,CAAC,EAAC,IAAI,EAAC,OAAO,CAAC,IAA0B,EAAE,GAAG,EAAC,OAAO,CAAC,GAAyB,EAAE,SAAS,EAAC,OAAO,CAAC,SAA+B,EAAC,CAAC,CAAC;QAC3J,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,4BAA4B,EAAE,GAAG,CAAC,CAAC;QACjD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC"}
1
+ {"version":3,"file":"deploy.js","sourceRoot":"","sources":["../../../src/commands/deploy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAC;AAEpD,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,EAAE,OAAqB,EAAE,EAAE;IAE3D,IAAI,CAAC;QACH,MAAM,UAAU,GAAG,OAAO,CAAC,UAAgC,CAAC;QAC5D,IAAI,UAA8B,CAAC;QAEnC,IAAI,UAAU,EAAE,CAAC;YACf,UAAU,GAAG,MAAM,QAAQ,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QACnD,CAAC;aAAM,CAAC;YACN,IAAI,CAAC;gBACH,MAAM,MAAM,CAAC,aAAa,CAAC,CAAC;gBAC5B,UAAU,GAAG,MAAM,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;YACtD,CAAC;YAAC,MAAM,CAAC;gBACP,qFAAqF;YACvF,CAAC;QACH,CAAC;QAED,MAAM,eAAe,CAAC;YACpB,IAAI,EAAE,OAAO,CAAC,IAA0B;YACxC,GAAG,EAAE,OAAO,CAAC,GAAyB;YACtC,SAAS,EAAE,OAAO,CAAC,SAA+B;YAClD,UAAU;SACX,CAAC,CAAC;QACH,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,CAAC,KAAK,CAAC,4BAA4B,EAAE,GAAG,CAAC,CAAC;QACjD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC"}
@@ -1,6 +1,7 @@
1
- export declare function deployProcesses({ file, url, scheduler }: {
1
+ export declare function deployProcesses({ file, url, scheduler, walletJson }: {
2
2
  file?: string;
3
3
  url?: string;
4
4
  scheduler?: string;
5
+ walletJson?: string;
5
6
  }): Promise<void>;
6
7
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/core/deploy/index.ts"],"names":[],"mappings":"AAUA,wBAAsB,eAAe,CAAC,EAAC,IAAI,EAAE,GAAG,EAAE,SAAS,EAAC,EAAE;IAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,GAAG,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAA;CAAC,iBAgC9G"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/core/deploy/index.ts"],"names":[],"mappings":"AAUA,wBAAsB,eAAe,CAAC,EAAC,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,UAAU,EAAC,EAAE;IAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,GAAG,CAAC,EAAE,MAAM,CAAC;IAAC,SAAS,CAAC,EAAE,MAAM,CAAC;IAAC,UAAU,CAAC,EAAE,MAAM,CAAA;CAAC,iBAkC/I"}
@@ -5,11 +5,12 @@ import { spawnProcess } from './spawnProcess.js';
5
5
  import { deploySource } from './deploySource.js';
6
6
  import { default_hb_url, default_scheduler } from '../../constants.js';
7
7
  dotenv.config();
8
- export async function deployProcesses({ file, url, scheduler }) {
9
- if (!process.env.WALLET_JSON) {
10
- throw new Error('Missing WALLET_JSON environment variable. Please provide wallet JSON in WALLET_JSON.');
8
+ export async function deployProcesses({ file, url, scheduler, walletJson }) {
9
+ const resolvedWalletJson = walletJson ?? process.env.WALLET_JSON;
10
+ if (!resolvedWalletJson) {
11
+ throw new Error('Missing WALLET_JSON environment variable. Please provide wallet JSON via WALLET_JSON env var, specify --wallet-path flag, or create a wallet.json file at the root of your project.');
11
12
  }
12
- const wallet = JSON.parse(process.env.WALLET_JSON);
13
+ const wallet = JSON.parse(resolvedWalletJson);
13
14
  const signer = createDataItemSigner(wallet);
14
15
  const processes = loadProcesses(file);
15
16
  const state = loadState(file);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/deploy/index.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAGvE,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,EAAC,IAAI,EAAE,GAAG,EAAE,SAAS,EAAoD;IAE7G,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,sFAAsF,CAAC,CAAC;IAC1G,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,WAAW,CAAY,CAAC;IAC9D,MAAM,MAAM,GAAG,oBAAoB,CAAC,MAAa,CAAC,CAAC;IAEnD,MAAM,SAAS,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACtC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;IAE9B,MAAM,EAAE,GAAG,OAAO,CAChB;QACE,IAAI,EAAE,SAAS;QACf,SAAS,EAAC,SAAS,IAAI,iBAAiB;QACxC,GAAG,EAAE,GAAG,IAAI,cAAc;QAC1B,MAAM;KACP,CACF,CAAC;IAEF,MAAM,SAAS,GAAqB,EAAE,CAAC;IAEvC,KAAK,MAAM,WAAW,IAAI,SAAS,EAAE,CAAC;QACpC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,MAAM,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;IACtF,CAAC;IAED,KAAK,MAAM,WAAW,IAAI,SAAS,EAAE,CAAC;QACpC,MAAM,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;IACxD,CAAC;IAED,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AACzB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/core/deploy/index.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AACpE,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAGvE,MAAM,CAAC,MAAM,EAAE,CAAC;AAEhB,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,EAAC,IAAI,EAAE,GAAG,EAAE,SAAS,EAAE,UAAU,EAAyE;IAE9I,MAAM,kBAAkB,GAAG,UAAU,IAAI,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC;IAEjE,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACxB,MAAM,IAAI,KAAK,CAAC,qLAAqL,CAAC,CAAC;IACzM,CAAC;IAED,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAY,CAAC;IACzD,MAAM,MAAM,GAAG,oBAAoB,CAAC,MAAa,CAAC,CAAC;IAEnD,MAAM,SAAS,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;IACtC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;IAE9B,MAAM,EAAE,GAAG,OAAO,CAChB;QACE,IAAI,EAAE,SAAS;QACf,SAAS,EAAC,SAAS,IAAI,iBAAiB;QACxC,GAAG,EAAE,GAAG,IAAI,cAAc;QAC1B,MAAM;KACP,CACF,CAAC;IAEF,MAAM,SAAS,GAAqB,EAAE,CAAC;IAEvC,KAAK,MAAM,WAAW,IAAI,SAAS,EAAE,CAAC;QACpC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,MAAM,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;IACtF,CAAC;IAED,KAAK,MAAM,WAAW,IAAI,SAAS,EAAE,CAAC;QACpC,MAAM,YAAY,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;IACxD,CAAC;IAED,SAAS,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;AACzB,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "aoform-toolkit",
3
- "version": "1.0.4",
3
+ "version": "1.0.5",
4
4
  "description": "CLI toolkit to deploy and update AO processes from YAML configs",
5
5
  "keywords": [
6
6
  "ao",