mirror of
https://github.com/seiichiro0185/sailotp.git
synced 2024-11-14 21:16:42 +00:00
Merge branch 'icewind1991-steam-auth' into develop
This commit is contained in:
commit
3561d57d63
3 changed files with 34 additions and 5 deletions
|
@ -41,9 +41,15 @@ CoverBackground {
|
||||||
function updateOTP() {
|
function updateOTP() {
|
||||||
// get seconds from current Date
|
// get seconds from current Date
|
||||||
var curDate = new Date();
|
var curDate = new Date();
|
||||||
|
var type;
|
||||||
|
|
||||||
if (lOTP.text == "------" || curDate.getSeconds() == 30 || curDate.getSeconds() == 0 || (curDate.getTime() - lastUpdated > 2000)) {
|
if (lOTP.text == "------" || curDate.getSeconds() == 30 || curDate.getSeconds() == 0 || (curDate.getTime() - lastUpdated > 2000)) {
|
||||||
appWin.coverOTP = OTP.calcOTP(appWin.coverSecret, "TOTP", 0);
|
if (appWin.coverTitle.substr(0,6) == "Steam:") {
|
||||||
|
type = "TOTP_STEAM"
|
||||||
|
} else {
|
||||||
|
type = "TOTP"
|
||||||
|
}
|
||||||
|
appWin.coverOTP = OTP.calcOTP(appWin.coverSecret, type, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Change color of the OTP to red if less than 5 seconds left
|
// Change color of the OTP to red if less than 5 seconds left
|
||||||
|
|
|
@ -63,6 +63,11 @@ function leftpad(str, len, pad) {
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// characters steam uses to generate the final code
|
||||||
|
var steamChars = ['2', '3', '4', '5', '6', '7', '8', '9', 'B', 'C',
|
||||||
|
'D', 'F', 'G', 'H', 'J', 'K', 'M', 'N', 'P', 'Q',
|
||||||
|
'R', 'T', 'V', 'W', 'X', 'Y']
|
||||||
|
|
||||||
// *** Main Function *** //
|
// *** Main Function *** //
|
||||||
|
|
||||||
// Calculate an OTP-Value from the given secret
|
// Calculate an OTP-Value from the given secret
|
||||||
|
@ -75,7 +80,7 @@ function calcOTP(secret, type, counter) {
|
||||||
var key = base32tohex(secret);
|
var key = base32tohex(secret);
|
||||||
var factor = "";
|
var factor = "";
|
||||||
|
|
||||||
if (type == "TOTP") {
|
if (type.substr(0, 4) == "TOTP") {
|
||||||
// Get current Time in UNIX Timestamp format (Seconds since 01.01.1970 00:00 UTC)
|
// Get current Time in UNIX Timestamp format (Seconds since 01.01.1970 00:00 UTC)
|
||||||
var epoch = Math.round(new Date().getTime() / 1000.0);
|
var epoch = Math.round(new Date().getTime() / 1000.0);
|
||||||
// Get last full 30 / 60 Seconds and convert to HEX
|
// Get last full 30 / 60 Seconds and convert to HEX
|
||||||
|
@ -92,8 +97,19 @@ function calcOTP(secret, type, counter) {
|
||||||
// Finally convert the HMAC-Value to the corresponding 6-digit token
|
// Finally convert the HMAC-Value to the corresponding 6-digit token
|
||||||
var offset = hex2dec(hmac.substring(hmac.length - 1));
|
var offset = hex2dec(hmac.substring(hmac.length - 1));
|
||||||
|
|
||||||
var otp = (hex2dec(hmac.substr(offset * 2, 8)) & hex2dec('7fffffff')) + '';
|
var code = hex2dec(hmac.substr(offset * 2, 8)) & hex2dec('7fffffff');
|
||||||
otp = (otp).substr(otp.length - 6, 6);
|
var otp = '';
|
||||||
|
|
||||||
|
// Steam has it's own way of creating the code from the result
|
||||||
|
if (type == "TOTP_STEAM") {
|
||||||
|
for (var i = 0; i < 5; i++) {
|
||||||
|
otp += steamChars[code % steamChars.length];
|
||||||
|
code = Math.floor(code/steamChars.length);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
otp = code + '';
|
||||||
|
otp = (otp).substr(otp.length - 6, 6);
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
otp = "Invalid Secret!"
|
otp = "Invalid Secret!"
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,13 +69,20 @@ Page {
|
||||||
// get seconds from current Date
|
// get seconds from current Date
|
||||||
var curDate = new Date();
|
var curDate = new Date();
|
||||||
var seconds = curDate.getSeconds();
|
var seconds = curDate.getSeconds();
|
||||||
|
var type;
|
||||||
|
|
||||||
// Iterate over all List entries
|
// Iterate over all List entries
|
||||||
for (var i=0; i<appWin.listModel.count; i++) {
|
for (var i=0; i<appWin.listModel.count; i++) {
|
||||||
if (appWin.listModel.get(i).type == "TOTP") {
|
if (appWin.listModel.get(i).type == "TOTP") {
|
||||||
// Only update on full 30 / 60 Seconds or if last run of the Functions is more than 2s in the past (e.g. app was in background)
|
// Only update on full 30 / 60 Seconds or if last run of the Functions is more than 2s in the past (e.g. app was in background)
|
||||||
if (appWin.listModel.get(i).otp == "------" || seconds == 30 || seconds == 0 || (curDate.getTime() - lastUpdated > 2000)) {
|
if (appWin.listModel.get(i).otp == "------" || seconds == 30 || seconds == 0 || (curDate.getTime() - lastUpdated > 2000)) {
|
||||||
var curOTP = OTP.calcOTP(appWin.listModel.get(i).secret, "TOTP")
|
if (appWin.listModel.get(i).title.substr(0,6) == "Steam:") {
|
||||||
|
type = "TOTP_STEAM"
|
||||||
|
} else {
|
||||||
|
type = "TOTP"
|
||||||
|
}
|
||||||
|
|
||||||
|
var curOTP = OTP.calcOTP(appWin.listModel.get(i).secret, type)
|
||||||
appWin.listModel.setProperty(i, "otp", curOTP);
|
appWin.listModel.setProperty(i, "otp", curOTP);
|
||||||
}
|
}
|
||||||
} else if (appWin.coverType == "HOTP" && (curDate.getTime() - lastUpdated > 2000) && appWin.listModel.get(i).fav == 1) {
|
} else if (appWin.coverType == "HOTP" && (curDate.getTime() - lastUpdated > 2000) && appWin.listModel.get(i).fav == 1) {
|
||||||
|
|
Loading…
Reference in a new issue