fix: update plugin api call
This commit is contained in:
		
							parent
							
								
									bbb7f398ab
								
							
						
					
					
						commit
						72d0364fee
					
				@ -126,16 +126,23 @@ function addButton() {
 | 
				
			|||||||
    console.log(graph);
 | 
					    console.log(graph);
 | 
				
			||||||
    console.log(prompt);
 | 
					    console.log(prompt);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    const endpoint = localStorage.getItem("endpoint");
 | 
				
			||||||
 | 
					    const apiKey = localStorage.getItem("apiKey");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (!endpoint || !apiKey) {
 | 
				
			||||||
 | 
					      configDialog.show();
 | 
				
			||||||
 | 
					      return;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    deploy.textContent = "Deploying...";
 | 
					    deploy.textContent = "Deploying...";
 | 
				
			||||||
    deploy.style.color = "orange";
 | 
					    deploy.style.color = "orange";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    const apiRoute = "http://localhost:3000/api/upload";
 | 
					    const apiRoute = endpoint + "/api/upload"
 | 
				
			||||||
    const userId = "user_2ZA6vuKD3IJXju16oJVQGLBcWwg";
 | 
					    // const userId = apiKey
 | 
				
			||||||
    try {
 | 
					    try {
 | 
				
			||||||
      let data = await fetch(apiRoute, {
 | 
					      let data = await fetch(apiRoute, {
 | 
				
			||||||
        method: "POST",
 | 
					        method: "POST",
 | 
				
			||||||
        body: JSON.stringify({
 | 
					        body: JSON.stringify({
 | 
				
			||||||
          user_id: userId,
 | 
					 | 
				
			||||||
          workflow_name,
 | 
					          workflow_name,
 | 
				
			||||||
          workflow_id,
 | 
					          workflow_id,
 | 
				
			||||||
          workflow: prompt.workflow,
 | 
					          workflow: prompt.workflow,
 | 
				
			||||||
@ -143,6 +150,7 @@ function addButton() {
 | 
				
			|||||||
        }),
 | 
					        }),
 | 
				
			||||||
        headers: {
 | 
					        headers: {
 | 
				
			||||||
          "Content-Type": "application/json",
 | 
					          "Content-Type": "application/json",
 | 
				
			||||||
 | 
					          "Authorization": "Bearer " + apiKey,
 | 
				
			||||||
        },
 | 
					        },
 | 
				
			||||||
      });
 | 
					      });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -181,7 +189,15 @@ function addButton() {
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const config = document.createElement("button");
 | 
				
			||||||
 | 
					  config.textContent = "Config";
 | 
				
			||||||
 | 
					  config.className = "configbtn";
 | 
				
			||||||
 | 
					  config.onclick = () => {
 | 
				
			||||||
 | 
					    configDialog.show();
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
  menu.append(deploy);
 | 
					  menu.append(deploy);
 | 
				
			||||||
 | 
					  menu.append(config);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
app.registerExtension(ext);
 | 
					app.registerExtension(ext);
 | 
				
			||||||
@ -221,3 +237,56 @@ export class InfoDialog extends ComfyDialog {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export const infoDialog = new InfoDialog()
 | 
					export const infoDialog = new InfoDialog()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export class ConfigDialog extends ComfyDialog {
 | 
				
			||||||
 | 
					  constructor() {
 | 
				
			||||||
 | 
					    super();
 | 
				
			||||||
 | 
					    this.element.classList.add("comfy-normal-modal");
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  createButtons() {
 | 
				
			||||||
 | 
					    return [
 | 
				
			||||||
 | 
					      $el("button", {
 | 
				
			||||||
 | 
					        type: "button",
 | 
				
			||||||
 | 
					        textContent: "Save",
 | 
				
			||||||
 | 
					        onclick: () => this.save(),
 | 
				
			||||||
 | 
					      }),
 | 
				
			||||||
 | 
					      $el("button", {
 | 
				
			||||||
 | 
					        type: "button",
 | 
				
			||||||
 | 
					        textContent: "Close",
 | 
				
			||||||
 | 
					        onclick: () => this.close(),
 | 
				
			||||||
 | 
					      }),
 | 
				
			||||||
 | 
					    ];
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  close() {
 | 
				
			||||||
 | 
					    this.element.style.display = "none";
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  save() {
 | 
				
			||||||
 | 
					    const endpoint = this.textElement.querySelector("#endpoint").value;
 | 
				
			||||||
 | 
					    const apiKey = this.textElement.querySelector("#apiKey").value;
 | 
				
			||||||
 | 
					    localStorage.setItem("endpoint", endpoint);
 | 
				
			||||||
 | 
					    localStorage.setItem("apiKey", apiKey);
 | 
				
			||||||
 | 
					    this.close();
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  show() {
 | 
				
			||||||
 | 
					    this.textElement.innerHTML = `
 | 
				
			||||||
 | 
					      <div style="width: 600px;">
 | 
				
			||||||
 | 
					      <label style="color: white;">
 | 
				
			||||||
 | 
					        Endpoint:
 | 
				
			||||||
 | 
					        <input id="endpoint" style="width: 100%;" type="text" value="${localStorage.getItem("endpoint") || ""}">
 | 
				
			||||||
 | 
					      </label>
 | 
				
			||||||
 | 
					      <label style="color: white;">
 | 
				
			||||||
 | 
					        API Key:
 | 
				
			||||||
 | 
					        <input id="apiKey" style="width: 100%;" type="text" value="${localStorage.getItem("apiKey") || ""}">
 | 
				
			||||||
 | 
					      </label>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
 | 
					    `;
 | 
				
			||||||
 | 
					    this.element.style.display = "flex";
 | 
				
			||||||
 | 
					    this.element.style.zIndex = 1001;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export const configDialog = new ConfigDialog();
 | 
				
			||||||
@ -16,3 +16,5 @@ SPACES_REGION="nyc3"
 | 
				
			|||||||
SPACES_BUCKET="comfyui-deploy"
 | 
					SPACES_BUCKET="comfyui-deploy"
 | 
				
			||||||
SPACES_KEY="xyz"
 | 
					SPACES_KEY="xyz"
 | 
				
			||||||
SPACES_SECRET="aaa"
 | 
					SPACES_SECRET="aaa"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					JWT_SECRET="openssl rand -hex 32"
 | 
				
			||||||
							
								
								
									
										
											BIN
										
									
								
								web/bun.lockb
									
									
									
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								web/bun.lockb
									
									
									
									
									
								
							
										
											Binary file not shown.
										
									
								
							@ -28,11 +28,13 @@
 | 
				
			|||||||
    "@radix-ui/react-slot": "^1.0.2",
 | 
					    "@radix-ui/react-slot": "^1.0.2",
 | 
				
			||||||
    "@radix-ui/react-tabs": "^1.0.4",
 | 
					    "@radix-ui/react-tabs": "^1.0.4",
 | 
				
			||||||
    "@tanstack/react-table": "^8.10.7",
 | 
					    "@tanstack/react-table": "^8.10.7",
 | 
				
			||||||
 | 
					    "@types/jsonwebtoken": "^9.0.5",
 | 
				
			||||||
    "@types/uuid": "^9.0.7",
 | 
					    "@types/uuid": "^9.0.7",
 | 
				
			||||||
    "class-variance-authority": "^0.7.0",
 | 
					    "class-variance-authority": "^0.7.0",
 | 
				
			||||||
    "clsx": "^2.0.0",
 | 
					    "clsx": "^2.0.0",
 | 
				
			||||||
    "dayjs": "^1.11.10",
 | 
					    "dayjs": "^1.11.10",
 | 
				
			||||||
    "drizzle-orm": "^0.29.1",
 | 
					    "drizzle-orm": "^0.29.1",
 | 
				
			||||||
 | 
					    "jsonwebtoken": "^9.0.2",
 | 
				
			||||||
    "lucide-react": "^0.294.0",
 | 
					    "lucide-react": "^0.294.0",
 | 
				
			||||||
    "nanoid": "^5.0.4",
 | 
					    "nanoid": "^5.0.4",
 | 
				
			||||||
    "next": "14.0.3",
 | 
					    "next": "14.0.3",
 | 
				
			||||||
 | 
				
			|||||||
@ -7,6 +7,7 @@ import {
 | 
				
			|||||||
} from "@/db/schema";
 | 
					} from "@/db/schema";
 | 
				
			||||||
import { parseDataSafe } from "@/lib/parseDataSafe";
 | 
					import { parseDataSafe } from "@/lib/parseDataSafe";
 | 
				
			||||||
import { sql } from "drizzle-orm";
 | 
					import { sql } from "drizzle-orm";
 | 
				
			||||||
 | 
					import jwt from "jsonwebtoken";
 | 
				
			||||||
import { NextResponse } from "next/server";
 | 
					import { NextResponse } from "next/server";
 | 
				
			||||||
import { z } from "zod";
 | 
					import { z } from "zod";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -17,7 +18,7 @@ const corsHeaders = {
 | 
				
			|||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const UploadRequest = z.object({
 | 
					const UploadRequest = z.object({
 | 
				
			||||||
  user_id: z.string(),
 | 
					  // user_id: z.string(),
 | 
				
			||||||
  workflow_id: z.string().optional(),
 | 
					  workflow_id: z.string().optional(),
 | 
				
			||||||
  workflow_name: z.string().optional(),
 | 
					  workflow_name: z.string().optional(),
 | 
				
			||||||
  workflow: workflowType,
 | 
					  workflow: workflowType,
 | 
				
			||||||
@ -35,8 +36,39 @@ export async function OPTIONS(request: Request) {
 | 
				
			|||||||
  });
 | 
					  });
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const APIKeyBodyRequest = z.object({
 | 
				
			||||||
 | 
					  user_id: z.string().optional(),
 | 
				
			||||||
 | 
					  org_id: z.string().optional(),
 | 
				
			||||||
 | 
					  iat: z.number(),
 | 
				
			||||||
 | 
					});
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function parseJWT(token: string) {
 | 
				
			||||||
 | 
					  try {
 | 
				
			||||||
 | 
					    // Verify the token - this also decodes it
 | 
				
			||||||
 | 
					    const decoded = jwt.verify(token, process.env.JWT_SECRET!);
 | 
				
			||||||
 | 
					    return APIKeyBodyRequest.parse(decoded);
 | 
				
			||||||
 | 
					  } catch (err) {
 | 
				
			||||||
 | 
					    // Handle error (token is invalid, expired, etc.)
 | 
				
			||||||
 | 
					    console.error(err);
 | 
				
			||||||
 | 
					    return null;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export async function POST(request: Request) {
 | 
					export async function POST(request: Request) {
 | 
				
			||||||
  console.log("hi");
 | 
					  const token = request.headers.get("Authorization")?.split(" ")?.[1]; // Assuming token is sent as "Bearer your_token"
 | 
				
			||||||
 | 
					  const userData = token ? parseJWT(token) : undefined;
 | 
				
			||||||
 | 
					  if (!userData) {
 | 
				
			||||||
 | 
					    return new NextResponse("Invalid or expired token", {
 | 
				
			||||||
 | 
					      status: 401,
 | 
				
			||||||
 | 
					      headers: corsHeaders,
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  console.log(userData);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const { user_id, org_id } = userData;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (!user_id) return new NextResponse("Invalid user_id", { status: 401 });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const [data, error] = await parseDataSafe(
 | 
					  const [data, error] = await parseDataSafe(
 | 
				
			||||||
    UploadRequest,
 | 
					    UploadRequest,
 | 
				
			||||||
@ -47,7 +79,7 @@ export async function POST(request: Request) {
 | 
				
			|||||||
  if (!data || error) return error;
 | 
					  if (!data || error) return error;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const {
 | 
					  const {
 | 
				
			||||||
    user_id,
 | 
					    // user_id,
 | 
				
			||||||
    workflow,
 | 
					    workflow,
 | 
				
			||||||
    workflow_api,
 | 
					    workflow_api,
 | 
				
			||||||
    workflow_id: _workflow_id,
 | 
					    workflow_id: _workflow_id,
 | 
				
			||||||
 | 
				
			|||||||
@ -4,31 +4,42 @@ import { db } from "@/db/db";
 | 
				
			|||||||
import { apiKeyTable } from "@/db/schema";
 | 
					import { apiKeyTable } from "@/db/schema";
 | 
				
			||||||
import { auth } from "@clerk/nextjs";
 | 
					import { auth } from "@clerk/nextjs";
 | 
				
			||||||
import { and, desc, eq } from "drizzle-orm";
 | 
					import { and, desc, eq } from "drizzle-orm";
 | 
				
			||||||
import { customAlphabet } from "nanoid";
 | 
					import jwt from "jsonwebtoken";
 | 
				
			||||||
import { revalidatePath } from "next/cache";
 | 
					import { revalidatePath } from "next/cache";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export const nanoid = customAlphabet(
 | 
					// export const nanoid = customAlphabet(
 | 
				
			||||||
  "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"
 | 
					//   "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"
 | 
				
			||||||
);
 | 
					// );
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const prefixes = {
 | 
					// const prefixes = {
 | 
				
			||||||
  cd: "cd",
 | 
					//   cd: "cd",
 | 
				
			||||||
} as const;
 | 
					// } as const;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function newId(prefix: keyof typeof prefixes): string {
 | 
					// function newId(prefix: keyof typeof prefixes): string {
 | 
				
			||||||
  return [prefixes[prefix], nanoid(16)].join("_");
 | 
					//   return [prefixes[prefix], nanoid(16)].join("_");
 | 
				
			||||||
}
 | 
					// }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
export async function addNewAPIKey(name: string) {
 | 
					export async function addNewAPIKey(name: string) {
 | 
				
			||||||
  const { userId, orgId } = auth();
 | 
					  const { userId, orgId } = auth();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (!userId) throw new Error("No user id");
 | 
					  if (!userId) throw new Error("No user id");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  let token: string;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (orgId) {
 | 
				
			||||||
 | 
					    token = jwt.sign(
 | 
				
			||||||
 | 
					      { user_id: userId, org_id: orgId },
 | 
				
			||||||
 | 
					      process.env.JWT_SECRET!
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  } else {
 | 
				
			||||||
 | 
					    token = jwt.sign({ user_id: userId }, process.env.JWT_SECRET!);
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const key = await db
 | 
					  const key = await db
 | 
				
			||||||
    .insert(apiKeyTable)
 | 
					    .insert(apiKeyTable)
 | 
				
			||||||
    .values({
 | 
					    .values({
 | 
				
			||||||
      name: name,
 | 
					      name: name,
 | 
				
			||||||
      key: newId("cd"),
 | 
					      key: token,
 | 
				
			||||||
      user_id: userId,
 | 
					      user_id: userId,
 | 
				
			||||||
      org_id: orgId,
 | 
					      org_id: orgId,
 | 
				
			||||||
    })
 | 
					    })
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user