From e306cdb2c8e58fc1aef79b95cba5d4cc96ac7658 Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Fri, 12 Feb 2021 17:04:08 +0000 Subject: [PATCH 1/9] =?UTF-8?q?=F0=9F=A7=BENew=20changelog=20file=20versio?= =?UTF-8?q?n=20[CI=20SKIP]=20[skip=20ci]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- CHANGELOG.md | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 00ef120..442b8a3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,16 +2,20 @@ All notable changes to this project will be documented in this file. Dates are displayed in UTC. +#### [v0.3.0](https://git.odit.services/lfk/document-server/compare/v0.3.0...v0.3.0) + #### [v0.3.0](https://git.odit.services/lfk/document-server/compare/v0.2.0...v0.3.0) -- 🚀Bumped version to v0.3.0 [`449a96b`](https://git.odit.services/lfk/document-server/commit/449a96b3027fe93d8042b30420245f66e92f14b8) -- Merge pull request 'Card generation feature/14-card_generation' (#24) from feature/14-card_generation into dev [`703eaa0`](https://git.odit.services/lfk/document-server/commit/703eaa0e9d667b628eab4e8496689fe66238f896) +> 12 February 2021 + +- Merge pull request 'Alpha Release 0.3.0 - Runnercard generation' (#25) from dev into main [`406add3`](https://git.odit.services/lfk/document-server/commit/406add3d517473d01628b6405569de6cb85114e0) - 🚀Bumped version to v0.2.0 [`491cdb8`](https://git.odit.services/lfk/document-server/commit/491cdb8d71a80ea196d16334c0c80b8f7cc859c5) - Added card generation speed tests (part 1) [`68572b1`](https://git.odit.services/lfk/document-server/commit/68572b194eb740238be8101efed6fdb2a207f65b) - Implemented first experimental speedtest [`e3a45a6`](https://git.odit.services/lfk/document-server/commit/e3a45a61ac3b2d691c2f75d36155896b7ed301d8) - Added basic logic to generate two-sided runnercards [`d3a213c`](https://git.odit.services/lfk/document-server/commit/d3a213ce3326aeb96d924e16a31fc87bf82eb5b3) - 🧾New changelog file version [CI SKIP] [skip ci] [`149bf18`](https://git.odit.services/lfk/document-server/commit/149bf1849db20b863ec998a72c77559ec401bc32) - Fixed double-sided printing [`7f58dd6`](https://git.odit.services/lfk/document-server/commit/7f58dd694b53152069c2095b2e18dd3a46cd04dd) +- 🧾New changelog file version [CI SKIP] [skip ci] [`e74b9a4`](https://git.odit.services/lfk/document-server/commit/e74b9a4c9d041780e0cfd8c4d68a5b63f916e091) - Added basic card generation function [`8fc6c71`](https://git.odit.services/lfk/document-server/commit/8fc6c7176ee92f813db1e1d4b3e5ef1b2f4e1aef) - Beautified output a bit [`aefe549`](https://git.odit.services/lfk/document-server/commit/aefe5493b06c04cc2b20029e1f7fc5f15ec9c04e) - Added barcode generatin [`5c075bc`](https://git.odit.services/lfk/document-server/commit/5c075bce8b94ff4482448c3cd56bdc28cbe0a7d9) @@ -25,6 +29,8 @@ All notable changes to this project will be documented in this file. Dates are d - Fixed runnercard backside padding [`08e8587`](https://git.odit.services/lfk/document-server/commit/08e858726c1462b599ba9cb3f7fb057f35178b83) - Added sizing for the real cards [`b92a6f7`](https://git.odit.services/lfk/document-server/commit/b92a6f7b2b98fb0074d5a563d9918295e9ec0274) - 🧾New changelog file version [CI SKIP] [skip ci] [`8a90f63`](https://git.odit.services/lfk/document-server/commit/8a90f63b0919376beefef6a52aae9a59337aea59) +- 🚀Bumped version to v0.3.0 [`449a96b`](https://git.odit.services/lfk/document-server/commit/449a96b3027fe93d8042b30420245f66e92f14b8) +- Merge pull request 'Card generation feature/14-card_generation' (#24) from feature/14-card_generation into dev [`703eaa0`](https://git.odit.services/lfk/document-server/commit/703eaa0e9d667b628eab4e8496689fe66238f896) - Added speedtest script to package [`75b8b28`](https://git.odit.services/lfk/document-server/commit/75b8b281b87d9b173093f16beae12d707ec05052) - Fixed bug in array swapping function [`9697d53`](https://git.odit.services/lfk/document-server/commit/9697d53a1527854536f8ddf5426f7ca902772f51) - Added **very** basic backside [`68f46a4`](https://git.odit.services/lfk/document-server/commit/68f46a45b5a51c8a8edafca852cb274af388fa76) -- 2.47.2 From bdeadd274bc0f9c8cbab35a8a5605bef4c22ba6c Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 16:09:58 +0100 Subject: [PATCH 2/9] Implemented basic auth ref #26 --- src/app.ts | 2 ++ src/config.ts | 23 ++++++++++++++++++++++- src/controllers/PdfController.ts | 3 ++- src/middlewares/AuthChecker.ts | 14 ++++++++++++++ 4 files changed, 40 insertions(+), 2 deletions(-) create mode 100644 src/middlewares/AuthChecker.ts diff --git a/src/app.ts b/src/app.ts index 6996e09..78846f3 100644 --- a/src/app.ts +++ b/src/app.ts @@ -3,11 +3,13 @@ import "reflect-metadata"; import { createExpressServer } from "routing-controllers"; import { config, e as errors } from './config'; import loaders from "./loaders/index"; +import AuthChecker from './middlewares/AuthChecker'; import { ErrorHandler } from './middlewares/ErrorHandler'; const CONTROLLERS_FILE_EXTENSION = process.env.NODE_ENV === 'production' ? 'js' : 'ts'; const app = createExpressServer({ middlewares: [ErrorHandler], + authorizationChecker: AuthChecker, development: config.development, cors: true, controllers: [`${__dirname}/controllers/*.${CONTROLLERS_FILE_EXTENSION}`], diff --git a/src/config.ts b/src/config.ts index 6815cc2..ad886d7 100644 --- a/src/config.ts +++ b/src/config.ts @@ -1,3 +1,4 @@ +import consola from "consola"; import { config as configDotenv } from 'dotenv'; configDotenv(); @@ -9,7 +10,8 @@ export const config = { currency_symbol: process.env.CURRENCY_SYMBOL || "€", sponsoring_receipt_minimum_amount: process.env.SPONSORING_RECEIPT_MINIMUM_AMOUNT || "10", codeformat: process.env.CODEFORMAT || "qrcode", - sponor_logos: getSponsorLogos() + sponor_logos: getSponsorLogos(), + api_key: getApiKey(), } let errors = 0 if (typeof config.internal_port !== "number") { @@ -27,4 +29,23 @@ function getSponsorLogos(): string[] { return [""]; } } + +function getApiKey(): string { + const key = process.env.API_KEY; + if (!key) { + consola.info("No API key set - generating a random one..."); + let result = ''; + const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'; + const charactersLength = characters.length; + for (var i = 0; i < 64; i++) { + result += characters.charAt(Math.floor(Math.random() * charactersLength)); + } + consola.info(`API KEY: ${result}`) + return result; + } + if (key.length < 64) { + consola.error(`API key is too short - minimum: 64, current: ${key.length}`) + throw new Error("API_KEY too short.") + } +} export let e = errors \ No newline at end of file diff --git a/src/controllers/PdfController.ts b/src/controllers/PdfController.ts index 17e2ca6..15f0db4 100644 --- a/src/controllers/PdfController.ts +++ b/src/controllers/PdfController.ts @@ -1,4 +1,4 @@ -import { Body, JsonController, Post, QueryParam, Res } from 'routing-controllers'; +import { Authorized, Body, JsonController, Post, QueryParam, Res } from 'routing-controllers'; import { OpenAPI } from 'routing-controllers-openapi'; import { Runner } from '../models/Runner'; import { RunnerCard } from '../models/RunnerCard'; @@ -10,6 +10,7 @@ import { PdfCreator } from '../PdfCreator'; * All endpoints have to accept a locale query-param to support i18n. */ @JsonController() +@Authorized() export class PdfController { private pdf: PdfCreator = new PdfCreator(); private initialized: boolean = false; diff --git a/src/middlewares/AuthChecker.ts b/src/middlewares/AuthChecker.ts new file mode 100644 index 0000000..e4ede50 --- /dev/null +++ b/src/middlewares/AuthChecker.ts @@ -0,0 +1,14 @@ +import { Action } from "routing-controllers"; +import { config } from '../config'; + +/** + * Handles authentication via jwt's (Bearer authorization header) for all api endpoints using the @Authorized decorator. + * @param action Routing-Controllers action object that provides request and response objects among other stuff. + * @param permissions The permissions that the endpoint using @Authorized requires. + */ +const AuthChecker = async (action: Action) => { + const provided_token = action.request.query.key; + return provided_token == config.api_key; +} + +export default AuthChecker \ No newline at end of file -- 2.47.2 From 7be211f8b7b26f7f620df81af4ebde5eec2feec2 Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 16:14:08 +0100 Subject: [PATCH 3/9] Fixed bug ref #26 --- src/config.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/src/config.ts b/src/config.ts index ad886d7..e7da417 100644 --- a/src/config.ts +++ b/src/config.ts @@ -47,5 +47,6 @@ function getApiKey(): string { consola.error(`API key is too short - minimum: 64, current: ${key.length}`) throw new Error("API_KEY too short.") } + return key } export let e = errors \ No newline at end of file -- 2.47.2 From 454309278ef20a2b97248277b07a7b58a063618d Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 16:16:36 +0100 Subject: [PATCH 4/9] Added api key to env doc ref #26 --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index 7e77e25..ac522c5 100644 --- a/README.md +++ b/README.md @@ -35,6 +35,7 @@ The basic generation mechanism makes the templates and routes interchangeable (i | CURRENCY_SYMBOL | String | "€" | The your currency's symbol - used to generate pdf text. | SPONSORING_RECEIPT_MINIMUM_AMOUNT | String | "10" | The mimimum total donation amount a sponsor has to donate to be able to receive a donation receipt - used to generate pdf text. | SPONOR_LOGOS | Array | Empty png | The sponsor images you want to loop through. You can provide them via http url, local file or base64-encoded image. +| API_KEY | String(min length: 64) | Random generated string | The api key you want to use for auth (query-param `key`), has to be at least 64 chars long. ## Templates > The document server uses html templates to generate various pdf documents. -- 2.47.2 From 729f2d7240b54ffe2d4db36cce29de0afdfc9417 Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 16:24:47 +0100 Subject: [PATCH 5/9] Added auth to openapi spec ref #26 --- src/apispec.ts | 8 ++++++++ src/controllers/PdfController.ts | 1 + 2 files changed, 9 insertions(+) diff --git a/src/apispec.ts b/src/apispec.ts index 4a1f496..9aa3018 100644 --- a/src/apispec.ts +++ b/src/apispec.ts @@ -14,6 +14,14 @@ export function generateSpec(storage: MetadataArgsStorage, schemas) { { components: { schemas, + "securitySchemes": { + "AuthToken": { + "type": "apiKey", + "in": "query", + "name": "key", + description: "A simple api key. See the README's env section for more details." + } + } }, info: { description: "The the API for the LfK! document server.", diff --git a/src/controllers/PdfController.ts b/src/controllers/PdfController.ts index 15f0db4..3e82693 100644 --- a/src/controllers/PdfController.ts +++ b/src/controllers/PdfController.ts @@ -11,6 +11,7 @@ import { PdfCreator } from '../PdfCreator'; */ @JsonController() @Authorized() +@OpenAPI({ security: [{ "AuthToken": [] }] }) export class PdfController { private pdf: PdfCreator = new PdfCreator(); private initialized: boolean = false; -- 2.47.2 From b7c6c6e15708e471f5c3d0ca4cf11b1c08c88c9c Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 20:09:52 +0000 Subject: [PATCH 6/9] =?UTF-8?q?=F0=9F=A7=BENew=20changelog=20file=20versio?= =?UTF-8?q?n=20[CI=20SKIP]=20[skip=20ci]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- CHANGELOG.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index 442b8a3..a9ff898 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -4,6 +4,13 @@ All notable changes to this project will be documented in this file. Dates are d #### [v0.3.0](https://git.odit.services/lfk/document-server/compare/v0.3.0...v0.3.0) +- Merge pull request 'API Key based auth feature/26-api_auth' (#27) from feature/26-api_auth into dev [`2d031da`](https://git.odit.services/lfk/document-server/commit/2d031dae035866a4aa247398ea68ff338ab58cbd) +- Implemented basic auth [`bdeadd2`](https://git.odit.services/lfk/document-server/commit/bdeadd274bc0f9c8cbab35a8a5605bef4c22ba6c) +- 🧾New changelog file version [CI SKIP] [skip ci] [`e306cdb`](https://git.odit.services/lfk/document-server/commit/e306cdb2c8e58fc1aef79b95cba5d4cc96ac7658) +- Added auth to openapi spec [`729f2d7`](https://git.odit.services/lfk/document-server/commit/729f2d7240b54ffe2d4db36cce29de0afdfc9417) +- Added api key to env doc [`4543092`](https://git.odit.services/lfk/document-server/commit/454309278ef20a2b97248277b07a7b58a063618d) +- Fixed bug [`7be211f`](https://git.odit.services/lfk/document-server/commit/7be211f8b7b26f7f620df81af4ebde5eec2feec2) + #### [v0.3.0](https://git.odit.services/lfk/document-server/compare/v0.2.0...v0.3.0) > 12 February 2021 -- 2.47.2 From dcde424b77dcc9753859f94f7bcbe24fe3523c27 Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 21:10:26 +0100 Subject: [PATCH 7/9] =?UTF-8?q?=F0=9F=9A=80Bumped=20version=20to=20v0.3.1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- package.json | 2 +- src/apispec.ts | 64 +++++++++---------- src/app.ts | 62 +++++++++---------- src/config.ts | 102 +++++++++++++++---------------- src/controllers/PdfController.ts | 96 ++++++++++++++--------------- src/middlewares/AuthChecker.ts | 26 ++++---- 6 files changed, 176 insertions(+), 176 deletions(-) diff --git a/package.json b/package.json index 141154f..d8212b6 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@odit/lfk-document-server", - "version": "0.3.0", + "version": "0.3.1", "description": "The document generation server for the LfK! runner system. This generates certificates, sponsoring aggreements and more", "main": "src/app.ts", "scripts": { diff --git a/src/apispec.ts b/src/apispec.ts index 9aa3018..6860264 100644 --- a/src/apispec.ts +++ b/src/apispec.ts @@ -1,33 +1,33 @@ -import { MetadataArgsStorage } from 'routing-controllers'; -import { routingControllersToSpec } from 'routing-controllers-openapi'; -import { config } from './config'; - -/** - * This function generates a the openapi spec from route metadata and type schemas. - * @param storage MetadataArgsStorage object generated by routing-controllers. - * @param schemas MetadataArgsStorage object generated by class-validator-jsonschema. - */ -export function generateSpec(storage: MetadataArgsStorage, schemas) { - return routingControllersToSpec( - storage, - {}, - { - components: { - schemas, - "securitySchemes": { - "AuthToken": { - "type": "apiKey", - "in": "query", - "name": "key", - description: "A simple api key. See the README's env section for more details." - } - } - }, - info: { - description: "The the API for the LfK! document server.", - title: "LfK! document server API", - version: config.version - }, - } - ); +import { MetadataArgsStorage } from 'routing-controllers'; +import { routingControllersToSpec } from 'routing-controllers-openapi'; +import { config } from './config'; + +/** + * This function generates a the openapi spec from route metadata and type schemas. + * @param storage MetadataArgsStorage object generated by routing-controllers. + * @param schemas MetadataArgsStorage object generated by class-validator-jsonschema. + */ +export function generateSpec(storage: MetadataArgsStorage, schemas) { + return routingControllersToSpec( + storage, + {}, + { + components: { + schemas, + "securitySchemes": { + "AuthToken": { + "type": "apiKey", + "in": "query", + "name": "key", + description: "A simple api key. See the README's env section for more details." + } + } + }, + info: { + description: "The the API for the LfK! document server.", + title: "LfK! document server API", + version: config.version + }, + } + ); } \ No newline at end of file diff --git a/src/app.ts b/src/app.ts index 78846f3..ee2396b 100644 --- a/src/app.ts +++ b/src/app.ts @@ -1,31 +1,31 @@ -import consola from "consola"; -import "reflect-metadata"; -import { createExpressServer } from "routing-controllers"; -import { config, e as errors } from './config'; -import loaders from "./loaders/index"; -import AuthChecker from './middlewares/AuthChecker'; -import { ErrorHandler } from './middlewares/ErrorHandler'; - -const CONTROLLERS_FILE_EXTENSION = process.env.NODE_ENV === 'production' ? 'js' : 'ts'; -const app = createExpressServer({ - middlewares: [ErrorHandler], - authorizationChecker: AuthChecker, - development: config.development, - cors: true, - controllers: [`${__dirname}/controllers/*.${CONTROLLERS_FILE_EXTENSION}`], -}); - -async function main() { - await loaders(app); - app.listen(config.internal_port, () => { - consola.success( - `⚡️[server]: Server is running at http://localhost:${config.internal_port}` - ); - }); -} -if (errors === 0) { - main(); -} else { - consola.error("error"); - // something's wrong -} +import consola from "consola"; +import "reflect-metadata"; +import { createExpressServer } from "routing-controllers"; +import { config, e as errors } from './config'; +import loaders from "./loaders/index"; +import AuthChecker from './middlewares/AuthChecker'; +import { ErrorHandler } from './middlewares/ErrorHandler'; + +const CONTROLLERS_FILE_EXTENSION = process.env.NODE_ENV === 'production' ? 'js' : 'ts'; +const app = createExpressServer({ + middlewares: [ErrorHandler], + authorizationChecker: AuthChecker, + development: config.development, + cors: true, + controllers: [`${__dirname}/controllers/*.${CONTROLLERS_FILE_EXTENSION}`], +}); + +async function main() { + await loaders(app); + app.listen(config.internal_port, () => { + consola.success( + `⚡️[server]: Server is running at http://localhost:${config.internal_port}` + ); + }); +} +if (errors === 0) { + main(); +} else { + consola.error("error"); + // something's wrong +} diff --git a/src/config.ts b/src/config.ts index e7da417..bded138 100644 --- a/src/config.ts +++ b/src/config.ts @@ -1,52 +1,52 @@ -import consola from "consola"; -import { config as configDotenv } from 'dotenv'; - -configDotenv(); -export const config = { - internal_port: parseInt(process.env.APP_PORT) || 4010, - development: process.env.NODE_ENV === "production", - version: process.env.VERSION || require('../package.json').version, - eventname: process.env.EVENT_NAME || "Please set the event name", - currency_symbol: process.env.CURRENCY_SYMBOL || "€", - sponsoring_receipt_minimum_amount: process.env.SPONSORING_RECEIPT_MINIMUM_AMOUNT || "10", - codeformat: process.env.CODEFORMAT || "qrcode", - sponor_logos: getSponsorLogos(), - api_key: getApiKey(), -} -let errors = 0 -if (typeof config.internal_port !== "number") { - errors++ -} -if (typeof config.development !== "boolean") { - errors++ -} -function getSponsorLogos(): string[] { - try { - const logos = JSON.parse(process.env.SPONOR_LOGOS); - if (!Array.isArray(logos)) { throw new Error("Not an array.") } - return logos; - } catch (error) { - return [""]; - } -} - -function getApiKey(): string { - const key = process.env.API_KEY; - if (!key) { - consola.info("No API key set - generating a random one..."); - let result = ''; - const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'; - const charactersLength = characters.length; - for (var i = 0; i < 64; i++) { - result += characters.charAt(Math.floor(Math.random() * charactersLength)); - } - consola.info(`API KEY: ${result}`) - return result; - } - if (key.length < 64) { - consola.error(`API key is too short - minimum: 64, current: ${key.length}`) - throw new Error("API_KEY too short.") - } - return key -} +import consola from "consola"; +import { config as configDotenv } from 'dotenv'; + +configDotenv(); +export const config = { + internal_port: parseInt(process.env.APP_PORT) || 4010, + development: process.env.NODE_ENV === "production", + version: process.env.VERSION || require('../package.json').version, + eventname: process.env.EVENT_NAME || "Please set the event name", + currency_symbol: process.env.CURRENCY_SYMBOL || "€", + sponsoring_receipt_minimum_amount: process.env.SPONSORING_RECEIPT_MINIMUM_AMOUNT || "10", + codeformat: process.env.CODEFORMAT || "qrcode", + sponor_logos: getSponsorLogos(), + api_key: getApiKey(), +} +let errors = 0 +if (typeof config.internal_port !== "number") { + errors++ +} +if (typeof config.development !== "boolean") { + errors++ +} +function getSponsorLogos(): string[] { + try { + const logos = JSON.parse(process.env.SPONOR_LOGOS); + if (!Array.isArray(logos)) { throw new Error("Not an array.") } + return logos; + } catch (error) { + return [""]; + } +} + +function getApiKey(): string { + const key = process.env.API_KEY; + if (!key) { + consola.info("No API key set - generating a random one..."); + let result = ''; + const characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'; + const charactersLength = characters.length; + for (var i = 0; i < 64; i++) { + result += characters.charAt(Math.floor(Math.random() * charactersLength)); + } + consola.info(`API KEY: ${result}`) + return result; + } + if (key.length < 64) { + consola.error(`API key is too short - minimum: 64, current: ${key.length}`) + throw new Error("API_KEY too short.") + } + return key +} export let e = errors \ No newline at end of file diff --git a/src/controllers/PdfController.ts b/src/controllers/PdfController.ts index 3e82693..f3a1009 100644 --- a/src/controllers/PdfController.ts +++ b/src/controllers/PdfController.ts @@ -1,48 +1,48 @@ -import { Authorized, Body, JsonController, Post, QueryParam, Res } from 'routing-controllers'; -import { OpenAPI } from 'routing-controllers-openapi'; -import { Runner } from '../models/Runner'; -import { RunnerCard } from '../models/RunnerCard'; -import { PdfCreator } from '../PdfCreator'; - -/** - * The pdf controller handels all endpoints concerning pdf generation. - * It therefore is the hearth of the document-generation server's endpoints. - * All endpoints have to accept a locale query-param to support i18n. - */ -@JsonController() -@Authorized() -@OpenAPI({ security: [{ "AuthToken": [] }] }) -export class PdfController { - private pdf: PdfCreator = new PdfCreator(); - private initialized: boolean = false; - - @Post('/contracts') - @OpenAPI({ description: "Generate Sponsoring contract pdfs from runner objects.
You can choose your prefered locale by passing the 'locale' query-param.
If you provide more than 100 runenrs this could take a moment or two (we tested up to 1000 runners in about 70sec so far)." }) - async generateContracts(@Body({ validate: true, options: { limit: "500mb" } }) runners: Runner | Runner[], @Res() res: any, @QueryParam("locale") locale: string, @QueryParam("codeformat") codeformat: string) { - if (!this.initialized) { - await this.pdf.init(); - this.initialized = true; - } - if (!Array.isArray(runners)) { - runners = [runners]; - } - const contracts = await this.pdf.generateSponsoringContract(runners, locale, codeformat); - res.setHeader('content-type', 'application/pdf'); - return contracts; - } - - @Post('/cards') - @OpenAPI({ description: "Generate runner card pdfs from runner card objects.
You can choose your prefered locale by passing the 'locale' query-param." }) - async generateCards(@Body({ validate: true, options: { limit: "500mb" } }) cards: RunnerCard | RunnerCard[], @Res() res: any, @QueryParam("locale") locale: string) { - if (!this.initialized) { - await this.pdf.init(); - this.initialized = true; - } - if (!Array.isArray(cards)) { - cards = [cards]; - } - const contracts = await this.pdf.generateRunnerCards(cards, locale); - res.setHeader('content-type', 'application/pdf'); - return contracts; - } -} +import { Authorized, Body, JsonController, Post, QueryParam, Res } from 'routing-controllers'; +import { OpenAPI } from 'routing-controllers-openapi'; +import { Runner } from '../models/Runner'; +import { RunnerCard } from '../models/RunnerCard'; +import { PdfCreator } from '../PdfCreator'; + +/** + * The pdf controller handels all endpoints concerning pdf generation. + * It therefore is the hearth of the document-generation server's endpoints. + * All endpoints have to accept a locale query-param to support i18n. + */ +@JsonController() +@Authorized() +@OpenAPI({ security: [{ "AuthToken": [] }] }) +export class PdfController { + private pdf: PdfCreator = new PdfCreator(); + private initialized: boolean = false; + + @Post('/contracts') + @OpenAPI({ description: "Generate Sponsoring contract pdfs from runner objects.
You can choose your prefered locale by passing the 'locale' query-param.
If you provide more than 100 runenrs this could take a moment or two (we tested up to 1000 runners in about 70sec so far)." }) + async generateContracts(@Body({ validate: true, options: { limit: "500mb" } }) runners: Runner | Runner[], @Res() res: any, @QueryParam("locale") locale: string, @QueryParam("codeformat") codeformat: string) { + if (!this.initialized) { + await this.pdf.init(); + this.initialized = true; + } + if (!Array.isArray(runners)) { + runners = [runners]; + } + const contracts = await this.pdf.generateSponsoringContract(runners, locale, codeformat); + res.setHeader('content-type', 'application/pdf'); + return contracts; + } + + @Post('/cards') + @OpenAPI({ description: "Generate runner card pdfs from runner card objects.
You can choose your prefered locale by passing the 'locale' query-param." }) + async generateCards(@Body({ validate: true, options: { limit: "500mb" } }) cards: RunnerCard | RunnerCard[], @Res() res: any, @QueryParam("locale") locale: string) { + if (!this.initialized) { + await this.pdf.init(); + this.initialized = true; + } + if (!Array.isArray(cards)) { + cards = [cards]; + } + const contracts = await this.pdf.generateRunnerCards(cards, locale); + res.setHeader('content-type', 'application/pdf'); + return contracts; + } +} diff --git a/src/middlewares/AuthChecker.ts b/src/middlewares/AuthChecker.ts index e4ede50..19160b3 100644 --- a/src/middlewares/AuthChecker.ts +++ b/src/middlewares/AuthChecker.ts @@ -1,14 +1,14 @@ -import { Action } from "routing-controllers"; -import { config } from '../config'; - -/** - * Handles authentication via jwt's (Bearer authorization header) for all api endpoints using the @Authorized decorator. - * @param action Routing-Controllers action object that provides request and response objects among other stuff. - * @param permissions The permissions that the endpoint using @Authorized requires. - */ -const AuthChecker = async (action: Action) => { - const provided_token = action.request.query.key; - return provided_token == config.api_key; -} - +import { Action } from "routing-controllers"; +import { config } from '../config'; + +/** + * Handles authentication via jwt's (Bearer authorization header) for all api endpoints using the @Authorized decorator. + * @param action Routing-Controllers action object that provides request and response objects among other stuff. + * @param permissions The permissions that the endpoint using @Authorized requires. + */ +const AuthChecker = async (action: Action) => { + const provided_token = action.request.query.key; + return provided_token == config.api_key; +} + export default AuthChecker \ No newline at end of file -- 2.47.2 From 95099c5fbd7e6cb07c68151a998eebb0f00556f3 Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 20:10:54 +0000 Subject: [PATCH 8/9] =?UTF-8?q?=F0=9F=A7=BENew=20changelog=20file=20versio?= =?UTF-8?q?n=20[CI=20SKIP]=20[skip=20ci]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- CHANGELOG.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a9ff898..d7a9452 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,10 +2,12 @@ All notable changes to this project will be documented in this file. Dates are displayed in UTC. -#### [v0.3.0](https://git.odit.services/lfk/document-server/compare/v0.3.0...v0.3.0) +#### [v0.3.1](https://git.odit.services/lfk/document-server/compare/v0.3.0...v0.3.1) -- Merge pull request 'API Key based auth feature/26-api_auth' (#27) from feature/26-api_auth into dev [`2d031da`](https://git.odit.services/lfk/document-server/commit/2d031dae035866a4aa247398ea68ff338ab58cbd) +- 🚀Bumped version to v0.3.1 [`dcde424`](https://git.odit.services/lfk/document-server/commit/dcde424b77dcc9753859f94f7bcbe24fe3523c27) - Implemented basic auth [`bdeadd2`](https://git.odit.services/lfk/document-server/commit/bdeadd274bc0f9c8cbab35a8a5605bef4c22ba6c) +- 🧾New changelog file version [CI SKIP] [skip ci] [`b7c6c6e`](https://git.odit.services/lfk/document-server/commit/b7c6c6e15708e471f5c3d0ca4cf11b1c08c88c9c) +- Merge pull request 'API Key based auth feature/26-api_auth' (#27) from feature/26-api_auth into dev [`2d031da`](https://git.odit.services/lfk/document-server/commit/2d031dae035866a4aa247398ea68ff338ab58cbd) - 🧾New changelog file version [CI SKIP] [skip ci] [`e306cdb`](https://git.odit.services/lfk/document-server/commit/e306cdb2c8e58fc1aef79b95cba5d4cc96ac7658) - Added auth to openapi spec [`729f2d7`](https://git.odit.services/lfk/document-server/commit/729f2d7240b54ffe2d4db36cce29de0afdfc9417) - Added api key to env doc [`4543092`](https://git.odit.services/lfk/document-server/commit/454309278ef20a2b97248277b07a7b58a063618d) -- 2.47.2 From 9d7d0443848522e5bdfdb6a80c836bea4bc200a1 Mon Sep 17 00:00:00 2001 From: Nicolai Ort Date: Sat, 13 Feb 2021 20:11:44 +0000 Subject: [PATCH 9/9] =?UTF-8?q?=F0=9F=93=96New=20license=20file=20version?= =?UTF-8?q?=20[CI=20SKIP]=20[skip=20ci]?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- licenses.md | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/licenses.md b/licenses.md index 00f9823..2b36dd4 100644 --- a/licenses.md +++ b/licenses.md @@ -698,12 +698,32 @@ If the Work includes a "NOTICE" text file as part of its distribution, then any END OF TERMS AND CONDITIONS # routing-controllers -**Author**: [object Object] +**Author**: TypeStack contributors **Repo**: [object Object] **License**: MIT **Description**: Create structured, declarative and beautifully organized class-based controllers with heavy decorators usage for Express / Koa using TypeScript. ## License Text - +The MIT License + +Copyright (c) 2015-2020 TypeStack + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in +all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +THE SOFTWARE. # routing-controllers-openapi **Author**: Aleksi Pekkala -- 2.47.2