-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
112 lines (100 loc) · 3.48 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
// Generated by CoffeeScript 2.2.3
(function() {
/*
ISC License
Copyright 2018, Saksham (DawnImpulse)
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted,
provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE
OR PERFORMANCE OF THIS SOFTWARE.
*/
'use strict';
/*
esat
index
@author Saksham
@note Last Branch Update -
@note Created on 2018-06-05 by Saksham
@note Updates :
*/
var errorHandler, tokenHandler;
tokenHandler = require('./handler/tokenHandler');
errorHandler = require('./utils/errorHandler');
/*
generate a new token
@param options - as name suggests this parameter contains all the extra options for generating token (optional)
1. exp - token expiry (milliseconds) - default 1 day
2. rat - token refresh interval/at (milliseconds) - default 1 hour
3. iss - token issuer
4. payload - additional json object/json array
@param key - encryption key
@param callback - not required in case of promise
*/
exports.generate = function(options, key, callback) {
if (callback) {
if (!key) {
return callback(errorHandler.keyNotProvided(), void 0);
} else {
return tokenHandler.generateToken(options.payload, key, options.exp, options.rat, options.iss, callback);
}
} else {
if (!key) {
return new Promise(function(resolve, reject) {
return reject(errorHandler.keyNotProvided());
});
} else {
return tokenHandler.generateToken(options.payload, key, options.exp, options.rat, options.iss);
}
}
};
/*
verify a token
@param token - the generated token
@param key - encryption key
@param callback - not required in case of promise
*/
exports.verify = function(token, key, callback) {
if (callback) {
if (!key) {
return callback(errorHandler.keyNotProvided(), void 0);
} else {
return tokenHandler.verifyToken(token, key, callback);
}
} else {
if (!key) {
return new Promise(function(resolve, reject) {
return reject(errorHandler.keyNotProvided());
});
} else {
return tokenHandler.verifyToken(token, key);
}
}
};
/*
refresh a token (if not expired completely)
@param oldToken - old token
@param key - encryption key
@param callback - not needed in case of promise
*/
exports.refresh = function(oldToken, key, callback) {
if (callback) {
if (!key) {
return callback(errorHandler.keyNotProvided(), void 0);
} else {
return tokenHandler.refreshToken(oldToken, key, callback);
}
} else {
if (!key) {
return new Promise(function(resolve, reject) {
return reject(errorHandler.keyNotProvided());
});
} else {
return tokenHandler.refreshToken(oldToken, key);
}
}
};
}).call(this);
//# sourceMappingURL=index.js.map