-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.coffee
92 lines (83 loc) · 2.93 KB
/
index.coffee
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
###
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 :
###
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 = (options, key, callback) ->
if(callback)
if(!key)
callback(errorHandler.keyNotProvided(), undefined)
else
tokenHandler.generateToken(options.payload, key, options.exp, options.rat, options.iss, callback)
else
if(!key)
return new Promise((resolve, reject)->
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 = (token, key, callback) ->
if callback
if !key
callback errorHandler.keyNotProvided(), undefined
else
tokenHandler.verifyToken(token, key, callback)
else
if !key
return new Promise((resolve, reject)->
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 = (oldToken, key, callback) ->
if callback
if !key
callback errorHandler.keyNotProvided(), undefined
else
tokenHandler.refreshToken(oldToken, key, callback)
else
if !key
return new Promise((resolve, reject)->
reject errorHandler.keyNotProvided()
)
else
return tokenHandler.refreshToken(oldToken, key)