"use strict";
exports.__esModule = true;
exports.WSSecurity = void 0;
var crypto = require("crypto");
var utils_1 = require("../utils");
var validPasswordTypes = ['PasswordDigest', 'PasswordText'];
var WSSecurity = /** @class */ (function () {
function WSSecurity(username, password, options) {
options = options || {};
this._username = username;
this._password = password;
this._envelopeKey = 'soap';
// must account for backward compatibility for passwordType String param as well as object options defaults: passwordType = 'PasswordText', hasTimeStamp = true
if (typeof options === 'string') {
this._passwordType = options ? options : 'PasswordText';
options = {};
}
else {
this._passwordType = options.passwordType ? options.passwordType : 'PasswordText';
}
if (validPasswordTypes.indexOf(this._passwordType) === -1) {
this._passwordType = 'PasswordText';
}
this._hasTimeStamp = options.hasTimeStamp || typeof options.hasTimeStamp === 'boolean' ? !!options.hasTimeStamp : true;
/*jshint eqnull:true */
if (options.hasNonce != null) {
this._hasNonce = !!options.hasNonce;
}
this._hasTokenCreated = options.hasTokenCreated || typeof options.hasTokenCreated === 'boolean' ? !!options.hasTokenCreated : true;
if (options.actor != null) {
this._actor = options.actor;
}
if (options.mustUnderstand != null) {
this._mustUnderstand = !!options.mustUnderstand;
}
if (options.envelopeKey) {
this._envelopeKey = options.envelopeKey;
}
}
WSSecurity.prototype.toXML = function () {
// avoid dependency on date formatting libraries
function getDate(d) {
function pad(n) {
return n < 10 ? '0' + n : n;
}
return d.getUTCFullYear() + '-'
+ pad(d.getUTCMonth() + 1) + '-'
+ pad(d.getUTCDate()) + 'T'
+ pad(d.getUTCHours()) + ':'
+ pad(d.getUTCMinutes()) + ':'
+ pad(d.getUTCSeconds()) + 'Z';
}
var now = new Date();
var created = getDate(now);
var timeStampXml = '';
if (this._hasTimeStamp) {
var expires = getDate(new Date(now.getTime() + (1000 * 600)));
timeStampXml = '' +
'' + created + '' +
'' + expires + '' +
'';
}
var password;
var nonce;
if (this._hasNonce || this._passwordType !== 'PasswordText') {
// nonce = base64 ( sha1 ( created + random ) )
var nHash = crypto.createHash('sha1');
nHash.update(created + Math.random());
nonce = nHash.digest('base64');
}
if (this._passwordType === 'PasswordText') {
password = '' + utils_1.xmlEscape(this._password) + '';
if (nonce) {
password += '' + nonce + '';
}
}
else {
/* Specific Testcase for passwordDigest calculation cover this code
/* istanbul ignore next */
password = '' + utils_1.passwordDigest(nonce, created, this._password) + '' +
'' + nonce + '';
}
return '' +
timeStampXml +
'' +
'' + utils_1.xmlEscape(this._username) + '' +
password +
(this._hasTokenCreated ? '' + created + '' : '') +
'' +
'';
};
return WSSecurity;
}());
exports.WSSecurity = WSSecurity;
//# sourceMappingURL=WSSecurity.js.map