@dubeyvishal/orbital-cli 1.0.1 → 1.0.2

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/package.json CHANGED
@@ -1,33 +1,25 @@
1
1
  {
2
2
  "name": "@dubeyvishal/orbital-cli",
3
- "version": "1.0.1",
3
+ "version": "1.0.2",
4
4
  "description": "A fullstack CLI-based AI platform with chat mode, multi-tool agents, and agentic AI workflows. Includes GitHub login with device authorization, secure authentication, and modular client–server architecture for building intelligent automation tools.",
5
5
  "author": "Vishal Dubey",
6
6
  "license": "MIT",
7
-
8
7
  "private": false,
9
-
10
8
  "type": "module",
11
9
  "bin": {
12
10
  "orbital": "server/src/cli/main.js"
13
11
  },
14
12
  "files": [
15
- "server/src/cli/",
16
- "server/src/config/",
17
- "server/src/lib/",
18
- "server/src/service/",
19
- "server/prisma/schema.prisma",
13
+ "server/src",
14
+ "server/prisma",
20
15
  "README.md"
21
16
  ],
22
-
23
17
  "publishConfig": {
24
18
  "access": "public"
25
19
  },
26
-
27
20
  "engines": {
28
- "node": ">=18"
21
+ "node": ">=18 <=22"
29
22
  },
30
-
31
23
  "dependencies": {
32
24
  "@ai-sdk/google": "^3.0.6",
33
25
  "@clack/prompts": "^0.11.0",
@@ -46,14 +38,13 @@
46
38
  "yocto-spinner": "^1.0.0",
47
39
  "zod": "^4.3.5"
48
40
  },
49
-
50
41
  "scripts": {
42
+ "postinstall": "cd server && npx prisma generate",
51
43
  "install-all": "npm install --prefix client && npm install --prefix server",
52
44
  "start-client": "npm start --prefix client",
53
45
  "start-server": "npm start --prefix server",
54
46
  "dev": "npm run start-server && npm run start-client"
55
47
  },
56
-
57
48
  "keywords": [
58
49
  "orbital",
59
50
  "cli",
@@ -0,0 +1,7 @@
1
+ -- CreateTable
2
+ CREATE TABLE "Test" (
3
+ "id" TEXT NOT NULL,
4
+ "name" TEXT NOT NULL,
5
+
6
+ CONSTRAINT "Test_pkey" PRIMARY KEY ("id")
7
+ );
@@ -0,0 +1,78 @@
1
+ -- CreateTable
2
+ CREATE TABLE "user" (
3
+ "id" TEXT NOT NULL,
4
+ "name" TEXT NOT NULL,
5
+ "email" TEXT NOT NULL,
6
+ "emailVerified" BOOLEAN NOT NULL DEFAULT false,
7
+ "image" TEXT,
8
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
9
+ "updatedAt" TIMESTAMP(3) NOT NULL,
10
+
11
+ CONSTRAINT "user_pkey" PRIMARY KEY ("id")
12
+ );
13
+
14
+ -- CreateTable
15
+ CREATE TABLE "session" (
16
+ "id" TEXT NOT NULL,
17
+ "expiresAt" TIMESTAMP(3) NOT NULL,
18
+ "token" TEXT NOT NULL,
19
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
20
+ "updatedAt" TIMESTAMP(3) NOT NULL,
21
+ "ipAddress" TEXT,
22
+ "userAgent" TEXT,
23
+ "userId" TEXT NOT NULL,
24
+
25
+ CONSTRAINT "session_pkey" PRIMARY KEY ("id")
26
+ );
27
+
28
+ -- CreateTable
29
+ CREATE TABLE "account" (
30
+ "id" TEXT NOT NULL,
31
+ "accountId" TEXT NOT NULL,
32
+ "providerId" TEXT NOT NULL,
33
+ "userId" TEXT NOT NULL,
34
+ "accessToken" TEXT,
35
+ "refreshToken" TEXT,
36
+ "idToken" TEXT,
37
+ "accessTokenExpiresAt" TIMESTAMP(3),
38
+ "refreshTokenExpiresAt" TIMESTAMP(3),
39
+ "scope" TEXT,
40
+ "password" TEXT,
41
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
42
+ "updatedAt" TIMESTAMP(3) NOT NULL,
43
+
44
+ CONSTRAINT "account_pkey" PRIMARY KEY ("id")
45
+ );
46
+
47
+ -- CreateTable
48
+ CREATE TABLE "verification" (
49
+ "id" TEXT NOT NULL,
50
+ "identifier" TEXT NOT NULL,
51
+ "value" TEXT NOT NULL,
52
+ "expiresAt" TIMESTAMP(3) NOT NULL,
53
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
54
+ "updatedAt" TIMESTAMP(3) NOT NULL,
55
+
56
+ CONSTRAINT "verification_pkey" PRIMARY KEY ("id")
57
+ );
58
+
59
+ -- CreateIndex
60
+ CREATE UNIQUE INDEX "user_email_key" ON "user"("email");
61
+
62
+ -- CreateIndex
63
+ CREATE INDEX "session_userId_idx" ON "session"("userId");
64
+
65
+ -- CreateIndex
66
+ CREATE UNIQUE INDEX "session_token_key" ON "session"("token");
67
+
68
+ -- CreateIndex
69
+ CREATE INDEX "account_userId_idx" ON "account"("userId");
70
+
71
+ -- CreateIndex
72
+ CREATE INDEX "verification_identifier_idx" ON "verification"("identifier");
73
+
74
+ -- AddForeignKey
75
+ ALTER TABLE "session" ADD CONSTRAINT "session_userId_fkey" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
76
+
77
+ -- AddForeignKey
78
+ ALTER TABLE "account" ADD CONSTRAINT "account_userId_fkey" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
@@ -0,0 +1,50 @@
1
+ -- CreateTable
2
+ CREATE TABLE "deviceCode" (
3
+ "id" TEXT NOT NULL,
4
+ "deviceCode" TEXT NOT NULL,
5
+ "userCode" TEXT NOT NULL,
6
+ "userId" TEXT,
7
+ "expiresAt" TIMESTAMP(3) NOT NULL,
8
+ "status" TEXT NOT NULL,
9
+ "lastPolledAt" TIMESTAMP(3),
10
+ "pollingInterval" INTEGER,
11
+ "clientId" TEXT,
12
+ "scope" TEXT,
13
+
14
+ CONSTRAINT "deviceCode_pkey" PRIMARY KEY ("id")
15
+ );
16
+
17
+ -- CreateTable
18
+ CREATE TABLE "conversation" (
19
+ "id" TEXT NOT NULL,
20
+ "userId" TEXT NOT NULL,
21
+ "title" TEXT NOT NULL,
22
+ "mode" TEXT NOT NULL DEFAULT 'chat',
23
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
24
+ "updatedAt" TIMESTAMP(3) NOT NULL,
25
+
26
+ CONSTRAINT "conversation_pkey" PRIMARY KEY ("id")
27
+ );
28
+
29
+ -- CreateTable
30
+ CREATE TABLE "message" (
31
+ "id" TEXT NOT NULL,
32
+ "conversationId" TEXT NOT NULL,
33
+ "role" TEXT NOT NULL,
34
+ "content" TEXT NOT NULL,
35
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
36
+
37
+ CONSTRAINT "message_pkey" PRIMARY KEY ("id")
38
+ );
39
+
40
+ -- CreateIndex
41
+ CREATE INDEX "conversation_userId_idx" ON "conversation"("userId");
42
+
43
+ -- CreateIndex
44
+ CREATE INDEX "message_conversationId_idx" ON "message"("conversationId");
45
+
46
+ -- AddForeignKey
47
+ ALTER TABLE "conversation" ADD CONSTRAINT "conversation_userId_fkey" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
48
+
49
+ -- AddForeignKey
50
+ ALTER TABLE "message" ADD CONSTRAINT "message_conversationId_fkey" FOREIGN KEY ("conversationId") REFERENCES "conversation"("id") ON DELETE CASCADE ON UPDATE CASCADE;
@@ -0,0 +1,3 @@
1
+ # Please do not edit this file manually
2
+ # It should be added in your version-control system (i.e. Git)
3
+ provider = "postgresql"
@@ -0,0 +1,102 @@
1
+ import "./config/env.js";
2
+ import express from "express";
3
+ import { fromNodeHeaders, toNodeHandler } from "better-auth/node";
4
+ import cors from "cors";
5
+ import { auth } from "./lib/auth.js";
6
+ import prisma from "./lib/db.js";
7
+ import { ensureDbConnectionOrExit } from "./lib/dbHealth.js";
8
+
9
+
10
+ const app = express();
11
+ const PORT = process.env.PORT || 8080;
12
+ const CLIENT_ORIGIN =
13
+ process.env.CLIENT_ORIGIN ||
14
+ process.env.FRONTEND_URL ||
15
+ "https://smart-cli-based-agent-t7x4.vercel.app";
16
+
17
+ app.use(express.json());
18
+
19
+ app.use(
20
+ cors({
21
+ origin: CLIENT_ORIGIN,
22
+ methods: ["GET", "POST", "PUT", "DELETE"],
23
+ credentials: true,
24
+ })
25
+ );
26
+
27
+ app.all("/api/auth/*splat", toNodeHandler(auth));
28
+
29
+ app.get("/api/me" , async (req, res)=>{
30
+ const session = await auth.api.getSession({
31
+ headers : fromNodeHeaders (req.headers),
32
+ });
33
+
34
+ if (session) {
35
+ return res.json(session);
36
+ }
37
+
38
+ const authHeader = req.headers.authorization;
39
+ if (!authHeader) {
40
+ return res.status(401).json(null);
41
+ }
42
+
43
+ const [scheme, credentials] = authHeader.split(" ");
44
+ if (!scheme || !credentials || scheme.toLowerCase() !== "bearer") {
45
+ return res.status(400).json({ error: "Invalid Authorization header" });
46
+ }
47
+
48
+ const dbSession = await prisma.session.findUnique({
49
+ where: { token: credentials },
50
+ include: { user: true },
51
+ });
52
+
53
+ if (!dbSession) {
54
+ return res.status(401).json(null);
55
+ }
56
+
57
+ if (dbSession.expiresAt && dbSession.expiresAt.getTime() <= Date.now()) {
58
+ return res.status(401).json({ error: "Session expired" });
59
+ }
60
+
61
+ return res.json({
62
+ user: dbSession.user,
63
+ session: {
64
+ id: dbSession.id,
65
+ expiresAt: dbSession.expiresAt,
66
+ },
67
+ });
68
+ });
69
+
70
+ app.get("/device" , async(req , res)=>{
71
+ const {user_code} = req.query;
72
+ res.redirect(`${CLIENT_ORIGIN}/device?user_code=${user_code}`)
73
+ });
74
+
75
+ const start = async () => {
76
+ await ensureDbConnectionOrExit({
77
+ retries: Number(process.env.DB_CONNECT_RETRIES || 10),
78
+ initialDelayMs: Number(process.env.DB_CONNECT_INITIAL_DELAY_MS || 500),
79
+ maxDelayMs: Number(process.env.DB_CONNECT_MAX_DELAY_MS || 5000),
80
+ });
81
+
82
+ const server = app.listen(PORT, () => {
83
+ console.log(`Server is running on ${PORT}`);
84
+ });
85
+
86
+ const shutdown = async (signal) => {
87
+ try {
88
+ console.log(`\nReceived ${signal}. Shutting down...`);
89
+ server.close(() => {
90
+ process.exitCode = 0;
91
+ });
92
+ await prisma.$disconnect();
93
+ } catch {
94
+ process.exit(1);
95
+ }
96
+ };
97
+
98
+ process.on("SIGINT", () => shutdown("SIGINT"));
99
+ process.on("SIGTERM", () => shutdown("SIGTERM"));
100
+ };
101
+
102
+ start();
@@ -1,12 +1,18 @@
1
- import "../config/env.js";
1
+ import "dotenv/config";
2
+ import { execSync } from "child_process";
2
3
  import { PrismaClient } from "@prisma/client";
3
4
 
4
5
  const globalForPrisma = globalThis;
5
6
 
7
+ // Safety net: generate client if missing
8
+ try {
9
+ execSync("npx prisma generate", { stdio: "ignore" });
10
+ } catch {}
11
+
6
12
  const prisma = globalForPrisma.prisma ?? new PrismaClient();
7
13
 
8
14
  if (process.env.NODE_ENV !== "production") {
9
- globalForPrisma.prisma = prisma;
15
+ globalForPrisma.prisma = prisma;
10
16
  }
11
17
 
12
- export default prisma;
18
+ export default prisma;
@@ -0,0 +1,94 @@
1
+ -- CreateTable
2
+ CREATE TABLE "user" (
3
+ "id" TEXT NOT NULL,
4
+ "name" TEXT NOT NULL,
5
+ "email" TEXT NOT NULL,
6
+ "emailVerified" BOOLEAN NOT NULL DEFAULT false,
7
+ "image" TEXT,
8
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
9
+ "updatedAt" TIMESTAMP(3) NOT NULL,
10
+
11
+ CONSTRAINT "user_pkey" PRIMARY KEY ("id")
12
+ );
13
+
14
+ -- CreateTable
15
+ CREATE TABLE "session" (
16
+ "id" TEXT NOT NULL,
17
+ "expiresAt" TIMESTAMP(3) NOT NULL,
18
+ "token" TEXT NOT NULL,
19
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
20
+ "updatedAt" TIMESTAMP(3) NOT NULL,
21
+ "ipAddress" TEXT,
22
+ "userAgent" TEXT,
23
+ "userId" TEXT NOT NULL,
24
+
25
+ CONSTRAINT "session_pkey" PRIMARY KEY ("id")
26
+ );
27
+
28
+ -- CreateTable
29
+ CREATE TABLE "account" (
30
+ "id" TEXT NOT NULL,
31
+ "accountId" TEXT NOT NULL,
32
+ "providerId" TEXT NOT NULL,
33
+ "userId" TEXT NOT NULL,
34
+ "accessToken" TEXT,
35
+ "refreshToken" TEXT,
36
+ "idToken" TEXT,
37
+ "accessTokenExpiresAt" TIMESTAMP(3),
38
+ "refreshTokenExpiresAt" TIMESTAMP(3),
39
+ "scope" TEXT,
40
+ "password" TEXT,
41
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
42
+ "updatedAt" TIMESTAMP(3) NOT NULL,
43
+
44
+ CONSTRAINT "account_pkey" PRIMARY KEY ("id")
45
+ );
46
+
47
+ -- CreateTable
48
+ CREATE TABLE "verification" (
49
+ "id" TEXT NOT NULL,
50
+ "identifier" TEXT NOT NULL,
51
+ "value" TEXT NOT NULL,
52
+ "expiresAt" TIMESTAMP(3) NOT NULL,
53
+ "createdAt" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP,
54
+ "updatedAt" TIMESTAMP(3) NOT NULL,
55
+
56
+ CONSTRAINT "verification_pkey" PRIMARY KEY ("id")
57
+ );
58
+
59
+ -- CreateTable
60
+ CREATE TABLE "deviceCode" (
61
+ "id" TEXT NOT NULL,
62
+ "deviceCode" TEXT NOT NULL,
63
+ "userCode" TEXT NOT NULL,
64
+ "userId" TEXT,
65
+ "expiresAt" TIMESTAMP(3) NOT NULL,
66
+ "status" TEXT NOT NULL,
67
+ "lastPolledAt" TIMESTAMP(3),
68
+ "pollingInterval" INTEGER,
69
+ "clientId" TEXT,
70
+ "scope" TEXT,
71
+
72
+ CONSTRAINT "deviceCode_pkey" PRIMARY KEY ("id")
73
+ );
74
+
75
+ -- CreateIndex
76
+ CREATE UNIQUE INDEX "user_email_key" ON "user"("email");
77
+
78
+ -- CreateIndex
79
+ CREATE INDEX "session_userId_idx" ON "session"("userId");
80
+
81
+ -- CreateIndex
82
+ CREATE UNIQUE INDEX "session_token_key" ON "session"("token");
83
+
84
+ -- CreateIndex
85
+ CREATE INDEX "account_userId_idx" ON "account"("userId");
86
+
87
+ -- CreateIndex
88
+ CREATE INDEX "verification_identifier_idx" ON "verification"("identifier");
89
+
90
+ -- AddForeignKey
91
+ ALTER TABLE "session" ADD CONSTRAINT "session_userId_fkey" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
92
+
93
+ -- AddForeignKey
94
+ ALTER TABLE "account" ADD CONSTRAINT "account_userId_fkey" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE;
@@ -0,0 +1,3 @@
1
+ # Please do not edit this file manually
2
+ # It should be added in your version-control system (i.e. Git)
3
+ provider = "postgresql"
@@ -0,0 +1,115 @@
1
+
2
+ generator client {
3
+ provider = "prisma-client-js"
4
+ }
5
+
6
+ datasource db {
7
+ provider = "postgresql"
8
+ url = env("DATABASE_URL")
9
+ directUrl = env("DIRECT_DATABASE_URL")
10
+ }
11
+
12
+ model User {
13
+ id String @id
14
+ name String
15
+ email String
16
+ emailVerified Boolean @default(false)
17
+ image String?
18
+ createdAt DateTime @default(now())
19
+ updatedAt DateTime @updatedAt
20
+ sessions Session[]
21
+ accounts Account[]
22
+
23
+ conversation Conversation
24
+
25
+ @@unique([email])
26
+ @@map("user")
27
+ }
28
+
29
+ model Session {
30
+ id String @id
31
+ expiresAt DateTime
32
+ token String
33
+ createdAt DateTime @default(now())
34
+ updatedAt DateTime @updatedAt
35
+ ipAddress String?
36
+ userAgent String?
37
+ userId String
38
+ user User @relation(fields: [userId], references: [id], onDelete: Cascade)
39
+
40
+ @@unique([token])
41
+ @@index([userId])
42
+ @@map("session")
43
+ }
44
+
45
+ model Account {
46
+ id String @id
47
+ accountId String
48
+ providerId String
49
+ userId String
50
+ user User @relation(fields: [userId], references: [id], onDelete: Cascade)
51
+ accessToken String?
52
+ refreshToken String?
53
+ idToken String?
54
+ accessTokenExpiresAt DateTime?
55
+ refreshTokenExpiresAt DateTime?
56
+ scope String?
57
+ password String?
58
+ createdAt DateTime @default(now())
59
+ updatedAt DateTime @updatedAt
60
+
61
+ @@index([userId])
62
+ @@map("account")
63
+ }
64
+
65
+ model Verification {
66
+ id String @id
67
+ identifier String
68
+ value String
69
+ expiresAt DateTime
70
+ createdAt DateTime @default(now())
71
+ updatedAt DateTime @updatedAt
72
+
73
+ @@index([identifier])
74
+ @@map("verification")
75
+ }
76
+
77
+ model DeviceCode {
78
+ id String @id
79
+ deviceCode String
80
+ userCode String
81
+ userId String?
82
+ expiresAt DateTime
83
+ status String
84
+ lastPolledAt DateTime?
85
+ pollingInterval Int?
86
+ clientId String?
87
+ scope String?
88
+
89
+ @@map("deviceCode")
90
+ }
91
+
92
+ model Conversation {
93
+ id String @id @default(cuid())
94
+ userId String
95
+ title String
96
+ mode String @default("chat")
97
+ createdAt DateTime @default(now())
98
+ updatedAt DateTime @default(now()) @updatedAt
99
+
100
+ user User @relation(fields: [userId] , references : [id] , onDelete : Cascade)
101
+ messages Message[]
102
+ }
103
+
104
+ model Message{
105
+ id String @id @default(cuid())
106
+ conversationId String
107
+ role String
108
+ content String
109
+ createdAt DateTime() @default(now())
110
+
111
+ conversation Conversation @relation(fields: [conversationId], references: [id], onDelete: Cascade)
112
+
113
+
114
+ @@index([conversationId])
115
+ }