@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.
- package/applications/delete-app.ts +6 -7
- package/applications/deploy-app-code.ts +8 -7
- package/applications/get-app-info.ts +6 -6
- package/applications/get-app-logs.ts +6 -6
- package/applications/list-apps.ts +2 -2
- package/applications/register-app.ts +6 -7
- package/applications/update-app.ts +6 -7
- package/cli.ts +48 -30
- package/cloudutils.ts +17 -0
- package/dist/packages/dbos-cloud/applications/delete-app.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/applications/delete-app.js +5 -6
- package/dist/packages/dbos-cloud/applications/delete-app.js.map +1 -1
- package/dist/packages/dbos-cloud/applications/deploy-app-code.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/applications/deploy-app-code.js +7 -6
- package/dist/packages/dbos-cloud/applications/deploy-app-code.js.map +1 -1
- package/dist/packages/dbos-cloud/applications/get-app-info.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/applications/get-app-info.js +5 -5
- package/dist/packages/dbos-cloud/applications/get-app-info.js.map +1 -1
- package/dist/packages/dbos-cloud/applications/get-app-logs.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/applications/get-app-logs.js +5 -5
- package/dist/packages/dbos-cloud/applications/get-app-logs.js.map +1 -1
- package/dist/packages/dbos-cloud/applications/list-apps.js +2 -2
- package/dist/packages/dbos-cloud/applications/list-apps.js.map +1 -1
- package/dist/packages/dbos-cloud/applications/register-app.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/applications/register-app.js +5 -6
- package/dist/packages/dbos-cloud/applications/register-app.js.map +1 -1
- package/dist/packages/dbos-cloud/applications/update-app.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/applications/update-app.js +5 -6
- package/dist/packages/dbos-cloud/applications/update-app.js.map +1 -1
- package/dist/packages/dbos-cloud/cli.js +45 -28
- package/dist/packages/dbos-cloud/cli.js.map +1 -1
- package/dist/packages/dbos-cloud/cloudutils.d.ts +2 -0
- package/dist/packages/dbos-cloud/cloudutils.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/cloudutils.js +18 -1
- package/dist/packages/dbos-cloud/cloudutils.js.map +1 -1
- package/dist/packages/dbos-cloud/register.d.ts.map +1 -1
- package/dist/packages/dbos-cloud/register.js +8 -2
- package/dist/packages/dbos-cloud/register.js.map +1 -1
- package/dist/packages/dbos-cloud/userdb.js +4 -4
- package/dist/packages/dbos-cloud/userdb.js.map +1 -1
- package/package.json +1 -1
- package/register.ts +7 -2
- 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
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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}
|
|
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
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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}
|
|
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}
|
|
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}
|
|
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
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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}
|
|
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
|
-
|
|
17
|
-
|
|
18
|
-
|
|
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}
|
|
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}
|
|
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.
|
|
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
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
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}
|
|
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
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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}
|
|
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
|
|
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('
|
|
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
|
|
58
|
-
.requiredOption('-d, --database <string>', 'Specify
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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('
|
|
100
|
-
.description(
|
|
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(
|
|
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
|
-
/*
|
|
118
|
-
|
|
129
|
+
//////////////////////////////////
|
|
130
|
+
/* DATABASE INSTANCE MANAGEMENT */
|
|
131
|
+
//////////////////////////////////
|
|
119
132
|
|
|
120
|
-
const
|
|
121
|
-
.command('
|
|
122
|
-
.
|
|
133
|
+
const databaseCommands = program
|
|
134
|
+
.command('database')
|
|
135
|
+
.alias('databases')
|
|
136
|
+
.alias('db')
|
|
137
|
+
.description('Manage Postgres database instances')
|
|
123
138
|
|
|
124
|
-
|
|
125
|
-
.command('
|
|
126
|
-
.
|
|
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
|
-
.
|
|
130
|
-
|
|
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
|
-
|
|
150
|
+
databaseCommands
|
|
136
151
|
.command('status')
|
|
137
|
-
.
|
|
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
|
-
|
|
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
|
-
|
|
153
|
-
.command('
|
|
154
|
-
.
|
|
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":"
|
|
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
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
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}
|
|
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,
|
|
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,
|
|
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
|
-
|
|
18
|
-
|
|
19
|
-
|
|
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}
|
|
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}
|
|
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}
|
|
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,
|
|
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":"
|
|
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
|
-
|
|
15
|
-
|
|
16
|
-
|
|
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}
|
|
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,
|
|
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":"
|
|
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
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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}
|
|
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,
|
|
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"}
|