samlesa 2.12.3
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/.editorconfig +19 -0
- package/.github/FUNDING.yml +1 -0
- package/.idea/compiler.xml +6 -0
- package/.idea/deployment.xml +14 -0
- package/.idea/inspectionProfiles/Project_Default.xml +6 -0
- package/.idea/jsLibraryMappings.xml +6 -0
- package/.idea/modules.xml +8 -0
- package/.idea/samlify.iml +12 -0
- package/.idea/vcs.xml +6 -0
- package/.pre-commit.sh +15 -0
- package/.snyk +8 -0
- package/.travis.yml +29 -0
- package/LICENSE +22 -0
- package/Makefile +25 -0
- package/README.md +84 -0
- package/build/.idea/workspace.xml +58 -0
- package/build/index.js +65 -0
- package/build/index.js.map +1 -0
- package/build/src/api.js +24 -0
- package/build/src/api.js.map +1 -0
- package/build/src/binding-post.js +369 -0
- package/build/src/binding-post.js.map +1 -0
- package/build/src/binding-redirect.js +333 -0
- package/build/src/binding-redirect.js.map +1 -0
- package/build/src/binding-simplesign.js +233 -0
- package/build/src/binding-simplesign.js.map +1 -0
- package/build/src/entity-idp.js +131 -0
- package/build/src/entity-idp.js.map +1 -0
- package/build/src/entity-sp.js +97 -0
- package/build/src/entity-sp.js.map +1 -0
- package/build/src/entity.js +236 -0
- package/build/src/entity.js.map +1 -0
- package/build/src/extractor.js +370 -0
- package/build/src/extractor.js.map +1 -0
- package/build/src/flow.js +320 -0
- package/build/src/flow.js.map +1 -0
- package/build/src/libsaml.js +642 -0
- package/build/src/libsaml.js.map +1 -0
- package/build/src/metadata-idp.js +128 -0
- package/build/src/metadata-idp.js.map +1 -0
- package/build/src/metadata-sp.js +232 -0
- package/build/src/metadata-sp.js.map +1 -0
- package/build/src/metadata.js +177 -0
- package/build/src/metadata.js.map +1 -0
- package/build/src/types.js +12 -0
- package/build/src/types.js.map +1 -0
- package/build/src/urn.js +213 -0
- package/build/src/urn.js.map +1 -0
- package/build/src/utility.js +249 -0
- package/build/src/utility.js.map +1 -0
- package/build/src/validator.js +27 -0
- package/build/src/validator.js.map +1 -0
- package/index.d.ts +10 -0
- package/index.js +19 -0
- package/index.js.map +1 -0
- package/index.ts +28 -0
- package/package.json +74 -0
- package/qodana.yaml +29 -0
- package/src/.idea/modules.xml +8 -0
- package/src/.idea/src.iml +12 -0
- package/src/.idea/vcs.xml +6 -0
- package/src/api.ts +36 -0
- package/src/binding-post.ts +338 -0
- package/src/binding-redirect.ts +331 -0
- package/src/binding-simplesign.ts +231 -0
- package/src/entity-idp.ts +145 -0
- package/src/entity-sp.ts +114 -0
- package/src/entity.ts +243 -0
- package/src/extractor.ts +392 -0
- package/src/flow.ts +467 -0
- package/src/libsaml.ts +786 -0
- package/src/metadata-idp.ts +146 -0
- package/src/metadata-sp.ts +268 -0
- package/src/metadata.ts +166 -0
- package/src/types.ts +153 -0
- package/src/urn.ts +211 -0
- package/src/utility.ts +248 -0
- package/src/validator.ts +44 -0
- package/tsconfig.json +38 -0
- package/tslint.json +35 -0
- package/types/index.d.ts +10 -0
- package/types/src/api.d.ts +13 -0
- package/types/src/binding-post.d.ts +46 -0
- package/types/src/binding-redirect.d.ts +52 -0
- package/types/src/binding-simplesign.d.ts +39 -0
- package/types/src/entity-idp.d.ts +42 -0
- package/types/src/entity-sp.d.ts +36 -0
- package/types/src/entity.d.ts +99 -0
- package/types/src/extractor.d.ts +25 -0
- package/types/src/flow.d.ts +6 -0
- package/types/src/libsaml.d.ts +210 -0
- package/types/src/metadata-idp.d.ts +24 -0
- package/types/src/metadata-sp.d.ts +36 -0
- package/types/src/metadata.d.ts +57 -0
- package/types/src/types.d.ts +127 -0
- package/types/src/urn.d.ts +194 -0
- package/types/src/utility.d.ts +134 -0
- package/types/src/validator.d.ts +3 -0
- package/types.d.ts +2 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"libsaml.js","sourceRoot":"","sources":["../../src/libsaml.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.IdpMetadata = void 0;
|
|
7
|
+
exports.default = default_1;
|
|
8
|
+
/**
|
|
9
|
+
* @file metadata-idp.ts
|
|
10
|
+
* @author tngan
|
|
11
|
+
* @desc Metadata of identity provider
|
|
12
|
+
*/
|
|
13
|
+
const metadata_js_1 = __importDefault(require("./metadata.js"));
|
|
14
|
+
const urn_js_1 = require("./urn.js");
|
|
15
|
+
const libsaml_js_1 = __importDefault(require("./libsaml.js"));
|
|
16
|
+
const utility_js_1 = require("./utility.js");
|
|
17
|
+
const xml_1 = __importDefault(require("xml"));
|
|
18
|
+
/*
|
|
19
|
+
* @desc interface function
|
|
20
|
+
*/
|
|
21
|
+
function default_1(meta) {
|
|
22
|
+
return new IdpMetadata(meta);
|
|
23
|
+
}
|
|
24
|
+
class IdpMetadata extends metadata_js_1.default {
|
|
25
|
+
constructor(meta) {
|
|
26
|
+
const isFile = (0, utility_js_1.isString)(meta) || meta instanceof Buffer;
|
|
27
|
+
if (!isFile) {
|
|
28
|
+
const { entityID, signingCert, encryptCert, wantAuthnRequestsSigned = false, nameIDFormat = [], singleSignOnService = [], singleLogoutService = [], } = meta;
|
|
29
|
+
const IDPSSODescriptor = [{
|
|
30
|
+
_attr: {
|
|
31
|
+
WantAuthnRequestsSigned: String(wantAuthnRequestsSigned),
|
|
32
|
+
protocolSupportEnumeration: urn_js_1.namespace.names.protocol,
|
|
33
|
+
},
|
|
34
|
+
}];
|
|
35
|
+
for (const cert of (0, utility_js_1.castArrayOpt)(signingCert)) {
|
|
36
|
+
IDPSSODescriptor.push(libsaml_js_1.default.createKeySection('signing', cert));
|
|
37
|
+
}
|
|
38
|
+
for (const cert of (0, utility_js_1.castArrayOpt)(encryptCert)) {
|
|
39
|
+
IDPSSODescriptor.push(libsaml_js_1.default.createKeySection('encryption', cert));
|
|
40
|
+
}
|
|
41
|
+
if ((0, utility_js_1.isNonEmptyArray)(nameIDFormat)) {
|
|
42
|
+
nameIDFormat.forEach(f => IDPSSODescriptor.push({ NameIDFormat: f }));
|
|
43
|
+
}
|
|
44
|
+
if ((0, utility_js_1.isNonEmptyArray)(singleSignOnService)) {
|
|
45
|
+
singleSignOnService.forEach((a, indexCount) => {
|
|
46
|
+
const attr = {
|
|
47
|
+
Binding: a.Binding,
|
|
48
|
+
Location: a.Location,
|
|
49
|
+
};
|
|
50
|
+
if (a.isDefault) {
|
|
51
|
+
attr.isDefault = true;
|
|
52
|
+
}
|
|
53
|
+
IDPSSODescriptor.push({ SingleSignOnService: [{ _attr: attr }] });
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw new Error('ERR_IDP_METADATA_MISSING_SINGLE_SIGN_ON_SERVICE');
|
|
58
|
+
}
|
|
59
|
+
if ((0, utility_js_1.isNonEmptyArray)(singleLogoutService)) {
|
|
60
|
+
singleLogoutService.forEach((a, indexCount) => {
|
|
61
|
+
const attr = {};
|
|
62
|
+
if (a.isDefault) {
|
|
63
|
+
attr.isDefault = true;
|
|
64
|
+
}
|
|
65
|
+
attr.Binding = a.Binding;
|
|
66
|
+
attr.Location = a.Location;
|
|
67
|
+
IDPSSODescriptor.push({ SingleLogoutService: [{ _attr: attr }] });
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
console.warn('Construct identity provider - missing endpoint of SingleLogoutService');
|
|
72
|
+
}
|
|
73
|
+
// Create a new metadata by setting
|
|
74
|
+
meta = (0, xml_1.default)([{
|
|
75
|
+
EntityDescriptor: [{
|
|
76
|
+
_attr: {
|
|
77
|
+
'xmlns': urn_js_1.namespace.names.metadata,
|
|
78
|
+
'xmlns:assertion': urn_js_1.namespace.names.assertion,
|
|
79
|
+
'xmlns:ds': 'http://www.w3.org/2000/09/xmldsig#',
|
|
80
|
+
entityID,
|
|
81
|
+
},
|
|
82
|
+
}, { IDPSSODescriptor }],
|
|
83
|
+
}]);
|
|
84
|
+
}
|
|
85
|
+
super(meta, [
|
|
86
|
+
{
|
|
87
|
+
key: 'wantAuthnRequestsSigned',
|
|
88
|
+
localPath: ['EntityDescriptor', 'IDPSSODescriptor'],
|
|
89
|
+
attributes: ['WantAuthnRequestsSigned'],
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
key: 'singleSignOnService',
|
|
93
|
+
localPath: ['EntityDescriptor', 'IDPSSODescriptor', 'SingleSignOnService'],
|
|
94
|
+
index: ['Binding'],
|
|
95
|
+
attributePath: [],
|
|
96
|
+
attributes: ['Location']
|
|
97
|
+
},
|
|
98
|
+
]);
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* @desc Get the preference whether it wants a signed request
|
|
102
|
+
* @return {boolean} WantAuthnRequestsSigned
|
|
103
|
+
*/
|
|
104
|
+
isWantAuthnRequestsSigned() {
|
|
105
|
+
const was = this.meta.wantAuthnRequestsSigned;
|
|
106
|
+
if (was === undefined) {
|
|
107
|
+
return false;
|
|
108
|
+
}
|
|
109
|
+
return String(was) === 'true';
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* @desc Get the entity endpoint for single sign on service
|
|
113
|
+
* @param {string} binding protocol binding (e.g. redirect, post)
|
|
114
|
+
* @return {string/object} location
|
|
115
|
+
*/
|
|
116
|
+
getSingleSignOnService(binding) {
|
|
117
|
+
if ((0, utility_js_1.isString)(binding)) {
|
|
118
|
+
const bindName = urn_js_1.namespace.binding[binding];
|
|
119
|
+
const service = this.meta.singleSignOnService[bindName];
|
|
120
|
+
if (service) {
|
|
121
|
+
return service;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
return this.meta.singleSignOnService;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
exports.IdpMetadata = IdpMetadata;
|
|
128
|
+
//# sourceMappingURL=metadata-idp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata-idp.js","sourceRoot":"","sources":["../../src/metadata-idp.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.SpMetadata = void 0;
|
|
7
|
+
exports.default = default_1;
|
|
8
|
+
/**
|
|
9
|
+
* @file metadata-sp.ts
|
|
10
|
+
* @author tngan
|
|
11
|
+
* @desc Metadata of service provider
|
|
12
|
+
*/
|
|
13
|
+
const metadata_js_1 = __importDefault(require("./metadata.js"));
|
|
14
|
+
const urn_js_1 = require("./urn.js");
|
|
15
|
+
const libsaml_js_1 = __importDefault(require("./libsaml.js"));
|
|
16
|
+
const utility_js_1 = require("./utility.js");
|
|
17
|
+
const xml_1 = __importDefault(require("xml"));
|
|
18
|
+
/*
|
|
19
|
+
* @desc interface function
|
|
20
|
+
*/
|
|
21
|
+
function default_1(meta) {
|
|
22
|
+
return new SpMetadata(meta);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* @desc SP Metadata is for creating Service Provider, provides a set of API to manage the actions in SP.
|
|
26
|
+
*/
|
|
27
|
+
class SpMetadata extends metadata_js_1.default {
|
|
28
|
+
/**
|
|
29
|
+
* @param {object/string} meta (either xml string or configuration in object)
|
|
30
|
+
* @return {object} prototypes including public functions
|
|
31
|
+
*/
|
|
32
|
+
constructor(meta) {
|
|
33
|
+
const isFile = (0, utility_js_1.isString)(meta) || meta instanceof Buffer;
|
|
34
|
+
// use object configuration instead of importing metadata file directly
|
|
35
|
+
if (!isFile) {
|
|
36
|
+
const { elementsOrder = urn_js_1.elementsOrder.default, entityID, signingCert, encryptCert, authnRequestsSigned = false, wantAssertionsSigned = false, wantMessageSigned = false, signatureConfig, nameIDFormat = [], singleLogoutService = [], assertionConsumerService = [], attributeConsumingService = [] } = meta;
|
|
37
|
+
const descriptors = {
|
|
38
|
+
KeyDescriptor: [],
|
|
39
|
+
NameIDFormat: [],
|
|
40
|
+
SingleLogoutService: [],
|
|
41
|
+
AssertionConsumerService: [],
|
|
42
|
+
AttributeConsumingService: [],
|
|
43
|
+
};
|
|
44
|
+
const SPSSODescriptor = [{
|
|
45
|
+
_attr: {
|
|
46
|
+
AuthnRequestsSigned: String(authnRequestsSigned),
|
|
47
|
+
WantAssertionsSigned: String(wantAssertionsSigned),
|
|
48
|
+
protocolSupportEnumeration: urn_js_1.namespace.names.protocol,
|
|
49
|
+
},
|
|
50
|
+
}];
|
|
51
|
+
if (wantMessageSigned && signatureConfig === undefined) {
|
|
52
|
+
console.warn('Construct service provider - missing signatureConfig');
|
|
53
|
+
}
|
|
54
|
+
for (const cert of (0, utility_js_1.castArrayOpt)(signingCert)) {
|
|
55
|
+
descriptors.KeyDescriptor.push(libsaml_js_1.default.createKeySection('signing', cert).KeyDescriptor);
|
|
56
|
+
}
|
|
57
|
+
for (const cert of (0, utility_js_1.castArrayOpt)(encryptCert)) {
|
|
58
|
+
descriptors.KeyDescriptor.push(libsaml_js_1.default.createKeySection('encryption', cert).KeyDescriptor);
|
|
59
|
+
}
|
|
60
|
+
if ((0, utility_js_1.isNonEmptyArray)(nameIDFormat)) {
|
|
61
|
+
nameIDFormat.forEach(f => descriptors.NameIDFormat.push(f));
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
// default value
|
|
65
|
+
descriptors.NameIDFormat.push(urn_js_1.namespace.format.emailAddress);
|
|
66
|
+
}
|
|
67
|
+
if ((0, utility_js_1.isNonEmptyArray)(singleLogoutService)) {
|
|
68
|
+
singleLogoutService.forEach(a => {
|
|
69
|
+
const attr = {
|
|
70
|
+
Binding: a.Binding,
|
|
71
|
+
Location: a.Location,
|
|
72
|
+
};
|
|
73
|
+
if (a.isDefault) {
|
|
74
|
+
attr.isDefault = true;
|
|
75
|
+
}
|
|
76
|
+
descriptors.SingleLogoutService.push([{ _attr: attr }]);
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
if ((0, utility_js_1.isNonEmptyArray)(assertionConsumerService)) {
|
|
80
|
+
let indexCount = 0;
|
|
81
|
+
assertionConsumerService.forEach(a => {
|
|
82
|
+
const attr = {
|
|
83
|
+
index: String(indexCount++),
|
|
84
|
+
Binding: a.Binding,
|
|
85
|
+
Location: a.Location,
|
|
86
|
+
};
|
|
87
|
+
if (a.isDefault) {
|
|
88
|
+
attr.isDefault = true;
|
|
89
|
+
}
|
|
90
|
+
descriptors.AssertionConsumerService.push([{ _attr: attr }]);
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
console.warn('Missing endpoint of AssertionConsumerService');
|
|
95
|
+
}
|
|
96
|
+
// 修改原有处理逻辑
|
|
97
|
+
if ((0, utility_js_1.isNonEmptyArray)(attributeConsumingService)) {
|
|
98
|
+
attributeConsumingService.forEach((service, index) => {
|
|
99
|
+
// 1. 构建AttributeConsumingService主元素
|
|
100
|
+
let indexCount = 0;
|
|
101
|
+
let attrConsumingService = [{
|
|
102
|
+
_attr: {
|
|
103
|
+
index: String(index + 1),
|
|
104
|
+
}
|
|
105
|
+
}];
|
|
106
|
+
if (service.isDefault) {
|
|
107
|
+
attrConsumingService[0]._attr.isDefault = true;
|
|
108
|
+
}
|
|
109
|
+
// 2. 添加ServiceName子元素
|
|
110
|
+
if ((0, utility_js_1.isNonEmptyArray)(service.serviceName)) {
|
|
111
|
+
service.serviceName.forEach(({ value, lang }) => {
|
|
112
|
+
attrConsumingService.push({
|
|
113
|
+
ServiceName: [
|
|
114
|
+
{
|
|
115
|
+
_attr: lang ? { 'xml:lang': lang } : {},
|
|
116
|
+
},
|
|
117
|
+
value
|
|
118
|
+
]
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
if ((0, utility_js_1.isNonEmptyArray)(service.serviceDescription)) {
|
|
123
|
+
service.serviceDescription.forEach(({ value, lang }) => {
|
|
124
|
+
attrConsumingService.push({
|
|
125
|
+
ServiceDescription: [
|
|
126
|
+
{
|
|
127
|
+
_attr: lang ? { 'xml:lang': lang } : {},
|
|
128
|
+
},
|
|
129
|
+
value
|
|
130
|
+
]
|
|
131
|
+
});
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
// 3. 添加RequestedAttribute子元素
|
|
135
|
+
if ((0, utility_js_1.isNonEmptyArray)(service.requestedAttributes)) {
|
|
136
|
+
service.requestedAttributes.forEach(attr => {
|
|
137
|
+
const requestedAttr = {
|
|
138
|
+
_attr: {
|
|
139
|
+
...(attr.isRequired && { isRequired: String(attr.isRequired) }),
|
|
140
|
+
Name: attr.name,
|
|
141
|
+
...(attr.friendlyName && { FriendlyName: attr.friendlyName }),
|
|
142
|
+
}
|
|
143
|
+
};
|
|
144
|
+
/* // 处理属性值白名单
|
|
145
|
+
if (isNonEmptyArray(attr.attributeValue)) {
|
|
146
|
+
requestedAttr[namespace.tags.attributeValue] = attr.attributeValue.map(val => ({
|
|
147
|
+
_: val
|
|
148
|
+
}));
|
|
149
|
+
}*/
|
|
150
|
+
attrConsumingService.push({
|
|
151
|
+
RequestedAttribute: [requestedAttr]
|
|
152
|
+
});
|
|
153
|
+
});
|
|
154
|
+
}
|
|
155
|
+
// 4. 将完整元素加入描述符
|
|
156
|
+
descriptors.AttributeConsumingService.push(attrConsumingService);
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
// handle element order
|
|
160
|
+
const existedElements = elementsOrder.filter(name => (0, utility_js_1.isNonEmptyArray)(descriptors[name]));
|
|
161
|
+
existedElements.forEach(name => {
|
|
162
|
+
descriptors[name].forEach(e => SPSSODescriptor.push({ [name]: e }));
|
|
163
|
+
});
|
|
164
|
+
// Re-assign the meta reference as a XML string|Buffer for use with the parent constructor
|
|
165
|
+
meta = (0, xml_1.default)([{
|
|
166
|
+
EntityDescriptor: [{
|
|
167
|
+
_attr: {
|
|
168
|
+
entityID,
|
|
169
|
+
'xmlns': urn_js_1.namespace.names.metadata,
|
|
170
|
+
'xmlns:assertion': urn_js_1.namespace.names.assertion,
|
|
171
|
+
'xmlns:ds': 'http://www.w3.org/2000/09/xmldsig#',
|
|
172
|
+
},
|
|
173
|
+
}, { SPSSODescriptor }],
|
|
174
|
+
}]);
|
|
175
|
+
}
|
|
176
|
+
// Use the re-assigned meta object reference here
|
|
177
|
+
super(meta, [
|
|
178
|
+
{
|
|
179
|
+
key: 'spSSODescriptor',
|
|
180
|
+
localPath: ['EntityDescriptor', 'SPSSODescriptor'],
|
|
181
|
+
attributes: ['WantAssertionsSigned', 'AuthnRequestsSigned'],
|
|
182
|
+
},
|
|
183
|
+
{
|
|
184
|
+
key: 'assertionConsumerService',
|
|
185
|
+
localPath: ['EntityDescriptor', 'SPSSODescriptor', 'AssertionConsumerService'],
|
|
186
|
+
attributes: ['Binding', 'Location', 'isDefault', 'index'],
|
|
187
|
+
}
|
|
188
|
+
]);
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* @desc Get the preference whether it wants a signed assertion response
|
|
192
|
+
* @return {boolean} Wantassertionssigned
|
|
193
|
+
*/
|
|
194
|
+
isWantAssertionsSigned() {
|
|
195
|
+
return this.meta.spSSODescriptor.wantAssertionsSigned === 'true';
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* @desc Get the preference whether it signs request
|
|
199
|
+
* @return {boolean} Authnrequestssigned
|
|
200
|
+
*/
|
|
201
|
+
isAuthnRequestSigned() {
|
|
202
|
+
return this.meta.spSSODescriptor.authnRequestsSigned === 'true';
|
|
203
|
+
}
|
|
204
|
+
/**
|
|
205
|
+
* @desc Get the entity endpoint for assertion consumer service
|
|
206
|
+
* @param {string} binding protocol binding (e.g. redirect, post)
|
|
207
|
+
* @return {string/[string]} URL of endpoint(s)
|
|
208
|
+
*/
|
|
209
|
+
getAssertionConsumerService(binding) {
|
|
210
|
+
if ((0, utility_js_1.isString)(binding)) {
|
|
211
|
+
let location;
|
|
212
|
+
const bindName = urn_js_1.namespace.binding[binding];
|
|
213
|
+
if ((0, utility_js_1.isNonEmptyArray)(this.meta.assertionConsumerService)) {
|
|
214
|
+
this.meta.assertionConsumerService.forEach(obj => {
|
|
215
|
+
if (obj.binding === bindName) {
|
|
216
|
+
location = obj.location;
|
|
217
|
+
return;
|
|
218
|
+
}
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
if (this.meta.assertionConsumerService.binding === bindName) {
|
|
223
|
+
location = this.meta.assertionConsumerService.location;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
return location;
|
|
227
|
+
}
|
|
228
|
+
return this.meta.assertionConsumerService;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
exports.SpMetadata = SpMetadata;
|
|
232
|
+
//# sourceMappingURL=metadata-sp.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata-sp.js","sourceRoot":"","sources":["../../src/metadata-sp.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,177 @@
|
|
|
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 () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
/**
|
|
37
|
+
* @file metadata.ts
|
|
38
|
+
* @author tngan
|
|
39
|
+
* @desc An abstraction for metadata of identity provider and service provider
|
|
40
|
+
*/
|
|
41
|
+
const fs = __importStar(require("fs"));
|
|
42
|
+
const urn_js_1 = require("./urn.js");
|
|
43
|
+
const extractor_js_1 = require("./extractor.js");
|
|
44
|
+
const utility_js_1 = require("./utility.js");
|
|
45
|
+
class Metadata {
|
|
46
|
+
xmlString;
|
|
47
|
+
meta;
|
|
48
|
+
/**
|
|
49
|
+
* @param {string | Buffer} xml
|
|
50
|
+
* @param {object} extraParse for custom metadata extractor
|
|
51
|
+
*/
|
|
52
|
+
constructor(xml, extraParse = []) {
|
|
53
|
+
this.xmlString = xml.toString();
|
|
54
|
+
this.meta = (0, extractor_js_1.extract)(this.xmlString, extraParse.concat([
|
|
55
|
+
{
|
|
56
|
+
key: 'entityDescriptor',
|
|
57
|
+
localPath: ['EntityDescriptor'],
|
|
58
|
+
attributes: [],
|
|
59
|
+
context: true
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
key: 'entityID',
|
|
63
|
+
localPath: ['EntityDescriptor'],
|
|
64
|
+
attributes: ['entityID']
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
// shared certificate for both encryption and signing
|
|
68
|
+
key: 'sharedCertificate',
|
|
69
|
+
localPath: ['EntityDescriptor', '~SSODescriptor', 'KeyDescriptor', 'KeyInfo', 'X509Data', 'X509Certificate'],
|
|
70
|
+
attributes: []
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
// explicit certificate declaration for encryption and signing
|
|
74
|
+
key: 'certificate',
|
|
75
|
+
localPath: ['EntityDescriptor', '~SSODescriptor', 'KeyDescriptor'],
|
|
76
|
+
index: ['use'],
|
|
77
|
+
attributePath: ['KeyInfo', 'X509Data', 'X509Certificate'],
|
|
78
|
+
attributes: []
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
key: 'singleLogoutService',
|
|
82
|
+
localPath: ['EntityDescriptor', '~SSODescriptor', 'SingleLogoutService'],
|
|
83
|
+
attributes: ['Binding', 'Location']
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
key: 'nameIDFormat',
|
|
87
|
+
localPath: ['EntityDescriptor', '~SSODescriptor', 'NameIDFormat'],
|
|
88
|
+
attributes: [],
|
|
89
|
+
}
|
|
90
|
+
]));
|
|
91
|
+
// get shared certificate
|
|
92
|
+
const sharedCertificate = this.meta.sharedCertificate;
|
|
93
|
+
if (typeof sharedCertificate === 'string') {
|
|
94
|
+
this.meta.certificate = {
|
|
95
|
+
signing: sharedCertificate,
|
|
96
|
+
encryption: sharedCertificate
|
|
97
|
+
};
|
|
98
|
+
delete this.meta.sharedCertificate;
|
|
99
|
+
}
|
|
100
|
+
if (Array.isArray(this.meta.entityDescriptor) &&
|
|
101
|
+
this.meta.entityDescriptor.length > 1) {
|
|
102
|
+
throw new Error('ERR_MULTIPLE_METADATA_ENTITYDESCRIPTOR');
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* @desc Get the metadata in xml format
|
|
107
|
+
* @return {string} metadata in xml format
|
|
108
|
+
*/
|
|
109
|
+
getMetadata() {
|
|
110
|
+
return this.xmlString;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* @desc Export the metadata to specific file
|
|
114
|
+
* @param {string} exportFile is the output file path
|
|
115
|
+
*/
|
|
116
|
+
exportMetadata(exportFile) {
|
|
117
|
+
fs.writeFileSync(exportFile, this.xmlString);
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* @desc Get the entityID in metadata
|
|
121
|
+
* @return {string} entityID
|
|
122
|
+
*/
|
|
123
|
+
getEntityID() {
|
|
124
|
+
return this.meta.entityID;
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* @desc Get the x509 certificate declared in entity metadata
|
|
128
|
+
* @param {string} use declares the type of certificate
|
|
129
|
+
* @return {string} certificate in string format
|
|
130
|
+
*/
|
|
131
|
+
getX509Certificate(use) {
|
|
132
|
+
return this.meta.certificate[use] || null;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* @desc Get the support NameID format declared in entity metadata
|
|
136
|
+
* @return {array} support NameID format
|
|
137
|
+
*/
|
|
138
|
+
getNameIDFormat() {
|
|
139
|
+
return this.meta.nameIDFormat;
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* @desc Get the entity endpoint for single logout service
|
|
143
|
+
* @param {string} binding e.g. redirect, post
|
|
144
|
+
* @return {string/object} location
|
|
145
|
+
*/
|
|
146
|
+
getSingleLogoutService(binding) {
|
|
147
|
+
if (binding && (0, utility_js_1.isString)(binding)) {
|
|
148
|
+
const bindType = urn_js_1.namespace.binding[binding];
|
|
149
|
+
let singleLogoutService = this.meta.singleLogoutService;
|
|
150
|
+
if (!(singleLogoutService instanceof Array)) {
|
|
151
|
+
singleLogoutService = [singleLogoutService];
|
|
152
|
+
}
|
|
153
|
+
const service = singleLogoutService.find(obj => obj.binding === bindType);
|
|
154
|
+
if (service) {
|
|
155
|
+
return service.location;
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
return this.meta.singleLogoutService;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* @desc Get the support bindings
|
|
162
|
+
* @param {[string]} services
|
|
163
|
+
* @return {[string]} support bindings
|
|
164
|
+
*/
|
|
165
|
+
getSupportBindings(services) {
|
|
166
|
+
let supportBindings = [];
|
|
167
|
+
if (services) {
|
|
168
|
+
supportBindings = services.reduce((acc, service) => {
|
|
169
|
+
const supportBinding = Object.keys(service)[0];
|
|
170
|
+
return acc.push(supportBinding);
|
|
171
|
+
}, []);
|
|
172
|
+
}
|
|
173
|
+
return supportBindings;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
exports.default = Metadata;
|
|
177
|
+
//# sourceMappingURL=metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metadata.js","sourceRoot":"","sources":["../../src/metadata.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ServiceProviderMetadata = exports.ServiceProviderConstructor = exports.IdentityProviderMetadata = exports.IdentityProviderConstructor = void 0;
|
|
4
|
+
var entity_idp_js_1 = require("./entity-idp.js");
|
|
5
|
+
Object.defineProperty(exports, "IdentityProviderConstructor", { enumerable: true, get: function () { return entity_idp_js_1.IdentityProvider; } });
|
|
6
|
+
var metadata_idp_js_1 = require("./metadata-idp.js");
|
|
7
|
+
Object.defineProperty(exports, "IdentityProviderMetadata", { enumerable: true, get: function () { return metadata_idp_js_1.IdpMetadata; } });
|
|
8
|
+
var entity_sp_js_1 = require("./entity-sp.js");
|
|
9
|
+
Object.defineProperty(exports, "ServiceProviderConstructor", { enumerable: true, get: function () { return entity_sp_js_1.ServiceProvider; } });
|
|
10
|
+
var metadata_sp_js_1 = require("./metadata-sp.js");
|
|
11
|
+
Object.defineProperty(exports, "ServiceProviderMetadata", { enumerable: true, get: function () { return metadata_sp_js_1.SpMetadata; } });
|
|
12
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":";;;AAEA,iDAAkF;AAAzE,4HAAA,gBAAgB,OAA+B;AACxD,qDAA4E;AAAnE,2HAAA,WAAW,OAA4B;AAEhD,+CAA+E;AAAtE,0HAAA,eAAe,OAA8B;AACtD,mDAAyE;AAAhE,yHAAA,UAAU,OAA2B"}
|