Optimizing for Docker Container
This commit is contained in:
parent
11f460406b
commit
f8dfceb300
30
.drone.yml
30
.drone.yml
@ -1,8 +1,22 @@
|
|||||||
pipeline:
|
kind: pipeline
|
||||||
core:
|
type: docker
|
||||||
image: node
|
name: default
|
||||||
commands:
|
|
||||||
- node --version && npm --version
|
steps:
|
||||||
- npm install
|
- name: Build with node
|
||||||
- cd views && npm install && cd ..
|
image: node:12
|
||||||
- npm run build
|
commands:
|
||||||
|
- npm install
|
||||||
|
- cd views && npm install && cd ..
|
||||||
|
- npm run build
|
||||||
|
- name: Publish to docker
|
||||||
|
image: plugins/docker
|
||||||
|
settings:
|
||||||
|
username:
|
||||||
|
from_secret: docker_username
|
||||||
|
password:
|
||||||
|
from_secret: docker_password
|
||||||
|
auto_tag: true
|
||||||
|
repo: hibas123.azurecr.io/authserver
|
||||||
|
registry: hibas123.azurecr.io
|
||||||
|
debug: true
|
||||||
|
32
Dockerfile
Normal file
32
Dockerfile
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
FROM node:12
|
||||||
|
|
||||||
|
LABEL maintainer="Fabian Stamm <dev@fabianstamm.de>"
|
||||||
|
|
||||||
|
# RUN apt-get update
|
||||||
|
|
||||||
|
# # for https
|
||||||
|
# RUN apt-get install -yyq ca-certificates
|
||||||
|
# # install libraries
|
||||||
|
# RUN apt-get install -yyq libappindicator1 libasound2 libatk1.0-0 libc6 libcairo2 libcups2 libdbus-1-3 libexpat1 libfontconfig1 libgcc1 libgconf-2-4 libgdk-pixbuf2.0-0 libglib2.0-0 libgtk-3-0 libnspr4 libnss3 libpango-1.0-0 libpangocairo-1.0-0 libstdc++6 libx11-6 libx11-xcb1 libxcb1 libxcomposite1 libxcursor1 libxdamage1 libxext6 libxfixes3 libxi6 libxrandr2 libxrender1 libxss1 libxtst6
|
||||||
|
# # tools
|
||||||
|
# RUN apt-get install -yyq gconf-service lsb-release wget xdg-utils
|
||||||
|
# # and fonts
|
||||||
|
# RUN apt-get install -yyq fonts-liberation
|
||||||
|
|
||||||
|
RUN mkdir -p /usr/src/app
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
|
||||||
|
COPY ["package.json", "package-lock.json", "tsconfig.json", "/usr/src/app/"]
|
||||||
|
|
||||||
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
|
RUN npm install
|
||||||
|
|
||||||
|
COPY lib/ /usr/src/app/lib
|
||||||
|
COPY views/out /usr/src/app/views/out/
|
||||||
|
|
||||||
|
VOLUME [ "/usr/src/app/logs"]
|
||||||
|
|
||||||
|
EXPOSE 3004/tcp
|
||||||
|
|
||||||
|
CMD ["npm", "run", "start"]
|
2950
package-lock.json
generated
2950
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -37,8 +37,10 @@
|
|||||||
"typescript": "^3.5.3"
|
"typescript": "^3.5.3"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@hibas123/config": "^1.0.2",
|
||||||
"@hibas123/nodelogging": "^2.1.0",
|
"@hibas123/nodelogging": "^2.1.0",
|
||||||
"@hibas123/nodeloggingserver_client": "^1.1.2",
|
"@hibas123/nodeloggingserver_client": "^1.1.2",
|
||||||
|
"@hibas123/openauth-views": "file:../Views",
|
||||||
"@hibas123/safe_mongo": "^1.6.1",
|
"@hibas123/safe_mongo": "^1.6.1",
|
||||||
"body-parser": "^1.19.0",
|
"body-parser": "^1.19.0",
|
||||||
"compression": "^1.7.4",
|
"compression": "^1.7.4",
|
||||||
|
@ -1,3 +1,11 @@
|
|||||||
|
import { parse } from "@hibas123/config";
|
||||||
|
import { Logging } from "@hibas123/nodelogging";
|
||||||
|
import * as dotenv from "dotenv";
|
||||||
|
import { readFileSync } from "fs";
|
||||||
|
import * as ini from "ini";
|
||||||
|
|
||||||
|
dotenv.config();
|
||||||
|
|
||||||
export interface DatabaseConfig {
|
export interface DatabaseConfig {
|
||||||
host: string
|
host: string
|
||||||
database: string
|
database: string
|
||||||
@ -11,34 +19,52 @@ export interface WebConfig {
|
|||||||
export interface CoreConfig {
|
export interface CoreConfig {
|
||||||
name: string
|
name: string
|
||||||
url: string
|
url: string
|
||||||
dev: string
|
dev: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface Config {
|
export interface Config {
|
||||||
core: CoreConfig
|
core: CoreConfig
|
||||||
database: DatabaseConfig
|
database: DatabaseConfig
|
||||||
web: WebConfig
|
web: WebConfig
|
||||||
dev: boolean
|
|
||||||
logging: {
|
|
||||||
server: string;
|
|
||||||
appid: string;
|
|
||||||
token: string;
|
|
||||||
} | undefined
|
|
||||||
}
|
}
|
||||||
|
|
||||||
import * as ini from "ini";
|
const config = parse({
|
||||||
import { readFileSync } from "fs";
|
core: {
|
||||||
|
dev: {
|
||||||
|
default: false,
|
||||||
|
type: Boolean
|
||||||
|
},
|
||||||
|
name: {
|
||||||
|
type: String,
|
||||||
|
default: "Open Auth"
|
||||||
|
},
|
||||||
|
url: String
|
||||||
|
},
|
||||||
|
database: {
|
||||||
|
database: {
|
||||||
|
type: String,
|
||||||
|
default: "openauth"
|
||||||
|
},
|
||||||
|
host: {
|
||||||
|
type: String,
|
||||||
|
default: "localhost"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
web: {
|
||||||
|
port: {
|
||||||
|
type: Number,
|
||||||
|
default: 3004
|
||||||
|
},
|
||||||
|
secure: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, "config.ini") as any as Config;
|
||||||
|
|
||||||
import * as dotenv from "dotenv";
|
|
||||||
import { Logging } from "@hibas123/nodelogging";
|
|
||||||
dotenv.config();
|
|
||||||
|
|
||||||
const config = ini.parse(readFileSync("./config.ini").toString()) as Config;
|
|
||||||
|
|
||||||
if (config.core.dev) config.dev = Boolean(config.core.dev);
|
|
||||||
if (process.env.DEV === "true")
|
if (process.env.DEV === "true")
|
||||||
config.dev = true;
|
config.core.dev = true;
|
||||||
if (config.dev)
|
if (config.core.dev)
|
||||||
Logging.warning("DEV mode active. This can cause major performance issues, data loss and vulnerabilities! ")
|
Logging.warning("DEV mode active. This can cause major performance issues, data loss and vulnerabilities! ")
|
||||||
|
|
||||||
export default config;
|
export default config;
|
@ -6,6 +6,6 @@ if (Config.database) {
|
|||||||
if (Config.database.database) dbname = Config.database.database;
|
if (Config.database.database) dbname = Config.database.database;
|
||||||
if (Config.database.host) host = Config.database.host;
|
if (Config.database.host) host = Config.database.host;
|
||||||
}
|
}
|
||||||
if (Config.dev) dbname += "_dev";
|
if (Config.core.dev) dbname += "_dev";
|
||||||
const DB = new SafeMongo("mongodb://" + host, dbname);
|
const DB = new SafeMongo("mongodb://" + host, dbname);
|
||||||
export default DB;
|
export default DB;
|
14
src/index.ts
14
src/index.ts
@ -1,11 +1,11 @@
|
|||||||
import Logging from "@hibas123/nodelogging";
|
import Logging from "@hibas123/nodelogging";
|
||||||
import config from "./config";
|
import config from "./config";
|
||||||
|
|
||||||
import NLS from "@hibas123/nodeloggingserver_client";
|
// import NLS from "@hibas123/nodeloggingserver_client";
|
||||||
if (config.logging) {
|
// if (config.logging) {
|
||||||
let s = NLS(Logging, config.logging.server, config.logging.appid, config.logging.token);
|
// let s = NLS(Logging, config.logging.server, config.logging.appid, config.logging.token);
|
||||||
s.send(`[${new Date().toLocaleTimeString()}] Starting application`);
|
// s.send(`[${new Date().toLocaleTimeString()}] Starting application`);
|
||||||
}
|
// }
|
||||||
|
|
||||||
// if (!config.database) {
|
// if (!config.database) {
|
||||||
// Logging.error("No database config set. Terminating.")
|
// Logging.error("No database config set. Terminating.")
|
||||||
@ -28,12 +28,12 @@ import TestData from "./testdata";
|
|||||||
import DB from "./database";
|
import DB from "./database";
|
||||||
|
|
||||||
Logging.log("Connecting to Database")
|
Logging.log("Connecting to Database")
|
||||||
if (config.dev) {
|
if (config.core.dev) {
|
||||||
Logging.warning("Running in dev mode! Database will be cleared!")
|
Logging.warning("Running in dev mode! Database will be cleared!")
|
||||||
}
|
}
|
||||||
DB.connect().then(async () => {
|
DB.connect().then(async () => {
|
||||||
Logging.log("Database connected")
|
Logging.log("Database connected")
|
||||||
if (config.dev)
|
if (config.core.dev)
|
||||||
await TestData()
|
await TestData()
|
||||||
let web = new Web(config.web)
|
let web = new Web(config.web)
|
||||||
web.listen()
|
web.listen()
|
||||||
|
@ -10,7 +10,7 @@ function loadStatic() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export default function GetAdminPage(__: typeof i__): string {
|
export default function GetAdminPage(__: typeof i__): string {
|
||||||
if (config.dev) {
|
if (config.core.dev) {
|
||||||
loadStatic()
|
loadStatic()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ function loadStatic() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export default function GetAuthPage(__: typeof i__, appname: string, scopes: { name: string, description: string, logo: string }[]): string {
|
export default function GetAuthPage(__: typeof i__, appname: string, scopes: { name: string, description: string, logo: string }[]): string {
|
||||||
if (config.dev) {
|
if (config.core.dev) {
|
||||||
loadStatic()
|
loadStatic()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,7 +28,7 @@ function loadStatic() {
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
export default function GetLoginPage(__: typeof i__): string {
|
export default function GetLoginPage(__: typeof i__): string {
|
||||||
if (config.dev) {
|
if (config.core.dev) {
|
||||||
loadStatic()
|
loadStatic()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ function loadStatic() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export default function GetRegistrationPage(__: typeof i__): string {
|
export default function GetRegistrationPage(__: typeof i__): string {
|
||||||
if (config.dev) {
|
if (config.core.dev) {
|
||||||
loadStatic()
|
loadStatic()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ import { UserMiddleware, GetUserMiddleware } from "../api/middlewares/user";
|
|||||||
|
|
||||||
Handlebars.registerHelper("appname", () => config.core.name);
|
Handlebars.registerHelper("appname", () => config.core.name);
|
||||||
|
|
||||||
const cacheTime = config.dev ? moment.duration(1, "month").asSeconds() : 10;
|
const cacheTime = config.core.dev ? moment.duration(1, "month").asSeconds() : 10;
|
||||||
|
|
||||||
const ViewRouter: IRouter<void> = Router();
|
const ViewRouter: IRouter<void> = Router();
|
||||||
ViewRouter.get("/", UserMiddleware, (req, res) => {
|
ViewRouter.get("/", UserMiddleware, (req, res) => {
|
||||||
@ -85,7 +85,7 @@ ViewRouter.get("/auth", Stacker(GetUserMiddleware(false, true), async (req, res)
|
|||||||
res.send(GetAuthPage(req.__, client.name, scopes));
|
res.send(GetAuthPage(req.__, client.name, scopes));
|
||||||
}));
|
}));
|
||||||
|
|
||||||
if (config.dev) {
|
if (config.core.dev) {
|
||||||
const logo = ""
|
const logo = ""
|
||||||
ViewRouter.get("/devauth", (req, res) => {
|
ViewRouter.get("/devauth", (req, res) => {
|
||||||
res.send(GetAuthPage(req.__, "Test 05265", [
|
res.send(GetAuthPage(req.__, "Test 05265", [
|
||||||
|
Loading…
Reference in New Issue
Block a user