@layr-labs/ecloud-cli 0.2.0 → 0.2.2-dev

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 (48) hide show
  1. package/VERSION +2 -2
  2. package/dist/commands/auth/whoami.js +16 -3
  3. package/dist/commands/auth/whoami.js.map +1 -1
  4. package/dist/commands/billing/cancel.js +44 -5
  5. package/dist/commands/billing/cancel.js.map +1 -1
  6. package/dist/commands/billing/status.js +44 -5
  7. package/dist/commands/billing/status.js.map +1 -1
  8. package/dist/commands/billing/subscribe.js +44 -5
  9. package/dist/commands/billing/subscribe.js.map +1 -1
  10. package/dist/commands/compute/app/create.js +16 -3
  11. package/dist/commands/compute/app/create.js.map +1 -1
  12. package/dist/commands/compute/app/deploy.js +120 -25
  13. package/dist/commands/compute/app/deploy.js.map +1 -1
  14. package/dist/commands/compute/app/info.js +124 -35
  15. package/dist/commands/compute/app/info.js.map +1 -1
  16. package/dist/commands/compute/app/list.js +78 -17
  17. package/dist/commands/compute/app/list.js.map +1 -1
  18. package/dist/commands/compute/app/logs.js +69 -28
  19. package/dist/commands/compute/app/logs.js.map +1 -1
  20. package/dist/commands/compute/app/profile/set.js +109 -40
  21. package/dist/commands/compute/app/profile/set.js.map +1 -1
  22. package/dist/commands/compute/app/releases.js +82 -120
  23. package/dist/commands/compute/app/releases.js.map +1 -1
  24. package/dist/commands/compute/app/start.js +77 -35
  25. package/dist/commands/compute/app/start.js.map +1 -1
  26. package/dist/commands/compute/app/stop.js +77 -35
  27. package/dist/commands/compute/app/stop.js.map +1 -1
  28. package/dist/commands/compute/app/terminate.js +77 -35
  29. package/dist/commands/compute/app/terminate.js.map +1 -1
  30. package/dist/commands/compute/app/upgrade.js +117 -39
  31. package/dist/commands/compute/app/upgrade.js.map +1 -1
  32. package/dist/commands/compute/build/info.js +56 -16
  33. package/dist/commands/compute/build/info.js.map +1 -1
  34. package/dist/commands/compute/build/list.js +72 -67
  35. package/dist/commands/compute/build/list.js.map +1 -1
  36. package/dist/commands/compute/build/logs.js +55 -13
  37. package/dist/commands/compute/build/logs.js.map +1 -1
  38. package/dist/commands/compute/build/status.js +55 -13
  39. package/dist/commands/compute/build/status.js.map +1 -1
  40. package/dist/commands/compute/build/submit.js +68 -9
  41. package/dist/commands/compute/build/submit.js.map +1 -1
  42. package/dist/commands/compute/build/verify.js +55 -13
  43. package/dist/commands/compute/build/verify.js.map +1 -1
  44. package/dist/commands/compute/environment/set.js +20 -7
  45. package/dist/commands/compute/environment/set.js.map +1 -1
  46. package/dist/commands/compute/undelegate.js +46 -10
  47. package/dist/commands/compute/undelegate.js.map +1 -1
  48. package/package.json +2 -2
@@ -14,9 +14,9 @@ import fs3 from "fs";
14
14
  import path3 from "path";
15
15
  import os3 from "os";
16
16
  import { isAddress as isAddress2 } from "viem";
17
- import { privateKeyToAccount as privateKeyToAccount2 } from "viem/accounts";
17
+ import { privateKeyToAccount as privateKeyToAccount3 } from "viem/accounts";
18
18
  import {
19
- getEnvironmentConfig,
19
+ getEnvironmentConfig as getEnvironmentConfig2,
20
20
  getAvailableEnvironments,
21
21
  isEnvironmentAvailable,
22
22
  getAllAppsByDeveloper as getAllAppsByDeveloper2,
@@ -33,12 +33,43 @@ import {
33
33
 
34
34
  // src/utils/appResolver.ts
35
35
  import { isAddress } from "viem";
36
- import { privateKeyToAccount } from "viem/accounts";
36
+ import { privateKeyToAccount as privateKeyToAccount2 } from "viem/accounts";
37
37
  import {
38
38
  UserApiClient,
39
39
  getAllAppsByDeveloper
40
40
  } from "@layr-labs/ecloud-sdk";
41
41
 
42
+ // src/utils/viemClients.ts
43
+ import {
44
+ createPublicClient,
45
+ http
46
+ } from "viem";
47
+ import { privateKeyToAccount } from "viem/accounts";
48
+ import {
49
+ getEnvironmentConfig,
50
+ addHexPrefix,
51
+ createViemClients as sdkCreateViemClients,
52
+ getChainFromID
53
+ } from "@layr-labs/ecloud-sdk";
54
+ function createViemClients(options) {
55
+ const privateKey = addHexPrefix(options.privateKey);
56
+ const environmentConfig = getEnvironmentConfig(options.environment);
57
+ const rpcUrl = options.rpcUrl || environmentConfig.defaultRPCURL;
58
+ const chain = getChainFromID(environmentConfig.chainID);
59
+ const { publicClient, walletClient } = sdkCreateViemClients({
60
+ privateKey,
61
+ rpcUrl,
62
+ chainId: environmentConfig.chainID
63
+ });
64
+ const account = privateKeyToAccount(privateKey);
65
+ return {
66
+ publicClient,
67
+ walletClient,
68
+ chain,
69
+ address: account.address
70
+ };
71
+ }
72
+
42
73
  // src/utils/globalConfig.ts
43
74
  import * as fs from "fs";
44
75
  import * as path from "path";
@@ -125,7 +156,7 @@ var APPS_DIR = path2.join(CONFIG_DIR, "apps");
125
156
 
126
157
  // src/utils/version.ts
127
158
  function getCliVersion() {
128
- return true ? "0.2.0" : "0.0.0";
159
+ return true ? "0.2.2-dev" : "0.0.0";
129
160
  }
130
161
  function getClientId() {
131
162
  return `ecloud-cli/v${getCliVersion()}`;
@@ -199,7 +230,7 @@ async function getPrivateKeyInteractive(privateKey) {
199
230
  async function getEnvironmentInteractive(environment) {
200
231
  if (environment) {
201
232
  try {
202
- getEnvironmentConfig(environment);
233
+ getEnvironmentConfig2(environment);
203
234
  if (!isEnvironmentAvailable(environment)) {
204
235
  throw new Error(`Environment ${environment} is not available in this build`);
205
236
  }
@@ -212,7 +243,7 @@ async function getEnvironmentInteractive(environment) {
212
243
  const configDefaultEnv = getDefaultEnvironment();
213
244
  if (configDefaultEnv && availableEnvs.includes(configDefaultEnv)) {
214
245
  try {
215
- getEnvironmentConfig(configDefaultEnv);
246
+ getEnvironmentConfig2(configDefaultEnv);
216
247
  defaultEnv = configDefaultEnv;
217
248
  } catch {
218
249
  }
@@ -279,16 +310,27 @@ import {
279
310
  createComputeModule,
280
311
  createBillingModule,
281
312
  createBuildModule,
282
- getEnvironmentConfig as getEnvironmentConfig2,
313
+ getEnvironmentConfig as getEnvironmentConfig3,
283
314
  requirePrivateKey,
284
315
  getPrivateKeyWithSource
285
316
  } from "@layr-labs/ecloud-sdk";
286
317
  async function createBuildClient(flags) {
287
318
  flags = await validateCommonFlags(flags, { requirePrivateKey: false });
319
+ const environment = flags.environment || "mainnet";
320
+ const environmentConfig = getEnvironmentConfig3(environment);
321
+ const rpcUrl = flags["rpc-url"] || environmentConfig.defaultRPCURL;
322
+ let walletClient;
323
+ if (flags["private-key"]) {
324
+ walletClient = createViemClients({
325
+ privateKey: flags["private-key"],
326
+ rpcUrl,
327
+ environment
328
+ }).walletClient;
329
+ }
288
330
  return createBuildModule({
289
331
  verbose: flags.verbose,
290
- privateKey: flags["private-key"],
291
- environment: flags.environment,
332
+ walletClient,
333
+ environment,
292
334
  clientId: getClientId(),
293
335
  skipTelemetry: true
294
336
  // CLI already has telemetry, skip SDK telemetry
@@ -371,8 +413,8 @@ function formatSourceLink(repoUrl, gitRef) {
371
413
  }
372
414
 
373
415
  // src/commands/compute/build/verify.ts
374
- import { privateKeyToAccount as privateKeyToAccount3 } from "viem/accounts";
375
- import { addHexPrefix } from "@layr-labs/ecloud-sdk";
416
+ import { privateKeyToAccount as privateKeyToAccount4 } from "viem/accounts";
417
+ import { addHexPrefix as addHexPrefix2 } from "@layr-labs/ecloud-sdk";
376
418
  var BuildVerify = class _BuildVerify extends Command {
377
419
  static description = "Verify provenance for a build or image";
378
420
  static examples = [
@@ -403,8 +445,8 @@ var BuildVerify = class _BuildVerify extends Command {
403
445
  try {
404
446
  let identifier = args.identifier;
405
447
  if (!identifier) {
406
- const billingAddress = privateKeyToAccount3(
407
- addHexPrefix(validatedFlags["private-key"])
448
+ const billingAddress = privateKeyToAccount4(
449
+ addHexPrefix2(validatedFlags["private-key"])
408
450
  ).address;
409
451
  identifier = await promptBuildIdFromRecentBuilds({ client, billingAddress, limit: 20 });
410
452
  }