You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
89 lines
2.2 KiB
89 lines
2.2 KiB
###
|
|
LemonLDAP::NG TOTP registration script
|
|
###
|
|
|
|
setMsg = (msg, level) ->
|
|
$('#msg').html window.translate msg
|
|
$('#color').removeClass 'message-positive message-warning message-danger alert-success alert-warning alert-danger'
|
|
$('#color').addClass "message-#{level}"
|
|
level = 'success' if level == 'positive'
|
|
$('#color').addClass "alert-#{level}"
|
|
|
|
displayError = (j, status, err) ->
|
|
console.log 'Error', err
|
|
res = JSON.parse j.responseText
|
|
if res and res.error
|
|
res = res.error.replace /.* /, ''
|
|
console.log 'Returned error', res
|
|
setMsg res, 'warning'
|
|
|
|
token=''
|
|
|
|
getKey = (reset) ->
|
|
setMsg 'yourTotpKey', 'warning'
|
|
$.ajax
|
|
type: "POST",
|
|
url: "#{portal}/2fregisters/totp/getkey"
|
|
dataType: 'json'
|
|
data:
|
|
newkey: reset
|
|
error: displayError
|
|
# Display key and QR code
|
|
success: (data) ->
|
|
if data.error
|
|
if data.error.match /totpExistingKey/
|
|
$("#divToHide").hide()
|
|
return setMsg data.error, 'warning'
|
|
unless data.portal and data.user and data.secret
|
|
return setMsg('PE24', 'danger')
|
|
|
|
# Generate OTP url
|
|
$("#divToHide").show()
|
|
s = "otpauth://totp/#{escape(data.portal)}:#{escape(data.user)}?secret=#{data.secret}&issuer=#{escape(data.portal)}"
|
|
if data.digits != 6
|
|
s += "&digits=#{data.digits}"
|
|
if data.interval != 30
|
|
s += "&period=#{data.interval}"
|
|
# Generate QR code
|
|
qr = new QRious
|
|
element: document.getElementById('qr'),
|
|
value: s
|
|
size:150
|
|
# Display serialized key
|
|
$('#serialized').text(s)
|
|
# Show message (warning level if key is new)
|
|
if data.newkey
|
|
setMsg 'yourNewTotpKey', 'warning'
|
|
else
|
|
setMsg 'yourTotpKey', 'success'
|
|
token = data.token
|
|
|
|
verify = ->
|
|
val = $('#code').val()
|
|
unless val
|
|
setMsg 'fillTheForm', 'warning'
|
|
else
|
|
$.ajax
|
|
type: "POST",
|
|
url: "#{portal}/2fregisters/totp/verify"
|
|
dataType: 'json'
|
|
data:
|
|
token: token
|
|
code: val
|
|
TOTPName: $('#TOTPName').val()
|
|
error: displayError
|
|
success: (data) ->
|
|
if data.error
|
|
if data.error.match /bad(Code|Name)/
|
|
setMsg data.error, 'warning'
|
|
else
|
|
setMsg data.error, 'danger'
|
|
else
|
|
setMsg 'yourKeyIsRegistered', 'success'
|
|
|
|
$(document).ready ->
|
|
getKey(0)
|
|
$('#changekey').on 'click', () ->
|
|
getKey(1)
|
|
$('#verify').on 'click', () ->
|
|
verify()
|
|
|