mirror of
https://github.com/fosrl/pangolin.git
synced 2025-08-02 00:55:48 +02:00
Merge branch 'main' of https://github.com/fosrl/pangolin
This commit is contained in:
commit
c1d87363dd
8 changed files with 64 additions and 9 deletions
|
@ -1,6 +1,4 @@
|
||||||
import { Router } from "express";
|
import { Router } from "express";
|
||||||
import { getConfig } from "./getConfig";
|
|
||||||
import { receiveBandwidth } from "./receiveBandwidth";
|
|
||||||
|
|
||||||
const badger = Router();
|
const badger = Router();
|
||||||
|
|
||||||
|
@ -8,7 +6,4 @@ badger.get("/", (_, res) => {
|
||||||
res.status(200).json({ message: "Healthy" });
|
res.status(200).json({ message: "Healthy" });
|
||||||
});
|
});
|
||||||
|
|
||||||
badger.get("/getConfig", getConfig);
|
|
||||||
badger.post("/receiveBandwidth", receiveBandwidth);
|
|
||||||
|
|
||||||
export default badger;
|
export default badger;
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
import { Router } from "express";
|
import { Router } from "express";
|
||||||
import badger from "./badger/badger";
|
import gerbil from "./gerbil/gerbil";
|
||||||
import pangolin from "./pangolin/pangolin";
|
import pangolin from "./pangolin/pangolin";
|
||||||
|
|
||||||
const unauth = Router();
|
const unauth = Router();
|
||||||
|
@ -8,7 +8,7 @@ unauth.get("/", (_, res) => {
|
||||||
res.status(200).json({ message: "Healthy" });
|
res.status(200).json({ message: "Healthy" });
|
||||||
});
|
});
|
||||||
|
|
||||||
unauth.use("/newt", badger);
|
unauth.use("/newt", gerbil);
|
||||||
unauth.use("/pangolin", pangolin);
|
unauth.use("/pangolin", pangolin);
|
||||||
|
|
||||||
export default unauth;
|
export default unauth;
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
import { Router } from "express";
|
import { Router } from "express";
|
||||||
|
import { getConfig } from "./getConfig";
|
||||||
|
import { receiveBandwidth } from "./receiveBandwidth";
|
||||||
|
|
||||||
const gerbil = Router();
|
const gerbil = Router();
|
||||||
|
|
||||||
|
@ -6,4 +8,7 @@ gerbil.get("/", (_, res) => {
|
||||||
res.status(200).json({ message: "Healthy" });
|
res.status(200).json({ message: "Healthy" });
|
||||||
});
|
});
|
||||||
|
|
||||||
|
gerbil.get("/getConfig", getConfig);
|
||||||
|
gerbil.post("/receiveBandwidth", receiveBandwidth);
|
||||||
|
|
||||||
export default gerbil;
|
export default gerbil;
|
||||||
|
|
|
@ -45,7 +45,7 @@ export const receiveBandwidth = async (req: Request, res: Response, next: NextFu
|
||||||
|
|
||||||
res.status(200).json({ message: 'Bandwidth data updated successfully' });
|
res.status(200).json({ message: 'Bandwidth data updated successfully' });
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error('Error updating bandwidth data:', error);
|
logger.error('Error updating bandwidth data:', error);
|
||||||
res.status(500).json({ error: 'Internal server error' });
|
res.status(500).json({ error: 'Internal server error' });
|
||||||
}
|
}
|
||||||
};
|
};
|
43
server/routers/global/createSite.ts
Normal file
43
server/routers/global/createSite.ts
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
import { Request, Response, NextFunction } from 'express';
|
||||||
|
import { DrizzleError, eq } from 'drizzle-orm';
|
||||||
|
import { sites, resources, targets, exitNodes } from '@server/db/schema';
|
||||||
|
import db from '@server/db';
|
||||||
|
import logger from '@server/logger';
|
||||||
|
|
||||||
|
interface CreateSiteRequest {
|
||||||
|
publicKey: string;
|
||||||
|
name: string;
|
||||||
|
orgId: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const createSite = async (req: Request, res: Response, next: NextFunction): Promise<void> => {
|
||||||
|
try {
|
||||||
|
const createSiteRequest: CreateSiteRequest = req.body;
|
||||||
|
|
||||||
|
// pick a subdomain not used
|
||||||
|
// pick a subnet not used
|
||||||
|
// pick an exit node
|
||||||
|
|
||||||
|
// const site = db
|
||||||
|
// .insert(sites)
|
||||||
|
// .values({
|
||||||
|
// orgId: createSiteRequest.orgId,
|
||||||
|
// exitNode: exitNodeId,
|
||||||
|
// name: createSiteRequest.name,
|
||||||
|
// subdomain: subdomain,
|
||||||
|
// pubKey: createSiteRequest.publicKey,
|
||||||
|
// subnet: subnet,
|
||||||
|
// })
|
||||||
|
// .returning()
|
||||||
|
// .get();
|
||||||
|
|
||||||
|
const site = {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
res.status(200).json(site);
|
||||||
|
} catch (error) {
|
||||||
|
logger.error('Error creating site:', error);
|
||||||
|
res.status(500).json({ error: 'Internal server error' });
|
||||||
|
}
|
||||||
|
};
|
12
server/routers/global/global.ts
Normal file
12
server/routers/global/global.ts
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
import { Router } from "express";
|
||||||
|
import { createSite } from "./createSite";
|
||||||
|
|
||||||
|
const global = Router();
|
||||||
|
|
||||||
|
global.get("/", (_, res) => {
|
||||||
|
res.status(200).json({ message: "Healthy" });
|
||||||
|
});
|
||||||
|
|
||||||
|
global.get("/createSite", createSite);
|
||||||
|
|
||||||
|
export default global;
|
|
@ -1,6 +1,6 @@
|
||||||
import { Router } from "express";
|
import { Router } from "express";
|
||||||
import badger from "./badger/badger";
|
|
||||||
import gerbil from "./gerbil/gerbil";
|
import gerbil from "./gerbil/gerbil";
|
||||||
|
import badger from "./badger/badger";
|
||||||
import { traefikConfigProvider } from "@server/traefik-config-provider";
|
import { traefikConfigProvider } from "@server/traefik-config-provider";
|
||||||
|
|
||||||
const unauth = Router();
|
const unauth = Router();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue