totptool/cmds/newSecret.nim

65 lines
1.3 KiB
Nim
Raw Normal View History

2015-09-15 01:49:40 +00:00
import base32
import nuuid
2015-09-15 02:10:07 +00:00
import os
import osproc
2015-09-15 01:49:40 +00:00
import otp
import random
import strutils
import uri
2015-09-15 01:49:40 +00:00
2015-09-21 23:59:40 +00:00
const newSecretUsage =
"""Usage: totptool newSecret <name>
2015-09-15 01:49:40 +00:00
2015-09-21 23:59:40 +00:00
This will newSecreterate a new secret and recovery codes
2015-09-15 02:10:07 +00:00
for a given service name. This will then write it
to your configured secret store and make it
available for `totptool code` instantly.
"""
2015-09-15 01:49:40 +00:00
2015-09-15 02:55:02 +00:00
proc help*() =
2015-09-21 23:59:40 +00:00
echo newSecretUsage
2015-09-15 02:10:07 +00:00
quit 2
2015-09-21 23:59:40 +00:00
proc newSecret*(root: string, args: seq[string]) =
2015-09-15 02:21:58 +00:00
if args.len != 1:
2015-09-15 02:10:07 +00:00
quit "I need a machine name"
var
res = generateUUID()[0 .. 19]
2015-09-15 02:10:07 +00:00
body: string
name = args[0]
reccodes: seq[int]
2015-09-15 02:10:07 +00:00
try:
discard newTOTP(encode res).now()
except:
quit "it failed"
body = (encode res) & "\n"
2015-09-15 02:10:07 +00:00
body = body & """" RATE_LIMIT 3 30 1441950209
" WINDOW_SIZE 3
" DISALLOW_REUSE 48065007
" TOTP_AUTH""" & "\n"
for i in countup(0, 4, 1):
var code = randomInt(10000000, 99999999)
body = body & $code & "\n"
reccodes = reccodes & code
2015-09-15 02:10:07 +00:00
try:
writeFile(root / name, body)
except:
quit getCurrentExceptionMsg()
var
2015-09-15 04:25:58 +00:00
clienturl = parseURI "otpauth://totp/" / name & "?secret=" & encode res
discard execShellCmd "qrencode -t ansiutf8 '" & $clienturl & "'"
echo "Success! ", clienturl, "\n"
echo "Your recovery codes are:"
for code in reccodes:
echo " ", code