@sphereon/ssi-express-support 0.14.2-next.25
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.
- package/LICENSE +201 -0
- package/README.md +25 -0
- package/dist/auth-utils.d.ts +19 -0
- package/dist/auth-utils.d.ts.map +1 -0
- package/dist/auth-utils.js +118 -0
- package/dist/auth-utils.js.map +1 -0
- package/dist/entra-id-auth.d.ts +10 -0
- package/dist/entra-id-auth.d.ts.map +1 -0
- package/dist/entra-id-auth.js +61 -0
- package/dist/entra-id-auth.js.map +1 -0
- package/dist/express-builders.d.ts +94 -0
- package/dist/express-builders.d.ts.map +1 -0
- package/dist/express-builders.js +269 -0
- package/dist/express-builders.js.map +1 -0
- package/dist/express-utils.d.ts +4 -0
- package/dist/express-utils.d.ts.map +1 -0
- package/dist/express-utils.js +34 -0
- package/dist/express-utils.js.map +1 -0
- package/dist/functions.d.ts +2 -0
- package/dist/functions.d.ts.map +1 -0
- package/dist/functions.js +11 -0
- package/dist/functions.js.map +1 -0
- package/dist/index.d.ts +8 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +27 -0
- package/dist/index.js.map +1 -0
- package/dist/openid-connect-auth.d.ts +10 -0
- package/dist/openid-connect-auth.d.ts.map +1 -0
- package/dist/openid-connect-auth.js +61 -0
- package/dist/openid-connect-auth.js.map +1 -0
- package/dist/static-bearer-auth.d.ts +34 -0
- package/dist/static-bearer-auth.d.ts.map +1 -0
- package/dist/static-bearer-auth.js +146 -0
- package/dist/static-bearer-auth.js.map +1 -0
- package/dist/types.d.ts +179 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +8 -0
- package/dist/types.js.map +1 -0
- package/package.json +70 -0
- package/src/auth-utils.ts +127 -0
- package/src/entra-id-auth.ts +47 -0
- package/src/express-builders.ts +320 -0
- package/src/express-utils.ts +30 -0
- package/src/functions.ts +6 -0
- package/src/index.ts +7 -0
- package/src/openid-connect-auth.ts +47 -0
- package/src/static-bearer-auth.ts +151 -0
- package/src/types.ts +192 -0
|
@@ -0,0 +1,269 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.ExpressCorsConfigurer = exports.ExpressBuilder = void 0;
|
|
30
|
+
/**
|
|
31
|
+
* @public
|
|
32
|
+
*/
|
|
33
|
+
const body_parser_1 = __importDefault(require("body-parser"));
|
|
34
|
+
const cors_1 = __importDefault(require("cors"));
|
|
35
|
+
const dotenv = __importStar(require("dotenv-flow"));
|
|
36
|
+
const express_1 = __importDefault(require("express"));
|
|
37
|
+
const express_session_1 = __importDefault(require("express-session"));
|
|
38
|
+
const morgan_1 = __importDefault(require("morgan"));
|
|
39
|
+
const passport_1 = __importDefault(require("passport"));
|
|
40
|
+
const auth_utils_1 = require("./auth-utils");
|
|
41
|
+
const express_utils_1 = require("./express-utils");
|
|
42
|
+
const functions_1 = require("./functions");
|
|
43
|
+
dotenv.config();
|
|
44
|
+
class ExpressBuilder {
|
|
45
|
+
constructor(opts) {
|
|
46
|
+
this._handlers = [];
|
|
47
|
+
this._startListen = undefined;
|
|
48
|
+
this._usePassportAuth = false;
|
|
49
|
+
const { existingExpress, envVarPrefix } = opts !== null && opts !== void 0 ? opts : {};
|
|
50
|
+
if (existingExpress) {
|
|
51
|
+
this.withExpress(existingExpress);
|
|
52
|
+
}
|
|
53
|
+
this.envVarPrefix = envVarPrefix !== null && envVarPrefix !== void 0 ? envVarPrefix : '';
|
|
54
|
+
}
|
|
55
|
+
static fromExistingExpress(opts) {
|
|
56
|
+
return new ExpressBuilder(opts !== null && opts !== void 0 ? opts : {});
|
|
57
|
+
}
|
|
58
|
+
static fromServerOpts(opts) {
|
|
59
|
+
const builder = new ExpressBuilder({ existingExpress: opts === null || opts === void 0 ? void 0 : opts.existingExpress, envVarPrefix: opts === null || opts === void 0 ? void 0 : opts.envVarPrefix });
|
|
60
|
+
return builder.withEnableListenOpts(opts);
|
|
61
|
+
}
|
|
62
|
+
enableListen(startOnBuild) {
|
|
63
|
+
if (startOnBuild !== undefined) {
|
|
64
|
+
this._startListen = startOnBuild;
|
|
65
|
+
}
|
|
66
|
+
return this;
|
|
67
|
+
}
|
|
68
|
+
withMorganLogging(opts) {
|
|
69
|
+
var _a, _b;
|
|
70
|
+
if ((opts === null || opts === void 0 ? void 0 : opts.existingMorgan) && (opts.format || opts.options)) {
|
|
71
|
+
throw Error('Cannot using an existing morgan with either a format or options');
|
|
72
|
+
}
|
|
73
|
+
this._morgan = (_a = opts === null || opts === void 0 ? void 0 : opts.existingMorgan) !== null && _a !== void 0 ? _a : (0, morgan_1.default)((_b = opts === null || opts === void 0 ? void 0 : opts.format) !== null && _b !== void 0 ? _b : 'dev', opts === null || opts === void 0 ? void 0 : opts.options);
|
|
74
|
+
return this;
|
|
75
|
+
}
|
|
76
|
+
withEnableListenOpts({ port, hostnameOrIP, callback, startOnBuild, }) {
|
|
77
|
+
port && this.withPort(port);
|
|
78
|
+
hostnameOrIP && this.withHostname(hostnameOrIP);
|
|
79
|
+
if (typeof callback === 'function') {
|
|
80
|
+
this.withListenCallback(callback);
|
|
81
|
+
}
|
|
82
|
+
this._startListen = startOnBuild !== false;
|
|
83
|
+
return this;
|
|
84
|
+
}
|
|
85
|
+
withPort(port) {
|
|
86
|
+
this.port = port;
|
|
87
|
+
return this;
|
|
88
|
+
}
|
|
89
|
+
withHostname(hostnameOrIP) {
|
|
90
|
+
this.hostnameOrIP = hostnameOrIP;
|
|
91
|
+
return this;
|
|
92
|
+
}
|
|
93
|
+
withListenCallback(callback) {
|
|
94
|
+
this.listenCallback = callback;
|
|
95
|
+
return this;
|
|
96
|
+
}
|
|
97
|
+
withExpress(existingExpress) {
|
|
98
|
+
this.existingExpress = existingExpress;
|
|
99
|
+
this._startListen = false;
|
|
100
|
+
return this;
|
|
101
|
+
}
|
|
102
|
+
withCorsConfigurer(configurer) {
|
|
103
|
+
this._corsConfigurer = configurer;
|
|
104
|
+
return this;
|
|
105
|
+
}
|
|
106
|
+
withPassportAuth(usePassport, initializeOptions) {
|
|
107
|
+
this._usePassportAuth = usePassport;
|
|
108
|
+
this._passportInitOpts = initializeOptions;
|
|
109
|
+
return this;
|
|
110
|
+
}
|
|
111
|
+
withGlobalUserIsInRole(userIsInRole) {
|
|
112
|
+
this._userIsInRole = userIsInRole;
|
|
113
|
+
return this;
|
|
114
|
+
}
|
|
115
|
+
withEnforcer(enforcer) {
|
|
116
|
+
this._enforcer = enforcer;
|
|
117
|
+
return this;
|
|
118
|
+
}
|
|
119
|
+
startListening(express) {
|
|
120
|
+
return express.listen(this.getPort(), this.getHostname(), this.listenCallback);
|
|
121
|
+
}
|
|
122
|
+
getHostname() {
|
|
123
|
+
var _a, _b;
|
|
124
|
+
return (_b = (_a = this.hostnameOrIP) !== null && _a !== void 0 ? _a : (0, functions_1.env)('HOSTNAME', this.envVarPrefix)) !== null && _b !== void 0 ? _b : '0.0.0.0';
|
|
125
|
+
}
|
|
126
|
+
getPort() {
|
|
127
|
+
var _a, _b;
|
|
128
|
+
return ((_b = (_a = this.port) !== null && _a !== void 0 ? _a : (0, functions_1.env)('PORT', this.envVarPrefix)) !== null && _b !== void 0 ? _b : 5000);
|
|
129
|
+
}
|
|
130
|
+
setHandlers(handlers) {
|
|
131
|
+
if (Array.isArray(handlers)) {
|
|
132
|
+
this._handlers = handlers;
|
|
133
|
+
}
|
|
134
|
+
else if (handlers) {
|
|
135
|
+
if (!this._handlers) {
|
|
136
|
+
this._handlers = [];
|
|
137
|
+
}
|
|
138
|
+
this._handlers.push(handlers);
|
|
139
|
+
}
|
|
140
|
+
else {
|
|
141
|
+
this._handlers = [];
|
|
142
|
+
}
|
|
143
|
+
return this;
|
|
144
|
+
}
|
|
145
|
+
addHandler(handler) {
|
|
146
|
+
if (!this._handlers) {
|
|
147
|
+
this._handlers = [];
|
|
148
|
+
}
|
|
149
|
+
this._handlers.push(handler);
|
|
150
|
+
return this;
|
|
151
|
+
}
|
|
152
|
+
withSessionOptions(sessionOpts) {
|
|
153
|
+
this._sessionOpts = sessionOpts;
|
|
154
|
+
return this;
|
|
155
|
+
}
|
|
156
|
+
build(opts) {
|
|
157
|
+
const express = this.buildExpress(opts);
|
|
158
|
+
return {
|
|
159
|
+
express,
|
|
160
|
+
port: this.getPort(),
|
|
161
|
+
hostname: this.getHostname(),
|
|
162
|
+
userIsInRole: this._userIsInRole,
|
|
163
|
+
startListening: this._startListen !== false,
|
|
164
|
+
enforcer: this._enforcer,
|
|
165
|
+
start: (opts) => {
|
|
166
|
+
if (this._startListen !== false) {
|
|
167
|
+
this.startListening(express);
|
|
168
|
+
}
|
|
169
|
+
if ((opts === null || opts === void 0 ? void 0 : opts.disableErrorHandler) !== true) {
|
|
170
|
+
express.use(express_utils_1.jsonErrorHandler);
|
|
171
|
+
}
|
|
172
|
+
return express;
|
|
173
|
+
},
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
buildExpress(opts) {
|
|
177
|
+
var _a, _b;
|
|
178
|
+
const app = (_b = (_a = opts === null || opts === void 0 ? void 0 : opts.express) !== null && _a !== void 0 ? _a : this.existingExpress) !== null && _b !== void 0 ? _b : (0, express_1.default)();
|
|
179
|
+
if (this._morgan) {
|
|
180
|
+
app.use(this._morgan);
|
|
181
|
+
}
|
|
182
|
+
if (this._sessionOpts) {
|
|
183
|
+
// @ts-ignore
|
|
184
|
+
app.use((0, express_session_1.default)(this._sessionOpts));
|
|
185
|
+
}
|
|
186
|
+
if (this._usePassportAuth) {
|
|
187
|
+
app.use(passport_1.default.initialize(this._passportInitOpts));
|
|
188
|
+
if (this._sessionOpts) {
|
|
189
|
+
app.use(passport_1.default.session());
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
if (this._userIsInRole) {
|
|
193
|
+
app.use((0, auth_utils_1.checkUserIsInRole)({ roles: this._userIsInRole }));
|
|
194
|
+
}
|
|
195
|
+
if (this._corsConfigurer) {
|
|
196
|
+
this._corsConfigurer.configure({ existingExpress: app });
|
|
197
|
+
}
|
|
198
|
+
// @ts-ignore
|
|
199
|
+
this._handlers && this._handlers.length > 0 && app.use(this._handlers);
|
|
200
|
+
// @ts-ignore
|
|
201
|
+
(opts === null || opts === void 0 ? void 0 : opts.handlers) && app.use(opts.handlers);
|
|
202
|
+
app.use(body_parser_1.default.urlencoded({ extended: true }));
|
|
203
|
+
app.use(body_parser_1.default.json());
|
|
204
|
+
/*if (this._startListen !== false) {
|
|
205
|
+
this.startListening(app)
|
|
206
|
+
}*/
|
|
207
|
+
return app;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
exports.ExpressBuilder = ExpressBuilder;
|
|
211
|
+
class ExpressCorsConfigurer {
|
|
212
|
+
constructor({ existingExpress, envVarPrefix }) {
|
|
213
|
+
this._express = existingExpress;
|
|
214
|
+
this._envVarPrefix = envVarPrefix;
|
|
215
|
+
}
|
|
216
|
+
allowOrigin(value) {
|
|
217
|
+
this._allowOrigin = value;
|
|
218
|
+
return this;
|
|
219
|
+
}
|
|
220
|
+
disableCors(value) {
|
|
221
|
+
this._disableCors = value;
|
|
222
|
+
return this;
|
|
223
|
+
}
|
|
224
|
+
allowMethods(value) {
|
|
225
|
+
this._allowMethods = value;
|
|
226
|
+
return this;
|
|
227
|
+
}
|
|
228
|
+
allowedHeaders(value) {
|
|
229
|
+
this._allowedHeaders = value;
|
|
230
|
+
return this;
|
|
231
|
+
}
|
|
232
|
+
allowCredentials(value) {
|
|
233
|
+
this._allowCredentials = value;
|
|
234
|
+
return this;
|
|
235
|
+
}
|
|
236
|
+
configure({ existingExpress }) {
|
|
237
|
+
var _a, _b, _c;
|
|
238
|
+
const express = existingExpress !== null && existingExpress !== void 0 ? existingExpress : this._express;
|
|
239
|
+
if (!express) {
|
|
240
|
+
throw Error('No express passed in during construction or configure');
|
|
241
|
+
}
|
|
242
|
+
const disableCorsEnv = (0, functions_1.env)('CORS_DISABLE', this._envVarPrefix);
|
|
243
|
+
const corsDisabled = (_a = this._disableCors) !== null && _a !== void 0 ? _a : (disableCorsEnv ? /true/.test(disableCorsEnv) : false);
|
|
244
|
+
if (corsDisabled) {
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
const envAllowOriginStr = (_b = (0, functions_1.env)('CORS_ALLOW_ORIGIN', this._envVarPrefix)) !== null && _b !== void 0 ? _b : '*';
|
|
248
|
+
let envAllowOrigin;
|
|
249
|
+
if (envAllowOriginStr.includes(',')) {
|
|
250
|
+
envAllowOrigin = envAllowOriginStr.split(',');
|
|
251
|
+
}
|
|
252
|
+
else if (envAllowOriginStr.includes(' ')) {
|
|
253
|
+
envAllowOrigin = envAllowOriginStr.split(' ');
|
|
254
|
+
}
|
|
255
|
+
else {
|
|
256
|
+
envAllowOrigin = envAllowOriginStr;
|
|
257
|
+
}
|
|
258
|
+
if (Array.isArray(envAllowOrigin) && envAllowOrigin.length === 1) {
|
|
259
|
+
envAllowOrigin = envAllowOrigin[0];
|
|
260
|
+
}
|
|
261
|
+
const corsOptions = Object.assign(Object.assign(Object.assign(Object.assign({ origin: (_c = this._allowOrigin) !== null && _c !== void 0 ? _c : envAllowOrigin }, (this._allowMethods && { methods: this._allowMethods })), (this._allowedHeaders && { allowedHeaders: this._allowedHeaders })), (this._allowCredentials !== undefined && { credentials: this._allowCredentials })), { optionsSuccessStatus: 204 });
|
|
262
|
+
if (this._enablePreflightOptions) {
|
|
263
|
+
express.options('*', (0, cors_1.default)(corsOptions));
|
|
264
|
+
}
|
|
265
|
+
express.use((0, cors_1.default)(corsOptions));
|
|
266
|
+
}
|
|
267
|
+
}
|
|
268
|
+
exports.ExpressCorsConfigurer = ExpressCorsConfigurer;
|
|
269
|
+
//# sourceMappingURL=express-builders.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"express-builders.js","sourceRoot":"","sources":["../src/express-builders.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import express, { NextFunction } from 'express';
|
|
2
|
+
export declare function sendErrorResponse(response: express.Response, statusCode: number, message: string | object, error?: Error): express.Response<any, Record<string, any>> | undefined;
|
|
3
|
+
export declare const jsonErrorHandler: (err: any, req: express.Request, res: express.Response, next: NextFunction) => void | express.Response<any, Record<string, any>>;
|
|
4
|
+
//# sourceMappingURL=express-utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"express-utils.d.ts","sourceRoot":"","sources":["../src/express-utils.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,EAAE,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAC/C,wBAAgB,iBAAiB,CAAC,QAAQ,EAAE,OAAO,CAAC,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,0DAiBxH;AAED,eAAO,MAAM,gBAAgB,QAAS,GAAG,OAAO,eAAe,OAAO,gBAAgB,QAAQ,YAAY,sDASzG,CAAA"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.jsonErrorHandler = exports.sendErrorResponse = void 0;
|
|
4
|
+
function sendErrorResponse(response, statusCode, message, error) {
|
|
5
|
+
console.log(`sendErrorResponse: ${message}`);
|
|
6
|
+
if (error) {
|
|
7
|
+
console.log(JSON.stringify(error));
|
|
8
|
+
}
|
|
9
|
+
if (response.headersSent) {
|
|
10
|
+
console.log(`sendErrorResponse headers already sent`);
|
|
11
|
+
return;
|
|
12
|
+
}
|
|
13
|
+
response.statusCode = statusCode;
|
|
14
|
+
if (typeof message === 'string' && !message.startsWith('{')) {
|
|
15
|
+
message = { error: message };
|
|
16
|
+
}
|
|
17
|
+
if (typeof message === 'string' && message.startsWith('{')) {
|
|
18
|
+
return response.status(statusCode).end(message);
|
|
19
|
+
}
|
|
20
|
+
return response.status(statusCode).json(message);
|
|
21
|
+
}
|
|
22
|
+
exports.sendErrorResponse = sendErrorResponse;
|
|
23
|
+
const jsonErrorHandler = (err, req, res, next) => {
|
|
24
|
+
const statusCode = 'statusCode' in err ? err.statusCode : 500;
|
|
25
|
+
const errorMsg = typeof err === 'string' ? err : err.message;
|
|
26
|
+
if (res.headersSent) {
|
|
27
|
+
console.log('Headers already sent, when calling error handler. Will defer to next error handler');
|
|
28
|
+
console.log(`Error was: ${JSON.stringify(err)}`);
|
|
29
|
+
return next(err);
|
|
30
|
+
}
|
|
31
|
+
return sendErrorResponse(res, statusCode, errorMsg, typeof err !== 'string' ? err : undefined);
|
|
32
|
+
};
|
|
33
|
+
exports.jsonErrorHandler = jsonErrorHandler;
|
|
34
|
+
//# sourceMappingURL=express-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"express-utils.js","sourceRoot":"","sources":["../src/express-utils.ts"],"names":[],"mappings":";;;AACA,SAAgB,iBAAiB,CAAC,QAA0B,EAAE,UAAkB,EAAE,OAAwB,EAAE,KAAa;IACvH,OAAO,CAAC,GAAG,CAAC,sBAAsB,OAAO,EAAE,CAAC,CAAA;IAC5C,IAAI,KAAK,EAAE;QACT,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAA;KACnC;IACD,IAAI,QAAQ,CAAC,WAAW,EAAE;QACxB,OAAO,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAA;QACrD,OAAM;KACP;IACD,QAAQ,CAAC,UAAU,GAAG,UAAU,CAAA;IAChC,IAAI,OAAO,OAAO,KAAK,QAAQ,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;QAC3D,OAAO,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,CAAA;KAC7B;IACD,IAAI,OAAO,OAAO,KAAK,QAAQ,IAAI,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE;QAC1D,OAAO,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;KAChD;IACD,OAAO,QAAQ,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAA;AAClD,CAAC;AAjBD,8CAiBC;AAEM,MAAM,gBAAgB,GAAG,CAAC,GAAQ,EAAE,GAAoB,EAAE,GAAqB,EAAE,IAAkB,EAAE,EAAE;IAC5G,MAAM,UAAU,GAAW,YAAY,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAA;IACrE,MAAM,QAAQ,GAAG,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAA;IAC5D,IAAI,GAAG,CAAC,WAAW,EAAE;QACnB,OAAO,CAAC,GAAG,CAAC,oFAAoF,CAAC,CAAA;QACjG,OAAO,CAAC,GAAG,CAAC,cAAc,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;QAChD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAA;KACjB;IACD,OAAO,iBAAiB,CAAC,GAAG,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;AAChG,CAAC,CAAA;AATY,QAAA,gBAAgB,oBAS5B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"functions.d.ts","sourceRoot":"","sources":["../src/functions.ts"],"names":[],"mappings":"AAAA,wBAAgB,GAAG,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAKrE"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.env = void 0;
|
|
4
|
+
function env(key, prefix) {
|
|
5
|
+
if (!key) {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
return process.env[`${prefix ? prefix.trim() : ''}${key}`];
|
|
9
|
+
}
|
|
10
|
+
exports.env = env;
|
|
11
|
+
//# sourceMappingURL=functions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"functions.js","sourceRoot":"","sources":["../src/functions.ts"],"names":[],"mappings":";;;AAAA,SAAgB,GAAG,CAAC,GAAY,EAAE,MAAe;IAC/C,IAAI,CAAC,GAAG,EAAE;QACR,OAAM;KACP;IACD,OAAO,OAAO,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAA;AAC5D,CAAC;AALD,kBAKC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './entra-id-auth';
|
|
2
|
+
export * from './static-bearer-auth';
|
|
3
|
+
export * from './auth-utils';
|
|
4
|
+
export * from './express-builders';
|
|
5
|
+
export * from './types';
|
|
6
|
+
export { sendErrorResponse, jsonErrorHandler } from './express-utils';
|
|
7
|
+
export * from './functions';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,sBAAsB,CAAA;AACpC,cAAc,cAAc,CAAA;AAC5B,cAAc,oBAAoB,CAAA;AAClC,cAAc,SAAS,CAAA;AACvB,OAAO,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAA;AACrE,cAAc,aAAa,CAAA"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.jsonErrorHandler = exports.sendErrorResponse = void 0;
|
|
18
|
+
__exportStar(require("./entra-id-auth"), exports);
|
|
19
|
+
__exportStar(require("./static-bearer-auth"), exports);
|
|
20
|
+
__exportStar(require("./auth-utils"), exports);
|
|
21
|
+
__exportStar(require("./express-builders"), exports);
|
|
22
|
+
__exportStar(require("./types"), exports);
|
|
23
|
+
var express_utils_1 = require("./express-utils");
|
|
24
|
+
Object.defineProperty(exports, "sendErrorResponse", { enumerable: true, get: function () { return express_utils_1.sendErrorResponse; } });
|
|
25
|
+
Object.defineProperty(exports, "jsonErrorHandler", { enumerable: true, get: function () { return express_utils_1.jsonErrorHandler; } });
|
|
26
|
+
__exportStar(require("./functions"), exports);
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,kDAA+B;AAC/B,uDAAoC;AACpC,+CAA4B;AAC5B,qDAAkC;AAClC,0CAAuB;AACvB,iDAAqE;AAA5D,kHAAA,iBAAiB,OAAA;AAAE,iHAAA,gBAAgB,OAAA;AAC5C,8CAA2B"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { IBearerStrategyOption, IBearerStrategyOptionWithRequest } from './types';
|
|
2
|
+
export declare class OpenIDConnectAuth {
|
|
3
|
+
private readonly strategy;
|
|
4
|
+
private options?;
|
|
5
|
+
static init(strategy: string): OpenIDConnectAuth;
|
|
6
|
+
private constructor();
|
|
7
|
+
withOptions(options: IBearerStrategyOption | IBearerStrategyOptionWithRequest): this;
|
|
8
|
+
connectPassport(): void;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=openid-connect-auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openid-connect-auth.d.ts","sourceRoot":"","sources":["../src/openid-connect-auth.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,gCAAgC,EAAiC,MAAM,SAAS,CAAA;AAEhH,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAQ;IACjC,OAAO,CAAC,OAAO,CAAC,CAAkC;WAEpC,IAAI,CAAC,QAAQ,EAAE,MAAM;IAInC,OAAO;IAIA,WAAW,CAAC,OAAO,EAAE,qBAAqB,GAAG,gCAAgC,GAAG,IAAI;IAQ3F,eAAe;CAuBhB"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
26
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
|
+
};
|
|
28
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
+
exports.OpenIDConnectAuth = void 0;
|
|
30
|
+
const passport_1 = __importDefault(require("passport"));
|
|
31
|
+
class OpenIDConnectAuth {
|
|
32
|
+
static init(strategy) {
|
|
33
|
+
return new OpenIDConnectAuth(strategy);
|
|
34
|
+
}
|
|
35
|
+
constructor(strategy) {
|
|
36
|
+
this.strategy = strategy;
|
|
37
|
+
}
|
|
38
|
+
withOptions(options) {
|
|
39
|
+
this.options = Object.assign(Object.assign({}, options), { passReqToCallback: 'passReqToCallback' in options ? options.passReqToCallback : false });
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
connectPassport() {
|
|
43
|
+
const _options = this.options;
|
|
44
|
+
if (!_options) {
|
|
45
|
+
throw Error('No options supplied for EntraID');
|
|
46
|
+
}
|
|
47
|
+
Promise.resolve().then(() => __importStar(require('passport-azure-ad'))).then((entraID) => passport_1.default.use(this.strategy, new entraID.BearerStrategy(_options, function (token, cb) {
|
|
48
|
+
if (token) {
|
|
49
|
+
// console.log(`token: ${JSON.stringify(token, null, 2)}`)
|
|
50
|
+
return cb(null, token);
|
|
51
|
+
}
|
|
52
|
+
return cb('bearer token not found or incorrect', null);
|
|
53
|
+
})))
|
|
54
|
+
.catch((reason) => {
|
|
55
|
+
console.log(reason);
|
|
56
|
+
throw Error('Could not create bearer strategy. Did you include the "passport-azure-ad/bearer-strategy" dependency in package.json?');
|
|
57
|
+
});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
exports.OpenIDConnectAuth = OpenIDConnectAuth;
|
|
61
|
+
//# sourceMappingURL=openid-connect-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"openid-connect-auth.js","sourceRoot":"","sources":["../src/openid-connect-auth.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,wDAA+B;AAG/B,MAAa,iBAAiB;IAIrB,MAAM,CAAC,IAAI,CAAC,QAAgB;QACjC,OAAO,IAAI,iBAAiB,CAAC,QAAQ,CAAC,CAAA;IACxC,CAAC;IAED,YAAoB,QAAgB;QAClC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAA;IAC1B,CAAC;IAEM,WAAW,CAAC,OAAiE;QAClF,IAAI,CAAC,OAAO,mCACP,OAAO,KACV,iBAAiB,EAAE,mBAAmB,IAAI,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC,CAAC,KAAK,GACtF,CAAA;QACD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,eAAe;QACb,MAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAA;QAC7B,IAAI,CAAC,QAAQ,EAAE;YACb,MAAM,KAAK,CAAC,iCAAiC,CAAC,CAAA;SAC/C;QACD,kDAAO,mBAAmB,IACvB,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAChB,kBAAQ,CAAC,GAAG,CACV,IAAI,CAAC,QAAQ,EACb,IAAI,OAAO,CAAC,cAAc,CAAC,QAAQ,EAAE,UAAU,KAAoB,EAAE,EAAkB;YACrF,IAAI,KAAK,EAAE;gBACT,0DAA0D;gBAC1D,OAAO,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,CAAA;aACvB;YACD,OAAO,EAAE,CAAC,qCAAqC,EAAE,IAAI,CAAC,CAAA;QACxD,CAAC,CAAC,CACH,CACF;aACA,KAAK,CAAC,CAAC,MAAM,EAAE,EAAE;YAChB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YACnB,MAAM,KAAK,CAAC,uHAAuH,CAAC,CAAA;QACtI,CAAC,CAAC,CAAA;IACN,CAAC;CACF;AA3CD,8CA2CC"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { BearerUser, IStaticBearerVerifyOptions } from './types';
|
|
2
|
+
export declare class StaticBearerAuth {
|
|
3
|
+
private readonly strategy;
|
|
4
|
+
private static providers;
|
|
5
|
+
private static verifyOptions;
|
|
6
|
+
private hashTokens?;
|
|
7
|
+
static init(strategy: string, provider?: StaticBearerUserProvider): StaticBearerAuth;
|
|
8
|
+
private constructor();
|
|
9
|
+
get provider(): StaticBearerUserProvider;
|
|
10
|
+
withHashTokens(hashTokens: boolean): this;
|
|
11
|
+
withUsers(users: BearerUser[] | BearerUser): this;
|
|
12
|
+
addUser(user: BearerUser[] | BearerUser): this;
|
|
13
|
+
withVerifyOptions(options: IStaticBearerVerifyOptions | string): this;
|
|
14
|
+
connectPassport(): void;
|
|
15
|
+
}
|
|
16
|
+
export interface StaticBearerUserProvider {
|
|
17
|
+
strategy: string;
|
|
18
|
+
addUser(user: BearerUser | BearerUser[], hashToken?: boolean): void;
|
|
19
|
+
getUser(token: string): BearerUser | undefined;
|
|
20
|
+
hashedTokens?: boolean;
|
|
21
|
+
}
|
|
22
|
+
export declare class MapBasedStaticBearerUserProvider implements StaticBearerUserProvider {
|
|
23
|
+
private readonly _strategy;
|
|
24
|
+
private readonly _users;
|
|
25
|
+
private readonly _hashedTokens;
|
|
26
|
+
constructor(strategy: string, hashedTokens?: boolean);
|
|
27
|
+
get users(): BearerUser[];
|
|
28
|
+
get hashedTokens(): boolean;
|
|
29
|
+
get strategy(): string;
|
|
30
|
+
getUser(token: string): BearerUser | undefined;
|
|
31
|
+
addUser(user: BearerUser | BearerUser[], hashToken?: boolean): void;
|
|
32
|
+
getUsers(): BearerUser[];
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=static-bearer-auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"static-bearer-auth.d.ts","sourceRoot":"","sources":["../src/static-bearer-auth.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,0BAA0B,EAAE,MAAM,SAAS,CAAA;AAChE,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAQ;IACjC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAmD;IAC3E,OAAO,CAAC,MAAM,CAAC,aAAa,CAA8D;IAC1F,OAAO,CAAC,UAAU,CAAC,CAAiB;WAEtB,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,wBAAwB;IAIxE,OAAO;IAWP,IAAI,QAAQ,6BAMX;IAED,cAAc,CAAC,UAAU,EAAE,OAAO,GAAG,IAAI;IAKzC,SAAS,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,UAAU,GAAG,IAAI;IAKjD,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,GAAG,UAAU,GAAG,IAAI;IAK9C,iBAAiB,CAAC,OAAO,EAAE,0BAA0B,GAAG,MAAM,GAAG,IAAI;IAKrE,eAAe;CAuChB;AAED,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,MAAM,CAAA;IAEhB,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,EAAE,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,IAAI,CAAA;IAEnE,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS,CAAA;IAE9C,YAAY,CAAC,EAAE,OAAO,CAAA;CACvB;AAED,qBAAa,gCAAiC,YAAW,wBAAwB;IAC/E,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAQ;IAClC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmB;IAC1C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;gBAE3B,QAAQ,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,OAAO;IAKpD,IAAI,KAAK,IAAI,UAAU,EAAE,CAExB;IAED,IAAI,YAAY,IAAI,OAAO,CAE1B;IAED,IAAI,QAAQ,IAAI,MAAM,CAErB;IAED,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,UAAU,GAAG,SAAS;IAI9C,OAAO,CAAC,IAAI,EAAE,UAAU,GAAG,UAAU,EAAE,EAAE,SAAS,CAAC,EAAE,OAAO,GAAG,IAAI;IAkBnE,QAAQ,IAAI,UAAU,EAAE;CAGzB"}
|