@stamhoofd/backend-env 2.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (2) hide show
  1. package/package.json +15 -0
  2. package/src/index.ts +52 -0
package/package.json ADDED
@@ -0,0 +1,15 @@
1
+ {
2
+ "name": "@stamhoofd/backend-env",
3
+ "version": "2.1.1",
4
+ "main": "./dist/index.js",
5
+ "types": "./dist/index.d.ts",
6
+ "license": "UNLICENCED",
7
+ "sideEffects": false,
8
+ "files": [
9
+ "src"
10
+ ],
11
+ "scripts": {
12
+ "build": "tsc -b",
13
+ "build:full": "rm -rf ./dist && yarn build"
14
+ }
15
+ }
package/src/index.ts ADDED
@@ -0,0 +1,52 @@
1
+ import fs from "fs"
2
+ import crypto from 'crypto';
3
+
4
+ export function load(settings?: { path?: string, service?: "redirecter" | "api" | "admin" | "renderer" }) {
5
+ // Read environment from file: .env.json
6
+ (global as any).STAMHOOFD = JSON.parse(fs.readFileSync(settings?.path ?? ".env.json", "utf-8"))
7
+
8
+ // Mapping out environment for dependencies that need environment variables
9
+ process.env.NODE_ENV = STAMHOOFD.environment === "production" ? "production" : "development"
10
+
11
+ if (settings?.service === "redirecter") {
12
+ return
13
+ }
14
+ if (settings?.service === "renderer") {
15
+ return
16
+ }
17
+
18
+ if (!STAMHOOFD.domains) {
19
+ throw new Error("Expected environment variable domains")
20
+ }
21
+
22
+ if (!STAMHOOFD.userMode || !['platform', 'organization'].includes(STAMHOOFD.userMode)) {
23
+ throw new Error("Expected environment variable userMode")
24
+ }
25
+
26
+ if (!STAMHOOFD.translationNamespace) {
27
+ throw new Error("Expected environment variable translationNamespace")
28
+ }
29
+
30
+ // Database
31
+ process.env.DB_DATABASE = STAMHOOFD.DB_DATABASE+""
32
+ process.env.DB_HOST = STAMHOOFD.DB_HOST+""
33
+ process.env.DB_PASS = STAMHOOFD.DB_PASS+""
34
+ process.env.DB_USER = STAMHOOFD.DB_USER+""
35
+
36
+ // AWS
37
+ process.env.AWS_ACCESS_KEY_ID = STAMHOOFD.AWS_ACCESS_KEY_ID+""
38
+ process.env.AWS_SECRET_ACCESS_KEY = STAMHOOFD.AWS_SECRET_ACCESS_KEY+""
39
+ process.env.AWS_REGION = STAMHOOFD.AWS_REGION+""
40
+
41
+ // Database
42
+ process.env.DB_MULTIPLE_STATEMENTS="true"
43
+ }
44
+
45
+ export function signInternal(...content: string[]) {
46
+ return crypto.createHmac('sha256', Buffer.from(STAMHOOFD.INTERNAL_SECRET_KEY, 'base64')).update(content.join(';')).digest('base64');
47
+ }
48
+
49
+ export function verifyInternalSignature(signature: string, ...content: string[]) {
50
+ const newSignature = signInternal(...content)
51
+ return crypto.timingSafeEqual(Buffer.from(signature, 'base64'), Buffer.from(newSignature, 'base64'))
52
+ }