@dbos-inc/dbos-cloud 0.10.2-preview.g78cbb783c6 → 0.10.3-preview

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 (43) hide show
  1. package/applications/delete-app.ts +6 -7
  2. package/applications/deploy-app-code.ts +8 -7
  3. package/applications/get-app-info.ts +6 -6
  4. package/applications/get-app-logs.ts +6 -6
  5. package/applications/list-apps.ts +2 -2
  6. package/applications/register-app.ts +6 -7
  7. package/applications/update-app.ts +6 -7
  8. package/cli.ts +48 -30
  9. package/cloudutils.ts +17 -0
  10. package/dist/packages/dbos-cloud/applications/delete-app.d.ts.map +1 -1
  11. package/dist/packages/dbos-cloud/applications/delete-app.js +5 -6
  12. package/dist/packages/dbos-cloud/applications/delete-app.js.map +1 -1
  13. package/dist/packages/dbos-cloud/applications/deploy-app-code.d.ts.map +1 -1
  14. package/dist/packages/dbos-cloud/applications/deploy-app-code.js +7 -6
  15. package/dist/packages/dbos-cloud/applications/deploy-app-code.js.map +1 -1
  16. package/dist/packages/dbos-cloud/applications/get-app-info.d.ts.map +1 -1
  17. package/dist/packages/dbos-cloud/applications/get-app-info.js +5 -5
  18. package/dist/packages/dbos-cloud/applications/get-app-info.js.map +1 -1
  19. package/dist/packages/dbos-cloud/applications/get-app-logs.d.ts.map +1 -1
  20. package/dist/packages/dbos-cloud/applications/get-app-logs.js +5 -5
  21. package/dist/packages/dbos-cloud/applications/get-app-logs.js.map +1 -1
  22. package/dist/packages/dbos-cloud/applications/list-apps.js +2 -2
  23. package/dist/packages/dbos-cloud/applications/list-apps.js.map +1 -1
  24. package/dist/packages/dbos-cloud/applications/register-app.d.ts.map +1 -1
  25. package/dist/packages/dbos-cloud/applications/register-app.js +5 -6
  26. package/dist/packages/dbos-cloud/applications/register-app.js.map +1 -1
  27. package/dist/packages/dbos-cloud/applications/update-app.d.ts.map +1 -1
  28. package/dist/packages/dbos-cloud/applications/update-app.js +5 -6
  29. package/dist/packages/dbos-cloud/applications/update-app.js.map +1 -1
  30. package/dist/packages/dbos-cloud/cli.js +45 -28
  31. package/dist/packages/dbos-cloud/cli.js.map +1 -1
  32. package/dist/packages/dbos-cloud/cloudutils.d.ts +2 -0
  33. package/dist/packages/dbos-cloud/cloudutils.d.ts.map +1 -1
  34. package/dist/packages/dbos-cloud/cloudutils.js +18 -1
  35. package/dist/packages/dbos-cloud/cloudutils.js.map +1 -1
  36. package/dist/packages/dbos-cloud/register.d.ts.map +1 -1
  37. package/dist/packages/dbos-cloud/register.js +8 -2
  38. package/dist/packages/dbos-cloud/register.js.map +1 -1
  39. package/dist/packages/dbos-cloud/userdb.js +4 -4
  40. package/dist/packages/dbos-cloud/userdb.js.map +1 -1
  41. package/package.json +1 -1
  42. package/register.ts +7 -2
  43. package/userdb.ts +4 -4
@@ -1,20 +1,19 @@
1
1
  import axios, { AxiosError } from "axios";
2
- import { isCloudAPIErrorResponse, handleAPIErrors, getCloudCredentials, getLogger } from "../cloudutils";
3
- import path from "node:path";
2
+ import { isCloudAPIErrorResponse, handleAPIErrors, getCloudCredentials, getLogger, retrieveApplicationName } from "../cloudutils";
4
3
 
5
4
  export async function deleteApp(host: string): Promise<number> {
6
5
  const logger = getLogger()
7
6
  const userCredentials = getCloudCredentials();
8
7
  const bearerToken = "Bearer " + userCredentials.token;
9
8
 
10
- // eslint-disable-next-line @typescript-eslint/no-var-requires
11
- const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
12
- const appName = packageJson.name;
13
- logger.info(`Loaded application name from package.json: ${appName}`)
9
+ const appName = retrieveApplicationName(logger);
10
+ if (appName === null) {
11
+ return 1;
12
+ }
14
13
  logger.info(`Deleting application: ${appName}`)
15
14
 
16
15
  try {
17
- await axios.delete(`https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`, {
16
+ await axios.delete(`https://${host}/${userCredentials.userName}/application/${appName}`, {
18
17
  headers: {
19
18
  "Content-Type": "application/json",
20
19
  Authorization: bearerToken,
@@ -1,7 +1,7 @@
1
1
  import axios, { AxiosError } from "axios";
2
2
  import { execSync } from "child_process";
3
3
  import { writeFileSync, existsSync } from 'fs';
4
- import { handleAPIErrors, createDirectory, dbosConfigFilePath, getCloudCredentials, getLogger, readFileSync, runCommand, sleep, isCloudAPIErrorResponse } from "../cloudutils";
4
+ import { handleAPIErrors, createDirectory, dbosConfigFilePath, getCloudCredentials, getLogger, readFileSync, runCommand, sleep, isCloudAPIErrorResponse, retrieveApplicationName } from "../cloudutils";
5
5
  import path from "path";
6
6
  import { Application } from "./types";
7
7
 
@@ -17,9 +17,10 @@ export async function deployAppCode(host: string, docker: boolean): Promise<numb
17
17
  const userCredentials = getCloudCredentials();
18
18
  const bearerToken = "Bearer " + userCredentials.token;
19
19
 
20
- // eslint-disable-next-line @typescript-eslint/no-var-requires
21
- const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
22
- const appName = packageJson.name;
20
+ const appName = retrieveApplicationName(logger);
21
+ if (appName === null) {
22
+ return 1;
23
+ }
23
24
  logger.info(`Loaded application name from package.json: ${appName}`)
24
25
 
25
26
  createDirectory(deployDirectoryName);
@@ -52,7 +53,7 @@ export async function deployAppCode(host: string, docker: boolean): Promise<numb
52
53
  // Submit the deploy request
53
54
  logger.info(`Submitting deploy request for ${appName}`)
54
55
  const response = await axios.post(
55
- `https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`,
56
+ `https://${host}/${userCredentials.userName}/application/${appName}`,
56
57
  {
57
58
  application_archive: zipData,
58
59
  },
@@ -84,7 +85,7 @@ export async function deployAppCode(host: string, docker: boolean): Promise<numb
84
85
 
85
86
  // Retrieve the application status, check if it is "AVAILABLE"
86
87
  const list = await axios.get(
87
- `https://${host}/v1alpha1/${userCredentials.userName}/applications`,
88
+ `https://${host}/${userCredentials.userName}/application`,
88
89
  {
89
90
  headers: {
90
91
  Authorization: bearerToken,
@@ -101,7 +102,7 @@ export async function deployAppCode(host: string, docker: boolean): Promise<numb
101
102
  }
102
103
  await sleep(5000); // Leave time for route cache updates
103
104
  logger.info(`Application ${appName} successfuly deployed`)
104
- logger.info(`Access your application at https://${host}/apps/${userCredentials.userName}/${appName}`)
105
+ logger.info(`Access your application at https://${host}/${userCredentials.userName}/application/${appName}`)
105
106
  return 0;
106
107
  } catch (e) {
107
108
  const errorLabel = `Failed to deploy application ${appName}`;
@@ -1,6 +1,5 @@
1
1
  import axios , { AxiosError } from "axios";
2
- import { handleAPIErrors, getCloudCredentials, getLogger, isCloudAPIErrorResponse } from "../cloudutils";
3
- import path from "node:path";
2
+ import { handleAPIErrors, getCloudCredentials, getLogger, isCloudAPIErrorResponse, retrieveApplicationName } from "../cloudutils";
4
3
  import { Application } from "./types";
5
4
 
6
5
  export async function getAppInfo(host: string, json: boolean): Promise<number> {
@@ -8,15 +7,16 @@ export async function getAppInfo(host: string, json: boolean): Promise<number> {
8
7
  const userCredentials = getCloudCredentials();
9
8
  const bearerToken = "Bearer " + userCredentials.token;
10
9
 
11
- // eslint-disable-next-line @typescript-eslint/no-var-requires
12
- const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
13
- const appName = packageJson.name;
10
+ const appName = retrieveApplicationName(logger);
11
+ if (appName === null) {
12
+ return 1;
13
+ }
14
14
  if (!json) {
15
15
  logger.info(`Retrieving info for application: ${appName}`)
16
16
  }
17
17
 
18
18
  try {
19
- const res = await axios.get(`https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`, {
19
+ const res = await axios.get(`https://${host}/${userCredentials.userName}/application/${appName}`, {
20
20
  headers: {
21
21
  "Content-Type": "application/json",
22
22
  Authorization: bearerToken,
@@ -1,6 +1,5 @@
1
1
  import axios , { AxiosError } from "axios";
2
- import { handleAPIErrors, getCloudCredentials, getLogger, isCloudAPIErrorResponse } from "../cloudutils";
3
- import path from "node:path";
2
+ import { handleAPIErrors, getCloudCredentials, getLogger, isCloudAPIErrorResponse, retrieveApplicationName } from "../cloudutils";
4
3
 
5
4
  export async function getAppLogs(host: string, last: number): Promise<number> {
6
5
  if (last != undefined && (isNaN(last) || last <= 0)) {
@@ -13,13 +12,14 @@ export async function getAppLogs(host: string, last: number): Promise<number> {
13
12
  const userCredentials = getCloudCredentials();
14
13
  const bearerToken = "Bearer " + userCredentials.token;
15
14
 
16
- // eslint-disable-next-line @typescript-eslint/no-var-requires
17
- const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
18
- const appName = packageJson.name;
15
+ const appName = retrieveApplicationName(logger);
16
+ if (appName === null) {
17
+ return 1;
18
+ }
19
19
  logger.info(`Retrieving logs for application: ${appName}`)
20
20
 
21
21
  try {
22
- const res = await axios.get(`https://${host}/v1alpha1/${userCredentials.userName}/logs/applications/${appName}?last=${last}`, {
22
+ const res = await axios.get(`https://${host}/${userCredentials.userName}/logs/application/${appName}?last=${last}`, {
23
23
  headers: {
24
24
  "Content-Type": "application/json",
25
25
  Authorization: bearerToken,
@@ -9,7 +9,7 @@ export async function listApps(host: string, json: boolean): Promise<number> {
9
9
 
10
10
  try {
11
11
  const list = await axios.get(
12
- `https://${host}/v1alpha1/${userCredentials.userName}/applications`,
12
+ `https://${host}/${userCredentials.userName}/application`,
13
13
  {
14
14
  headers: {
15
15
  Authorization: bearerToken,
@@ -28,7 +28,7 @@ export async function listApps(host: string, json: boolean): Promise<number> {
28
28
  applications.forEach(app => {
29
29
  console.log(`Application Name: ${app.Name}`);
30
30
  console.log(`ID: ${app.ID}`);
31
- console.log(`Postgres Instance Name: ${app.ApplicationDatabaseName}`);
31
+ console.log(`Postgres Instance Name: ${app.PostgresInstanceName}`);
32
32
  console.log(`Application Database Name: ${app.ApplicationDatabaseName}`);
33
33
  console.log(`Status: ${app.Status}`);
34
34
  console.log(`Version: ${app.Version}`);
@@ -1,21 +1,20 @@
1
1
  import axios, { AxiosError } from "axios";
2
- import { handleAPIErrors, getCloudCredentials, getLogger, isCloudAPIErrorResponse } from "../cloudutils";
3
- import path from "node:path";
2
+ import { handleAPIErrors, getCloudCredentials, getLogger, isCloudAPIErrorResponse, retrieveApplicationName } from "../cloudutils";
4
3
 
5
4
  export async function registerApp(dbname: string, host: string): Promise<number> {
6
5
  const logger = getLogger();
7
6
  const userCredentials = getCloudCredentials();
8
7
  const bearerToken = "Bearer " + userCredentials.token;
9
8
 
10
- // eslint-disable-next-line @typescript-eslint/no-var-requires
11
- const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
12
- const appName = packageJson.name;
13
- logger.info(`Loaded application name from package.json: ${appName}`)
9
+ const appName = retrieveApplicationName(logger);
10
+ if (appName === null) {
11
+ return 1;
12
+ }
14
13
  logger.info(`Registering application: ${appName}`)
15
14
 
16
15
  try {
17
16
  const register = await axios.put(
18
- `https://${host}/v1alpha1/${userCredentials.userName}/applications`,
17
+ `https://${host}/${userCredentials.userName}/application`,
19
18
  {
20
19
  name: appName,
21
20
  database: dbname,
@@ -1,23 +1,22 @@
1
1
  import axios, { AxiosError } from "axios";
2
- import { getCloudCredentials, getLogger, handleAPIErrors, isCloudAPIErrorResponse } from "../cloudutils";
2
+ import { getCloudCredentials, getLogger, handleAPIErrors, isCloudAPIErrorResponse, retrieveApplicationName } from "../cloudutils";
3
3
  import { Application } from "./types";
4
- import path from "node:path";
5
4
 
6
5
  export async function updateApp(host: string): Promise<number> {
7
6
  const logger = getLogger();
8
7
  const userCredentials = getCloudCredentials();
9
8
  const bearerToken = "Bearer " + userCredentials.token;
10
9
 
11
- // eslint-disable-next-line @typescript-eslint/no-var-requires
12
- const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
13
- const appName = packageJson.name;
14
- logger.info(`Loaded application name from package.json: ${appName}`)
10
+ const appName = retrieveApplicationName(logger);
11
+ if (appName === null) {
12
+ return 1;
13
+ }
15
14
  logger.info(`Updating application: ${appName}`)
16
15
 
17
16
  try {
18
17
  logger.info(`Updating application ${appName}`);
19
18
  const update = await axios.patch(
20
- `https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`,
19
+ `https://${host}/${userCredentials.userName}/application/${appName}`,
21
20
  {
22
21
  name: appName,
23
22
  },
package/cli.ts CHANGED
@@ -12,7 +12,7 @@ import { Command } from 'commander';
12
12
  import { login } from "./login";
13
13
  import { registerUser } from "./register";
14
14
  import { createUserDb, getUserDb, deleteUserDb, listUserDB } from "./userdb";
15
- import { DBOSCloudHost } from "./cloudutils";
15
+ import { DBOSCloudHost, credentialsExist, deleteCredentials } from "./cloudutils";
16
16
  import { getAppInfo } from "./applications/get-app-info";
17
17
 
18
18
  const program = new Command();
@@ -37,25 +37,38 @@ program
37
37
 
38
38
  program
39
39
  .command('register')
40
- .description('Register a user and log in to DBOS cloud')
40
+ .description('Register a user with DBOS cloud')
41
41
  .requiredOption('-u, --username <string>', 'Username')
42
42
  .action(async (options: { username: string}) => {
43
43
  const exitCode = await registerUser(options.username, DBOSCloudHost);
44
44
  process.exit(exitCode);
45
45
  });
46
46
 
47
+ program
48
+ .command('logout')
49
+ .description('Log out of DBOS cloud')
50
+ .action(() => {
51
+ if (credentialsExist()) {
52
+ deleteCredentials();
53
+ }
54
+ process.exit(0);
55
+ });
56
+
47
57
  /////////////////////////////
48
58
  /* APPLICATIONS MANAGEMENT */
49
59
  /////////////////////////////
50
60
 
51
61
  const applicationCommands = program
52
- .command('applications')
62
+ .command('application')
63
+ .alias('applications')
64
+ .alias('app')
65
+ .alias('apps')
53
66
  .description('Manage your DBOS applications')
54
67
 
55
68
  applicationCommands
56
69
  .command('register')
57
- .description('Register a new application')
58
- .requiredOption('-d, --database <string>', 'Specify the app database name')
70
+ .description('Register this application')
71
+ .requiredOption('-d, --database <string>', 'Specify a Postgres database instance for this application')
59
72
  .action(async (options: { database: string }) => {
60
73
  const exitCode = await registerApp(options.database, DBOSCloudHost);
61
74
  process.exit(exitCode);
@@ -63,7 +76,7 @@ applicationCommands
63
76
 
64
77
  applicationCommands
65
78
  .command('update')
66
- .description('Update an application')
79
+ .description('Update this application')
67
80
  .action(async () => {
68
81
  const exitCode = await updateApp(DBOSCloudHost);
69
82
  process.exit(exitCode);
@@ -71,7 +84,7 @@ applicationCommands
71
84
 
72
85
  applicationCommands
73
86
  .command('deploy')
74
- .description('Deploy an application code to the cloud')
87
+ .description('Deploy this application to the cloud')
75
88
  .option('--no-docker', 'Build the code locally without using Docker')
76
89
  .action(async (options: { docker: boolean }) => {
77
90
  const exitCode = await deployAppCode(DBOSCloudHost, options.docker);
@@ -80,7 +93,7 @@ applicationCommands
80
93
 
81
94
  applicationCommands
82
95
  .command('delete')
83
- .description('Delete a previously deployed application')
96
+ .description('Delete this application')
84
97
  .action(async () => {
85
98
  const exitCode = await deleteApp(DBOSCloudHost);
86
99
  process.exit(exitCode);
@@ -88,7 +101,7 @@ applicationCommands
88
101
 
89
102
  applicationCommands
90
103
  .command('list')
91
- .description('List all deployed applications')
104
+ .description('List all applications')
92
105
  .option('--json', 'Emit JSON output')
93
106
  .action(async (options: { json: boolean }) => {
94
107
  const exitCode = await listApps(DBOSCloudHost, options.json);
@@ -96,8 +109,8 @@ applicationCommands
96
109
  });
97
110
 
98
111
  applicationCommands
99
- .command('get')
100
- .description('Get application info')
112
+ .command('status')
113
+ .description("Retrieve this application's status")
101
114
  .option('--json', 'Emit JSON output')
102
115
  .action(async (options: { json: boolean }) => {
103
116
  const exitCode = await getAppInfo(DBOSCloudHost, options.json);
@@ -106,52 +119,57 @@ applicationCommands
106
119
 
107
120
  applicationCommands
108
121
  .command('logs')
109
- .description('Print the microVM logs of a deployed application')
122
+ .description("Print this application's logs")
110
123
  .option('-l, --last <integer>', 'How far back to query, in seconds from current time. By default, we retrieve all data', parseInt)
111
124
  .action(async (options: { last: number}) => {
112
125
  const exitCode = await getAppLogs(DBOSCloudHost, options.last);
113
126
  process.exit(exitCode);
114
127
  });
115
128
 
116
- //////////////////////////////
117
- /* USER DATABASE MANAGEMENT */
118
- //////////////////////////////
129
+ //////////////////////////////////
130
+ /* DATABASE INSTANCE MANAGEMENT */
131
+ //////////////////////////////////
119
132
 
120
- const userdbCommands = program
121
- .command('userdb')
122
- .description('Manage your databases')
133
+ const databaseCommands = program
134
+ .command('database')
135
+ .alias('databases')
136
+ .alias('db')
137
+ .description('Manage Postgres database instances')
123
138
 
124
- userdbCommands
125
- .command('create')
126
- .argument('<string>', 'database name')
139
+ databaseCommands
140
+ .command('provision')
141
+ .description("Provision a Postgres database instance")
142
+ .argument('<string>', 'database instance name')
127
143
  .requiredOption('-a, --admin <string>', 'Specify the admin user')
128
144
  .requiredOption('-W, --password <string>', 'Specify the admin password')
129
- .option('-s, --sync', 'make synchronous call', true)
130
- .action((async (dbname: string, options: { admin: string, password: string, sync: boolean }) => {
131
- const exitCode = await createUserDb(DBOSCloudHost, dbname, options.admin, options.password, options.sync)
145
+ .action((async (dbname: string, options: { admin: string, password: string }) => {
146
+ const exitCode = await createUserDb(DBOSCloudHost, dbname, options.admin, options.password, true)
132
147
  process.exit(exitCode);
133
148
  }))
134
149
 
135
- userdbCommands
150
+ databaseCommands
136
151
  .command('status')
137
- .argument('<string>', 'database name')
152
+ .description("Retrieve the status of a Postgres database instance")
153
+ .argument('<string>', 'database instance name')
138
154
  .option('--json', 'Emit JSON output')
139
155
  .action((async (dbname: string, options: { json: boolean}) => {
140
156
  const exitCode = await getUserDb(DBOSCloudHost, dbname, options.json)
141
157
  process.exit(exitCode);
142
158
  }))
143
159
 
144
- userdbCommands
160
+ databaseCommands
145
161
  .command('list')
162
+ .description("List all your Postgres database instances")
146
163
  .option('--json', 'Emit JSON output')
147
164
  .action((async (options: { json: boolean}) => {
148
165
  const exitCode = await listUserDB(DBOSCloudHost, options.json)
149
166
  process.exit(exitCode);
150
167
  }))
151
168
 
152
- userdbCommands
153
- .command('delete')
154
- .argument('<string>', 'database name')
169
+ databaseCommands
170
+ .command('destroy')
171
+ .description("Destroy a Postgres database instance")
172
+ .argument('<string>', 'database instance name')
155
173
  .action((async (dbname: string) => {
156
174
  const exitCode = await deleteUserDb(DBOSCloudHost, dbname)
157
175
  process.exit(exitCode);
package/cloudutils.ts CHANGED
@@ -4,6 +4,7 @@ import { transports, createLogger, format, Logger } from "winston";
4
4
  import fs from "fs";
5
5
  import { AxiosError } from "axios";
6
6
  import jwt from 'jsonwebtoken';
7
+ import path from "node:path";
7
8
 
8
9
  export interface DBOSCloudCredentials {
9
10
  token: string;
@@ -14,6 +15,18 @@ export const dbosConfigFilePath = "dbos-config.yaml";
14
15
  export const DBOSCloudHost = process.env.DBOS_DOMAIN || "cloud.dbos.dev";
15
16
  export const dbosEnvPath = ".dbos";
16
17
 
18
+ export function retrieveApplicationName(logger: Logger): string | null {
19
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
20
+ const packageJson = require(path.join(process.cwd(), 'package.json')) as { name: string };
21
+ const appName = packageJson.name;
22
+ if (appName === undefined) {
23
+ logger.error("Error: cannot find a valid package.json file. Please run this command in an application root directory.")
24
+ return null;
25
+ }
26
+ logger.info(`Loaded application name from package.json: ${appName}`)
27
+ return appName
28
+ }
29
+
17
30
  // FIXME: we should have a global instance of the logger created in cli.ts
18
31
  export function getLogger(): Logger {
19
32
  const winstonTransports: TransportStream[] = [];
@@ -77,6 +90,10 @@ export function credentialsExist(): boolean {
77
90
  return fs.existsSync(`./${dbosEnvPath}/credentials`);
78
91
  }
79
92
 
93
+ export function deleteCredentials() {
94
+ fs.unlinkSync(`./${dbosEnvPath}/credentials`);
95
+ }
96
+
80
97
  // Run a command, streaming its output to stdout
81
98
  export function runCommand(command: string, args: string[] = []): Promise<number> {
82
99
  return new Promise((resolve, reject) => {
@@ -1 +1 @@
1
- {"version":3,"file":"delete-app.d.ts","sourceRoot":"","sources":["../../../../applications/delete-app.ts"],"names":[],"mappings":"AAIA,wBAAsB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CA+B7D"}
1
+ {"version":3,"file":"delete-app.d.ts","sourceRoot":"","sources":["../../../../applications/delete-app.ts"],"names":[],"mappings":"AAGA,wBAAsB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CA+B7D"}
@@ -6,18 +6,17 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.deleteApp = void 0;
7
7
  const axios_1 = __importDefault(require("axios"));
8
8
  const cloudutils_1 = require("../cloudutils");
9
- const node_path_1 = __importDefault(require("node:path"));
10
9
  async function deleteApp(host) {
11
10
  const logger = (0, cloudutils_1.getLogger)();
12
11
  const userCredentials = (0, cloudutils_1.getCloudCredentials)();
13
12
  const bearerToken = "Bearer " + userCredentials.token;
14
- // eslint-disable-next-line @typescript-eslint/no-var-requires
15
- const packageJson = require(node_path_1.default.join(process.cwd(), 'package.json'));
16
- const appName = packageJson.name;
17
- logger.info(`Loaded application name from package.json: ${appName}`);
13
+ const appName = (0, cloudutils_1.retrieveApplicationName)(logger);
14
+ if (appName === null) {
15
+ return 1;
16
+ }
18
17
  logger.info(`Deleting application: ${appName}`);
19
18
  try {
20
- await axios_1.default.delete(`https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`, {
19
+ await axios_1.default.delete(`https://${host}/${userCredentials.userName}/application/${appName}`, {
21
20
  headers: {
22
21
  "Content-Type": "application/json",
23
22
  Authorization: bearerToken,
@@ -1 +1 @@
1
- {"version":3,"file":"delete-app.js","sourceRoot":"","sources":["../../../../applications/delete-app.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0C;AAC1C,8CAAyG;AACzG,0DAA6B;AAEtB,KAAK,UAAU,SAAS,CAAC,IAAY;IAC1C,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAA;IAC1B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,8DAA8D;IAC9D,MAAM,WAAW,GAAG,OAAO,CAAC,mBAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAqB,CAAC;IAC1F,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;IACjC,MAAM,CAAC,IAAI,CAAC,8CAA8C,OAAO,EAAE,CAAC,CAAA;IACpE,MAAM,CAAC,IAAI,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAA;IAE/C,IAAI,CAAC;QACH,MAAM,eAAK,CAAC,MAAM,CAAC,WAAW,IAAI,aAAa,eAAe,CAAC,QAAQ,iBAAiB,OAAO,EAAE,EAAE;YACjG,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CAAC,CAAC;QAEH,MAAM,CAAC,IAAI,CAAC,qCAAqC,OAAO,EAAE,CAAC,CAAC;QAC5D,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,gCAAgC,OAAO,EAAE,CAAC;QAC7D,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AA/BD,8BA+BC"}
1
+ {"version":3,"file":"delete-app.js","sourceRoot":"","sources":["../../../../applications/delete-app.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0C;AAC1C,8CAAkI;AAE3H,KAAK,UAAU,SAAS,CAAC,IAAY;IAC1C,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAA;IAC1B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,MAAM,OAAO,GAAG,IAAA,oCAAuB,EAAC,MAAM,CAAC,CAAC;IAChD,IAAI,OAAO,KAAK,IAAI,EAAE,CAAC;QACrB,OAAO,CAAC,CAAC;IACX,CAAC;IACD,MAAM,CAAC,IAAI,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAA;IAE/C,IAAI,CAAC;QACH,MAAM,eAAK,CAAC,MAAM,CAAC,WAAW,IAAI,IAAI,eAAe,CAAC,QAAQ,gBAAgB,OAAO,EAAE,EAAE;YACvF,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CAAC,CAAC;QAEH,MAAM,CAAC,IAAI,CAAC,qCAAqC,OAAO,EAAE,CAAC,CAAC;QAC5D,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,gCAAgC,OAAO,EAAE,CAAC;QAC7D,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AA/BD,8BA+BC"}
@@ -1 +1 @@
1
- {"version":3,"file":"deploy-app-code.d.ts","sourceRoot":"","sources":["../../../../applications/deploy-app-code.ts"],"names":[],"mappings":"AAcA,wBAAsB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAqGlF"}
1
+ {"version":3,"file":"deploy-app-code.d.ts","sourceRoot":"","sources":["../../../../applications/deploy-app-code.ts"],"names":[],"mappings":"AAcA,wBAAsB,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAsGlF"}
@@ -14,9 +14,10 @@ async function deployAppCode(host, docker) {
14
14
  const logger = (0, cloudutils_1.getLogger)();
15
15
  const userCredentials = (0, cloudutils_1.getCloudCredentials)();
16
16
  const bearerToken = "Bearer " + userCredentials.token;
17
- // eslint-disable-next-line @typescript-eslint/no-var-requires
18
- const packageJson = require(path_1.default.join(process.cwd(), 'package.json'));
19
- const appName = packageJson.name;
17
+ const appName = (0, cloudutils_1.retrieveApplicationName)(logger);
18
+ if (appName === null) {
19
+ return 1;
20
+ }
20
21
  logger.info(`Loaded application name from package.json: ${appName}`);
21
22
  (0, cloudutils_1.createDirectory)(deployDirectoryName);
22
23
  // Verify that package-lock.json exists
@@ -43,7 +44,7 @@ async function deployAppCode(host, docker) {
43
44
  const zipData = (0, cloudutils_1.readFileSync)(`${deployDirectoryName}/${appName}.zip`, "base64");
44
45
  // Submit the deploy request
45
46
  logger.info(`Submitting deploy request for ${appName}`);
46
- const response = await axios_1.default.post(`https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`, {
47
+ const response = await axios_1.default.post(`https://${host}/${userCredentials.userName}/application/${appName}`, {
47
48
  application_archive: zipData,
48
49
  }, {
49
50
  headers: {
@@ -69,7 +70,7 @@ async function deployAppCode(host, docker) {
69
70
  return 1;
70
71
  }
71
72
  // Retrieve the application status, check if it is "AVAILABLE"
72
- const list = await axios_1.default.get(`https://${host}/v1alpha1/${userCredentials.userName}/applications`, {
73
+ const list = await axios_1.default.get(`https://${host}/${userCredentials.userName}/application`, {
73
74
  headers: {
74
75
  Authorization: bearerToken,
75
76
  },
@@ -84,7 +85,7 @@ async function deployAppCode(host, docker) {
84
85
  }
85
86
  await (0, cloudutils_1.sleep)(5000); // Leave time for route cache updates
86
87
  logger.info(`Application ${appName} successfuly deployed`);
87
- logger.info(`Access your application at https://${host}/apps/${userCredentials.userName}/${appName}`);
88
+ logger.info(`Access your application at https://${host}/${userCredentials.userName}/application/${appName}`);
88
89
  return 0;
89
90
  }
90
91
  catch (e) {
@@ -1 +1 @@
1
- {"version":3,"file":"deploy-app-code.js","sourceRoot":"","sources":["../../../../applications/deploy-app-code.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA0C;AAC1C,iDAAyC;AACzC,2BAA+C;AAC/C,8CAA+K;AAC/K,gDAAwB;AAGxB,MAAM,mBAAmB,GAAG,aAAa,CAAC;AAOnC,KAAK,UAAU,aAAa,CAAC,IAAY,EAAE,MAAe;IAC/D,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAA;IAC1B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,8DAA8D;IAC9D,MAAM,WAAW,GAAG,OAAO,CAAC,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAqB,CAAC;IAC1F,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;IACjC,MAAM,CAAC,IAAI,CAAC,8CAA8C,OAAO,EAAE,CAAC,CAAA;IAEpE,IAAA,4BAAe,EAAC,mBAAmB,CAAC,CAAC;IAErC,uCAAuC;IACvC,IAAI,CAAC,IAAA,eAAU,EAAC,cAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,mBAAmB,CAAC,CAAC,EAAE,CAAC;QAC/D,MAAM,CAAC,KAAK,CAAC,yEAAyE,CAAC,CAAA;QACvF,OAAO,CAAC,CAAC;IACX,CAAC;IAED,IAAI,MAAM,EAAE,CAAC;QACX,+FAA+F;QAC/F,MAAM,CAAC,IAAI,CAAC,YAAY,OAAO,eAAe,CAAC,CAAA;QAC/C,MAAM,aAAa,GAAG,MAAM,gBAAgB,CAAC,OAAO,CAAC,CAAC;QACtD,IAAI,CAAC,aAAa,EAAE,CAAC;YACnB,OAAO,CAAC,CAAC;QACX,CAAC;IACH,CAAC;SAAM,CAAC;QACN,8GAA8G;QAC9G,IAAA,wBAAQ,EAAC,WAAW,mBAAmB,IAAI,OAAO,eAAe,mBAAmB,gBAAgB,CAAC,CAAC;IACxG,CAAC;IAED,MAAM,kBAAkB,GAAG,sBAAsB,CAAC,+BAAkB,CAAC,CAAA;IACrE,IAAA,kBAAa,EAAC,GAAG,mBAAmB,IAAI,+BAAkB,EAAE,EAAE,kBAAkB,CAAC,CAAA;IACjF,IAAA,wBAAQ,EAAC,UAAU,mBAAmB,IAAI,OAAO,QAAQ,mBAAmB,IAAI,+BAAkB,cAAc,CAAC,CAAC;IAElH,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,IAAA,yBAAY,EAAC,GAAG,mBAAmB,IAAI,OAAO,MAAM,EAAE,QAAQ,CAAC,CAAC;QAEhF,4BAA4B;QAC5B,MAAM,CAAC,IAAI,CAAC,iCAAiC,OAAO,EAAE,CAAC,CAAA;QACvD,MAAM,QAAQ,GAAG,MAAM,eAAK,CAAC,IAAI,CAC/B,WAAW,IAAI,aAAa,eAAe,CAAC,QAAQ,iBAAiB,OAAO,EAAE,EAC9E;YACE,mBAAmB,EAAE,OAAO;SAC7B,EACD;YACE,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CACF,CAAC;QACF,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAoB,CAAC;QACnD,MAAM,CAAC,IAAI,CAAC,gCAAgC,OAAO,uBAAuB,YAAY,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAE7G,+CAA+C;QAC/C,IAAI,KAAK,GAAG,CAAC,CAAA;QACb,IAAI,oBAAoB,GAAG,KAAK,CAAA;QAChC,OAAO,CAAC,oBAAoB,EAAE,CAAC;YAC7B,KAAK,IAAI,CAAC,CAAA;YACV,IAAI,KAAK,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACpB,MAAM,CAAC,IAAI,CAAC,eAAe,OAAO,iBAAiB,YAAY,CAAC,kBAAkB,kBAAkB,CAAC,CAAC;gBACtG,IAAI,KAAK,GAAG,EAAE,EAAE,CAAC;oBACf,MAAM,CAAC,IAAI,CAAC,MAAM,OAAO,6FAA6F,CAAC,CAAC;gBAC1H,CAAC;YACH,CAAC;YACD,IAAI,KAAK,GAAG,GAAG,EAAE,CAAC;gBAChB,MAAM,CAAC,KAAK,CAAC,iDAAiD,CAAC,CAAA;gBAC/D,OAAO,CAAC,CAAC;YACX,CAAC;YAED,8DAA8D;YAC9D,MAAM,IAAI,GAAG,MAAM,eAAK,CAAC,GAAG,CAC1B,WAAW,IAAI,aAAa,eAAe,CAAC,QAAQ,eAAe,EACnE;gBACE,OAAO,EAAE;oBACP,aAAa,EAAE,WAAW;iBAC3B;aACF,CACF,CAAC;YACF,MAAM,YAAY,GAAkB,IAAI,CAAC,IAAqB,CAAC;YAC/D,KAAK,MAAM,WAAW,IAAI,YAAY,EAAE,CAAC;gBACvC,IAAI,WAAW,CAAC,IAAI,KAAK,OAAO,IAAI,WAAW,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;oBACvE,oBAAoB,GAAG,IAAI,CAAA;gBAC7B,CAAC;YACH,CAAC;YACD,MAAM,IAAA,kBAAK,EAAC,IAAI,CAAC,CAAC;QACpB,CAAC;QACD,MAAM,IAAA,kBAAK,EAAC,IAAI,CAAC,CAAC,CAAC,qCAAqC;QACxD,MAAM,CAAC,IAAI,CAAC,eAAe,OAAO,uBAAuB,CAAC,CAAA;QAC1D,MAAM,CAAC,IAAI,CAAC,sCAAsC,IAAI,SAAS,eAAe,CAAC,QAAQ,IAAI,OAAO,EAAE,CAAC,CAAA;QACrG,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,gCAAgC,OAAO,EAAE,CAAC;QAC7D,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AArGD,sCAqGC;AAED,SAAS,sBAAsB,CAAC,cAAsB;IACpD,MAAM,iBAAiB,GAAG,IAAA,yBAAY,EAAC,cAAc,CAAW,CAAC;IACjE,MAAM,KAAK,GAAG,cAAc,CAAC,CAAE,gDAAgD;IAC/E,OAAO,iBAAiB,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,EAAU,EAAE,EAAE;QACxD,OAAO,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAE,0DAA0D;IAC7F,CAAC,CAAC,CAAC;AACH,CAAC;AAED,KAAK,UAAU,gBAAgB,CAAC,OAAe;IAC7C,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAC;IAE3B,2BAA2B;IAC3B,IAAI,CAAC;QACH,IAAA,wBAAQ,EAAC,yBAAyB,CAAC,CAAA;IACrC,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,CAAC,KAAK,CAAC,uHAAuH,CAAC,CAAA;QACrI,OAAO,KAAK,CAAA;IACd,CAAC;IAED,MAAM,cAAc,GAAG,GAAG,mBAAmB,kBAAkB,CAAC;IAChE,MAAM,aAAa,GAAG,gBAAgB,OAAO,EAAE,CAAC;IAEhD,qBAAqB;IACrB,MAAM,iBAAiB,GAAG;;;;;;;;;cASd,OAAO,gBAAgB,OAAO,aAAa,mBAAmB;CAC3E,CAAC;IACA,MAAM,mBAAmB,GAAG;;EAE5B,mBAAmB;;;CAGpB,CAAC;IACA,IAAI,CAAC;QACH,yCAAyC;QACzC,IAAA,kBAAa,EAAC,cAAc,EAAE,iBAAiB,CAAC,CAAC;QACjD,IAAA,kBAAa,EAAC,GAAG,mBAAmB,+BAA+B,EAAE,mBAAmB,CAAC,CAAC;QAC1F,sGAAsG;QACtG,MAAM,IAAA,uBAAU,EAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,cAAc,EAAE,GAAG,CAAC,CAAC,CAAA;QAC/E,oBAAoB;QACpB,IAAA,wBAAQ,EAAC,wBAAwB,aAAa,IAAI,OAAO,EAAE,CAAC,CAAC;QAC7D,oEAAoE;QACpE,IAAA,wBAAQ,EAAC,aAAa,aAAa,SAAS,OAAO,QAAQ,mBAAmB,IAAI,OAAO,MAAM,CAAC,CAAC;QACjG,gCAAgC;QAChC,IAAA,wBAAQ,EAAC,eAAe,aAAa,EAAE,CAAC,CAAC;QACzC,IAAA,wBAAQ,EAAC,aAAa,aAAa,EAAE,CAAC,CAAC;QACvC,OAAO,IAAI,CAAC;IACd,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,CAAC,KAAK,CAAC,+BAA+B,OAAO,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QAChF,OAAO,KAAK,CAAC;IACf,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"deploy-app-code.js","sourceRoot":"","sources":["../../../../applications/deploy-app-code.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"get-app-info.d.ts","sourceRoot":"","sources":["../../../../applications/get-app-info.ts"],"names":[],"mappings":"AAKA,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAyC7E"}
1
+ {"version":3,"file":"get-app-info.d.ts","sourceRoot":"","sources":["../../../../applications/get-app-info.ts"],"names":[],"mappings":"AAIA,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CA0C7E"}
@@ -6,19 +6,19 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.getAppInfo = void 0;
7
7
  const axios_1 = __importDefault(require("axios"));
8
8
  const cloudutils_1 = require("../cloudutils");
9
- const node_path_1 = __importDefault(require("node:path"));
10
9
  async function getAppInfo(host, json) {
11
10
  const logger = (0, cloudutils_1.getLogger)();
12
11
  const userCredentials = (0, cloudutils_1.getCloudCredentials)();
13
12
  const bearerToken = "Bearer " + userCredentials.token;
14
- // eslint-disable-next-line @typescript-eslint/no-var-requires
15
- const packageJson = require(node_path_1.default.join(process.cwd(), 'package.json'));
16
- const appName = packageJson.name;
13
+ const appName = (0, cloudutils_1.retrieveApplicationName)(logger);
14
+ if (appName === null) {
15
+ return 1;
16
+ }
17
17
  if (!json) {
18
18
  logger.info(`Retrieving info for application: ${appName}`);
19
19
  }
20
20
  try {
21
- const res = await axios_1.default.get(`https://${host}/v1alpha1/${userCredentials.userName}/applications/${appName}`, {
21
+ const res = await axios_1.default.get(`https://${host}/${userCredentials.userName}/application/${appName}`, {
22
22
  headers: {
23
23
  "Content-Type": "application/json",
24
24
  Authorization: bearerToken,
@@ -1 +1 @@
1
- {"version":3,"file":"get-app-info.js","sourceRoot":"","sources":["../../../../applications/get-app-info.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA2C;AAC3C,8CAAyG;AACzG,0DAA6B;AAGtB,KAAK,UAAU,UAAU,CAAC,IAAY,EAAE,IAAa;IAC1D,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAC;IAC3B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,8DAA8D;IAC9D,MAAM,WAAW,GAAG,OAAO,CAAC,mBAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAqB,CAAC;IAC1F,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;IACjC,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,CAAC,IAAI,CAAC,oCAAoC,OAAO,EAAE,CAAC,CAAA;IAC5D,CAAC;IAED,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,WAAW,IAAI,aAAa,eAAe,CAAC,QAAQ,iBAAiB,OAAO,EAAE,EAAE;YAC1G,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CAAC,CAAC;QACH,MAAM,GAAG,GAAG,GAAG,CAAC,IAAmB,CAAA;QACnC,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,qBAAqB,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;YAC7B,OAAO,CAAC,GAAG,CAAC,2BAA2B,GAAG,CAAC,oBAAoB,EAAE,CAAC,CAAC;YACnE,OAAO,CAAC,GAAG,CAAC,8BAA8B,GAAG,CAAC,uBAAuB,EAAE,CAAC,CAAC;YACzE,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;YACrC,OAAO,CAAC,GAAG,CAAC,YAAY,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,2CAA2C,OAAO,EAAE,CAAC;QACxE,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AAzCD,gCAyCC"}
1
+ {"version":3,"file":"get-app-info.js","sourceRoot":"","sources":["../../../../applications/get-app-info.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA2C;AAC3C,8CAAkI;AAG3H,KAAK,UAAU,UAAU,CAAC,IAAY,EAAE,IAAa;IAC1D,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAC;IAC3B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,MAAM,OAAO,GAAG,IAAA,oCAAuB,EAAC,MAAM,CAAC,CAAC;IAChD,IAAI,OAAO,KAAK,IAAI,EAAE,CAAC;QACrB,OAAO,CAAC,CAAC;IACX,CAAC;IACD,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,MAAM,CAAC,IAAI,CAAC,oCAAoC,OAAO,EAAE,CAAC,CAAA;IAC5D,CAAC;IAED,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,WAAW,IAAI,IAAI,eAAe,CAAC,QAAQ,gBAAgB,OAAO,EAAE,EAAE;YAChG,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CAAC,CAAC;QACH,MAAM,GAAG,GAAG,GAAG,CAAC,IAAmB,CAAA;QACnC,IAAI,IAAI,EAAE,CAAC;YACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,qBAAqB,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,OAAO,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;YAC7B,OAAO,CAAC,GAAG,CAAC,2BAA2B,GAAG,CAAC,oBAAoB,EAAE,CAAC,CAAC;YACnE,OAAO,CAAC,GAAG,CAAC,8BAA8B,GAAG,CAAC,uBAAuB,EAAE,CAAC,CAAC;YACzE,OAAO,CAAC,GAAG,CAAC,WAAW,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;YACrC,OAAO,CAAC,GAAG,CAAC,YAAY,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QACzC,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,2CAA2C,OAAO,EAAE,CAAC;QACxE,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AA1CD,gCA0CC"}
@@ -1 +1 @@
1
- {"version":3,"file":"get-app-logs.d.ts","sourceRoot":"","sources":["../../../../applications/get-app-logs.ts"],"names":[],"mappings":"AAIA,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAwC5E"}
1
+ {"version":3,"file":"get-app-logs.d.ts","sourceRoot":"","sources":["../../../../applications/get-app-logs.ts"],"names":[],"mappings":"AAGA,wBAAsB,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAyC5E"}
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.getAppLogs = void 0;
7
7
  const axios_1 = __importDefault(require("axios"));
8
8
  const cloudutils_1 = require("../cloudutils");
9
- const node_path_1 = __importDefault(require("node:path"));
10
9
  async function getAppLogs(host, last) {
11
10
  if (last != undefined && (isNaN(last) || last <= 0)) {
12
11
  throw new Error('The --last parmameter must be an integer greater than 0');
@@ -17,12 +16,13 @@ async function getAppLogs(host, last) {
17
16
  const logger = (0, cloudutils_1.getLogger)();
18
17
  const userCredentials = (0, cloudutils_1.getCloudCredentials)();
19
18
  const bearerToken = "Bearer " + userCredentials.token;
20
- // eslint-disable-next-line @typescript-eslint/no-var-requires
21
- const packageJson = require(node_path_1.default.join(process.cwd(), 'package.json'));
22
- const appName = packageJson.name;
19
+ const appName = (0, cloudutils_1.retrieveApplicationName)(logger);
20
+ if (appName === null) {
21
+ return 1;
22
+ }
23
23
  logger.info(`Retrieving logs for application: ${appName}`);
24
24
  try {
25
- const res = await axios_1.default.get(`https://${host}/v1alpha1/${userCredentials.userName}/logs/applications/${appName}?last=${last}`, {
25
+ const res = await axios_1.default.get(`https://${host}/${userCredentials.userName}/logs/application/${appName}?last=${last}`, {
26
26
  headers: {
27
27
  "Content-Type": "application/json",
28
28
  Authorization: bearerToken,
@@ -1 +1 @@
1
- {"version":3,"file":"get-app-logs.js","sourceRoot":"","sources":["../../../../applications/get-app-logs.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA2C;AAC3C,8CAAyG;AACzG,0DAA6B;AAEtB,KAAK,UAAU,UAAU,CAAC,IAAY,EAAE,IAAY;IACzD,IAAI,IAAI,IAAI,SAAS,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC;QACpD,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;IAC7E,CAAC;IACD,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;QACtB,IAAI,GAAG,CAAC,CAAA,CAAM,8DAA8D;IAC9E,CAAC;IACD,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAC;IAC3B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,8DAA8D;IAC9D,MAAM,WAAW,GAAG,OAAO,CAAC,mBAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,cAAc,CAAC,CAAqB,CAAC;IAC1F,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;IACjC,MAAM,CAAC,IAAI,CAAC,oCAAoC,OAAO,EAAE,CAAC,CAAA;IAE1D,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,WAAW,IAAI,aAAa,eAAe,CAAC,QAAQ,sBAAsB,OAAO,SAAS,IAAI,EAAE,EAAE;YAC5H,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CAAC,CAAC;QACH,IAAI,GAAG,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC;YACnB,MAAM,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAC;QAC5D,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,+CAA+C,OAAO,EAAE,CAAC,CAAC;YACtE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QACvB,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,0CAA0C,OAAO,EAAE,CAAC;QACvE,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AAxCD,gCAwCC"}
1
+ {"version":3,"file":"get-app-logs.js","sourceRoot":"","sources":["../../../../applications/get-app-logs.ts"],"names":[],"mappings":";;;;;;AAAA,kDAA2C;AAC3C,8CAAkI;AAE3H,KAAK,UAAU,UAAU,CAAC,IAAY,EAAE,IAAY;IACzD,IAAI,IAAI,IAAI,SAAS,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,EAAE,CAAC;QACpD,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;IAC7E,CAAC;IACD,IAAI,IAAI,IAAI,SAAS,EAAE,CAAC;QACtB,IAAI,GAAG,CAAC,CAAA,CAAM,8DAA8D;IAC9E,CAAC;IACD,MAAM,MAAM,GAAG,IAAA,sBAAS,GAAE,CAAC;IAC3B,MAAM,eAAe,GAAG,IAAA,gCAAmB,GAAE,CAAC;IAC9C,MAAM,WAAW,GAAG,SAAS,GAAG,eAAe,CAAC,KAAK,CAAC;IAEtD,MAAM,OAAO,GAAG,IAAA,oCAAuB,EAAC,MAAM,CAAC,CAAC;IAChD,IAAI,OAAO,KAAK,IAAI,EAAE,CAAC;QACrB,OAAO,CAAC,CAAC;IACX,CAAC;IACD,MAAM,CAAC,IAAI,CAAC,oCAAoC,OAAO,EAAE,CAAC,CAAA;IAE1D,IAAI,CAAC;QACH,MAAM,GAAG,GAAG,MAAM,eAAK,CAAC,GAAG,CAAC,WAAW,IAAI,IAAI,eAAe,CAAC,QAAQ,qBAAqB,OAAO,SAAS,IAAI,EAAE,EAAE;YAClH,OAAO,EAAE;gBACP,cAAc,EAAE,kBAAkB;gBAClC,aAAa,EAAE,WAAW;aAC3B;SACF,CAAC,CAAC;QACH,IAAI,GAAG,CAAC,IAAI,IAAI,EAAE,EAAE,CAAC;YACnB,MAAM,CAAC,IAAI,CAAC,4CAA4C,CAAC,CAAC;QAC5D,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,IAAI,CAAC,+CAA+C,OAAO,EAAE,CAAC,CAAC;YACtE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;QACvB,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,MAAM,UAAU,GAAG,0CAA0C,OAAO,EAAE,CAAC;QACvE,MAAM,UAAU,GAAG,CAAe,CAAC;QACnC,IAAI,IAAA,oCAAuB,EAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC;YACvD,IAAA,4BAAe,EAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAC1C,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,KAAK,CAAC,GAAG,UAAU,KAAM,CAAW,CAAC,OAAO,EAAE,CAAC,CAAC;QACzD,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;AACH,CAAC;AAzCD,gCAyCC"}