Add caddy file and update docker compose. Added IMS_TOKEN validation.
This commit is contained in:
@@ -1,2 +1,3 @@
|
|||||||
MEDIA_PATH=~/Desktop/IMS
|
MEDIA_PATH=~/Desktop/IMS
|
||||||
PORT=8000
|
PORT=8000
|
||||||
|
IMS_TOKEN=ImEXMS
|
||||||
36
docker-compose.yml
Normal file
36
docker-compose.yml
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
version: '2'
|
||||||
|
services:
|
||||||
|
ims:
|
||||||
|
ports:
|
||||||
|
- 8000:8000
|
||||||
|
volumes:
|
||||||
|
- ~:/root
|
||||||
|
#- "C:\\IMS:/media"
|
||||||
|
- "/Users/pfic/Desktop/ISM:/media"
|
||||||
|
environment:
|
||||||
|
- MEDIA_PATH=/media
|
||||||
|
- DUPLICATE_BILL_TO_VENDOR=false
|
||||||
|
- IMS_TOKEN=ThisIsAnImEXSecretTokenToBeSent
|
||||||
|
image: imexonline/media-server:latest
|
||||||
|
#image: imexonline/media-server:beta
|
||||||
|
restart: unless-stopped
|
||||||
|
watchtower:
|
||||||
|
image: containrrr/watchtower
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
- /root/.docker/config.json:/config.json
|
||||||
|
command: --interval 3600
|
||||||
|
caddy:
|
||||||
|
image: caddy/caddy:latest
|
||||||
|
container_name: caddy-service
|
||||||
|
restart: unless-stopped
|
||||||
|
ports:
|
||||||
|
- "80:80"
|
||||||
|
- "443:443"
|
||||||
|
volumes:
|
||||||
|
- $PWD/Caddyfile:/etc/caddy/Caddyfile
|
||||||
|
- caddy_data:/data
|
||||||
|
- caddy_config:/config
|
||||||
|
volumes:
|
||||||
|
caddy_data:
|
||||||
|
caddy_config:
|
||||||
@@ -1 +1,2 @@
|
|||||||
docker build . -t imexonline/media-server:latest -t imexonline/media-server:1.0
|
docker build . -t imexonline/media-server:latest -t imexonline/media-server:1.0
|
||||||
|
docker build . -t imexonline/media-server:beta
|
||||||
|
|||||||
@@ -1,12 +0,0 @@
|
|||||||
version: '2'
|
|
||||||
services:
|
|
||||||
web:
|
|
||||||
ports:
|
|
||||||
- 8000:8000
|
|
||||||
volumes:
|
|
||||||
- ~:/root
|
|
||||||
- "/Users/pfic/Desktop/ISM:/media"
|
|
||||||
environment:
|
|
||||||
- MEDIA_PATH=/media
|
|
||||||
- DUPLICATE_BILL_TO_VENDOR=false
|
|
||||||
image: imexonline/media-server:latest
|
|
||||||
@@ -20,6 +20,7 @@
|
|||||||
"file-type": "^16.5.3",
|
"file-type": "^16.5.3",
|
||||||
"fs-extra": "^10.1.0",
|
"fs-extra": "^10.1.0",
|
||||||
"gm": "^1.23.1",
|
"gm": "^1.23.1",
|
||||||
|
"helmet": "^5.0.2",
|
||||||
"image-thumbnail": "^1.0.14",
|
"image-thumbnail": "^1.0.14",
|
||||||
"morgan": "^1.10.0",
|
"morgan": "^1.10.0",
|
||||||
"multer": "^1.4.4",
|
"multer": "^1.4.4",
|
||||||
@@ -27,13 +28,13 @@
|
|||||||
"winston-daily-rotate-file": "^4.6.1"
|
"winston-daily-rotate-file": "^4.6.1"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/multer": "^1.4.7",
|
|
||||||
"@types/cors": "^2.8.12",
|
"@types/cors": "^2.8.12",
|
||||||
"@types/express": "^4.17.13",
|
"@types/express": "^4.17.13",
|
||||||
"@types/fs-extra": "^9.0.13",
|
"@types/fs-extra": "^9.0.13",
|
||||||
"@types/gm": "^1.18.11",
|
"@types/gm": "^1.18.11",
|
||||||
"@types/image-thumbnail": "^1.0.1",
|
"@types/image-thumbnail": "^1.0.1",
|
||||||
"@types/morgan": "^1.9.3",
|
"@types/morgan": "^1.9.3",
|
||||||
|
"@types/multer": "^1.4.7",
|
||||||
"@types/node": "^16.11.32",
|
"@types/node": "^16.11.32",
|
||||||
"nodemon": "^2.0.15",
|
"nodemon": "^2.0.15",
|
||||||
"ts-node": "^10.7.0",
|
"ts-node": "^10.7.0",
|
||||||
|
|||||||
40
readme.md
40
readme.md
@@ -6,6 +6,8 @@ MEDIA_PATH => Must match the mount directory of the volume. e.g.
|
|||||||
volumes: - ~:/root - "/Users/pfic/Desktop/ISM:/media"
|
volumes: - ~:/root - "/Users/pfic/Desktop/ISM:/media"
|
||||||
environment: - MEDIA_PATH=/media
|
environment: - MEDIA_PATH=/media
|
||||||
|
|
||||||
|
IMS_TOKEN => This will be validated on every request. If it is not sent, the request will be rejected.
|
||||||
|
|
||||||
# Operations
|
# Operations
|
||||||
|
|
||||||
## Bills
|
## Bills
|
||||||
@@ -13,19 +15,51 @@ environment: - MEDIA_PATH=/media
|
|||||||
By default, it will query from the job files. Anything duplicated to the vendor files is purely for reference.
|
By default, it will query from the job files. Anything duplicated to the vendor files is purely for reference.
|
||||||
If an invoice number is included, it will be default fetch that file only.
|
If an invoice number is included, it will be default fetch that file only.
|
||||||
|
|
||||||
Sample Docker Compose file.
|
Caddy is used as a reverse HTTPS proxy so that CORS does not block requests. This must sit in the same dir as the docker-compose.yml file.
|
||||||
|
|
||||||
|
```markdown
|
||||||
|
domain.com {
|
||||||
|
reverse_proxy ims:8000
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
## Sample Docker Compose file.
|
||||||
|
|
||||||
```docker
|
```docker
|
||||||
version: '2'
|
version: '2'
|
||||||
services:
|
services:
|
||||||
web:
|
ims:
|
||||||
ports:
|
ports:
|
||||||
- 8000:8000
|
- 8000:8000
|
||||||
volumes:
|
volumes:
|
||||||
- ~:/root
|
- ~:/root
|
||||||
- "D:\Images:/media"
|
- "C:\\IMS:/media"
|
||||||
|
#- "/Users/pfic/Desktop/ISM:/media"
|
||||||
environment:
|
environment:
|
||||||
- MEDIA_PATH=/media
|
- MEDIA_PATH=/media
|
||||||
- DUPLICATE_BILL_TO_VENDOR=false
|
- DUPLICATE_BILL_TO_VENDOR=false
|
||||||
|
- IMS_TOKEN=ThisIsAnImEXSecretTokenToBeSent
|
||||||
image: imexonline/media-server:latest
|
image: imexonline/media-server:latest
|
||||||
|
#image: imexonline/media-server:beta
|
||||||
|
restart: unless-stopped
|
||||||
|
watchtower:
|
||||||
|
image: containrrr/watchtower
|
||||||
|
volumes:
|
||||||
|
- /var/run/docker.sock:/var/run/docker.sock
|
||||||
|
- /root/.docker/config.json:/config.json
|
||||||
|
command: --interval 3600
|
||||||
|
caddy:
|
||||||
|
image: caddy/caddy:latest
|
||||||
|
container_name: caddy-service
|
||||||
|
restart: unless-stopped
|
||||||
|
ports:
|
||||||
|
- "80:80"
|
||||||
|
- "443:443"
|
||||||
|
volumes:
|
||||||
|
- $PWD/Caddyfile:/etc/caddy/Caddyfile
|
||||||
|
- caddy_data:/data
|
||||||
|
- caddy_config:/config
|
||||||
|
volumes:
|
||||||
|
caddy_data:
|
||||||
|
caddy_config:
|
||||||
```
|
```
|
||||||
|
|||||||
16
server.ts
16
server.ts
@@ -13,10 +13,12 @@ import morgan from "morgan";
|
|||||||
import { BillsListMedia } from "./bills/billsListMedia";
|
import { BillsListMedia } from "./bills/billsListMedia";
|
||||||
import BillRequestValidator from "./bills/billRequestValidator";
|
import BillRequestValidator from "./bills/billRequestValidator";
|
||||||
import cors from "cors";
|
import cors from "cors";
|
||||||
|
import helmet from "helmet";
|
||||||
import {
|
import {
|
||||||
BillsMediaUploadMulter,
|
BillsMediaUploadMulter,
|
||||||
BillsUploadMedia,
|
BillsUploadMedia,
|
||||||
} from "./bills/billsUploadMedia";
|
} from "./bills/billsUploadMedia";
|
||||||
|
import ValidateImsToken from "./util/validateToken";
|
||||||
|
|
||||||
dotenv.config({
|
dotenv.config({
|
||||||
path: resolve(process.cwd(), `.env.${process.env.NODE_ENV || "development"}`),
|
path: resolve(process.cwd(), `.env.${process.env.NODE_ENV || "development"}`),
|
||||||
@@ -115,26 +117,36 @@ const morganMiddleware = morgan(
|
|||||||
);
|
);
|
||||||
|
|
||||||
app.use(morganMiddleware);
|
app.use(morganMiddleware);
|
||||||
|
app.use(helmet());
|
||||||
app.post("/jobs/list", JobRequestValidator, JobsListMedia);
|
app.post("/jobs/list", ValidateImsToken, JobRequestValidator, JobsListMedia);
|
||||||
app.post(
|
app.post(
|
||||||
"/jobs/upload",
|
"/jobs/upload",
|
||||||
|
ValidateImsToken,
|
||||||
JobMediaUploadMulter.array("file"),
|
JobMediaUploadMulter.array("file"),
|
||||||
JobRequestValidator,
|
JobRequestValidator,
|
||||||
jobsUploadMedia
|
jobsUploadMedia
|
||||||
);
|
);
|
||||||
app.post(
|
app.post(
|
||||||
"/jobs/move", //JobRequestValidator,
|
"/jobs/move", //JobRequestValidator,
|
||||||
|
ValidateImsToken,
|
||||||
JobsMoveMedia
|
JobsMoveMedia
|
||||||
);
|
);
|
||||||
|
|
||||||
app.post("/bills/list", BillRequestValidator, BillsListMedia);
|
app.post("/bills/list", BillRequestValidator, BillsListMedia);
|
||||||
app.post(
|
app.post(
|
||||||
"/bills/upload",
|
"/bills/upload",
|
||||||
|
ValidateImsToken,
|
||||||
BillsMediaUploadMulter.array("file"),
|
BillsMediaUploadMulter.array("file"),
|
||||||
BillRequestValidator,
|
BillRequestValidator,
|
||||||
BillsUploadMedia
|
BillsUploadMedia
|
||||||
);
|
);
|
||||||
|
app.get(
|
||||||
|
"/",
|
||||||
|
ValidateImsToken,
|
||||||
|
(req: express.Request, res: express.Response) => {
|
||||||
|
res.send("IMS running.");
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
InitServer();
|
InitServer();
|
||||||
app.use(FolderPaths.StaticPath, express.static(FolderPaths.Root, {}));
|
app.use(FolderPaths.StaticPath, express.static(FolderPaths.Root, {}));
|
||||||
|
|||||||
28
util/validateToken.ts
Normal file
28
util/validateToken.ts
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
import { Request, Response, NextFunction } from "express";
|
||||||
|
import dotenv from "dotenv";
|
||||||
|
import { resolve } from "path";
|
||||||
|
import { logger } from "../server";
|
||||||
|
|
||||||
|
dotenv.config({
|
||||||
|
path: resolve(process.cwd(), `.env.${process.env.NODE_ENV || "development"}`),
|
||||||
|
});
|
||||||
|
|
||||||
|
export default function ValidateImsToken(
|
||||||
|
req: Request,
|
||||||
|
res: Response,
|
||||||
|
next: NextFunction
|
||||||
|
) {
|
||||||
|
const jobid: string = (req.body.jobid || "").trim();
|
||||||
|
|
||||||
|
const IMS_TOKEN: string = (process.env.IMS_TOKEN || "").trim();
|
||||||
|
|
||||||
|
if (IMS_TOKEN === "") {
|
||||||
|
next();
|
||||||
|
} else {
|
||||||
|
if (req.headers.ims_token !== IMS_TOKEN) {
|
||||||
|
res.sendStatus(401);
|
||||||
|
} else {
|
||||||
|
next();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user