thedesk/app/js/login/login.js

410 lines
11 KiB
JavaScript
Raw Normal View History

2018-01-28 23:22:43 +11:00
/*ログイン処理・認証までのJS*/
//最初に読むやつ
2018-02-09 03:43:11 +11:00
//アスタルテ判定初期化
2018-03-31 13:39:06 +11:00
2018-02-09 03:43:11 +11:00
localStorage.removeItem("kirishima")
2018-04-16 23:58:14 +10:00
localStorage.removeItem("imas")
2018-02-19 04:41:25 +11:00
localStorage.removeItem("image");
2018-03-31 13:39:06 +11:00
2018-01-28 23:22:43 +11:00
function ck() {
2018-05-20 16:17:10 +10:00
var main = localStorage.getItem("main");
if(!main){
localStorage.setItem("main",0)
}
2018-01-28 23:22:43 +11:00
var domain = localStorage.getItem("domain_0");
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_0_at");
var oldat = localStorage.getItem(domain + "_at");
if(oldat){
console.log("Move to New Account Management System")
var multi = localStorage.getItem("multi");
if (!multi) {
var acctlen=1;
} else {
var obj = JSON.parse(multi);
var acctlen=obj.length;
}
for(i=0;acctlen>i;i++){
var domain = localStorage.getItem("domain_"+i);
var oldat = localStorage.getItem(domain + "_at");
var newat = localStorage.setItem("acct_"+ i + "_at",oldat);
localStorage.removeItem(domain + "_at");
}
}
2018-02-18 16:43:11 +11:00
//コード受信
if(location.search){
2018-02-26 02:32:10 +11:00
var m = location.search.match(/\?mode=([a-zA-Z-0-9]+)\&code=(.+)/);
2018-02-18 16:43:11 +11:00
var mode=m[1];
var codex=m[2];
if(mode=="manager" || mode=="login"){
code(codex,mode);
2018-07-05 11:26:07 +10:00
}else{
2018-02-18 16:43:11 +11:00
}
}
2018-03-31 13:39:06 +11:00
2018-01-28 23:22:43 +11:00
if (at) {
$("#tl").show();
parseColumn();
2018-07-07 03:51:48 +10:00
multiSelector();
2018-01-28 23:22:43 +11:00
} else {
2018-03-27 13:39:35 +11:00
$("#tl").show();
2018-07-07 03:51:48 +10:00
multiSelector();
2018-01-28 23:22:43 +11:00
}
}
ck();
//ログインポップアップ
function login(url) {
2018-03-11 01:22:59 +11:00
if($('#linux:checked').val()=="on"){
2018-02-26 02:32:10 +11:00
var red = "urn:ietf:wg:oauth:2.0:oob"
}else{
var red = 'thedesk://login';
}
localStorage.setItem("redirect", red);
2018-01-28 23:22:43 +11:00
var start = "https://" + url + "/api/v1/apps";
2018-04-17 03:10:35 +10:00
var httpreq = new XMLHttpRequest();
httpreq.open('POST', start, true);
httpreq.setRequestHeader('Content-Type', 'application/json');
httpreq.responseType = 'json';
httpreq.send(JSON.stringify({
scopes: 'read write follow',
client_name: "TheDesk(PC)",
redirect_uris: red,
website: "https://thedesk.top"
}));
httpreq.onreadystatechange = function() {
if (httpreq.readyState == 4) {
var json = httpreq.response;
console.log(json);
var auth = "https://" + url + "/oauth/authorize?client_id=" + json[
2018-01-28 23:22:43 +11:00
"client_id"] + "&client_secret=" + json["client_secret"] +
2018-03-11 01:22:59 +11:00
"&response_type=code&redirect_uri="+red+"&scope=read+write+follow";
2018-01-28 23:22:43 +11:00
localStorage.setItem("domain_" + acct_id, url);
localStorage.setItem("client_id", json["client_id"]);
localStorage.setItem("client_secret", json["client_secret"]);
$("#auth").show();
$("#masara").hide();
2018-01-31 03:43:01 +11:00
const {
shell
} = require('electron');
2018-02-18 16:43:11 +11:00
shell.openExternal(auth);
2018-03-11 01:22:59 +11:00
if($('#linux:checked').val()=="on"){
}else{
var electron = require("electron");
var ipc = electron.ipcRenderer;
ipc.send('quit', 'go');
}
2018-04-17 03:10:35 +10:00
}
}
2018-01-28 23:22:43 +11:00
}
//テキストボックスにURL入れた
function instance() {
var url = $("#url").val();
login(url);
}
2018-02-18 16:43:11 +11:00
2018-01-28 23:22:43 +11:00
//コードを入れた後認証
2018-02-18 16:43:11 +11:00
function code(code,mode) {
2018-02-26 02:32:10 +11:00
var red = localStorage.getItem("redirect");
localStorage.removeItem("redirect")
2018-02-18 16:43:11 +11:00
if(!code){
var code = $("#code").val();
}
if(localStorage.getItem("domain_tmp")){
var url = localStorage.getItem("domain_tmp");
}else{
var url = localStorage.getItem("domain_" + acct_id);
}
2018-01-28 23:22:43 +11:00
var start = "https://" + url + "/oauth/token";
var id = localStorage.getItem("client_id");
var secret = localStorage.getItem("client_secret");
fetch(start, {
method: 'POST',
headers: {
'content-type': 'application/json'
},
body: JSON.stringify({
grant_type: "authorization_code",
2018-02-26 02:32:10 +11:00
redirect_uri: red,
2018-01-28 23:22:43 +11:00
client_id: id,
client_secret: secret,
code: code
})
}).then(function(response) {
return response.json();
}).catch(function(error) {
todo(error);
console.error(error);
}).then(function(json) {
2018-02-18 16:43:11 +11:00
todo(json);
2018-01-28 23:22:43 +11:00
if (json["access_token"]) {
localStorage.setItem(url + "_at", json["access_token"]);
2018-02-18 16:43:11 +11:00
if(mode=="manager"){
getdataAdv(url, json["access_token"]);
}else{
getdata();
}
2018-01-28 23:22:43 +11:00
}
});
}
2018-02-18 16:43:11 +11:00
//ユーザーデータ取得(最初)
2018-01-28 23:22:43 +11:00
function getdata() {
var acct_id = 0;
var domain = localStorage.getItem("domain_" + acct_id);
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var start = "https://" + domain + "/api/v1/accounts/verify_credentials";
fetch(start, {
method: 'GET',
headers: {
'content-type': 'application/json',
'Authorization': 'Bearer ' + at
},
}).then(function(response) {
return response.json();
}).catch(function(error) {
todo(error);
console.error(error);
}).then(function(json) {
console.log(json);
if (json.error) {
console.error("Error:" + json.error);
Materialize.toast("エラーが発生しました。しばらく待ってから再起動してください。Error:" + json.error,
5000);
return;
}
2018-03-31 13:39:06 +11:00
var avatar=json["avatar"];
//missingがmissingなやつ
if(avatar=="/avatars/original/missing.png"){
avatar="./img/missing.svg";
}
2018-01-28 23:22:43 +11:00
var obj = [{
at: at,
name: json["display_name"],
domain: domain,
user: json["acct"],
2018-06-18 00:26:45 +10:00
prof: avatar,
id: json["id"],
vis: json["source"]["privacy"]
2018-01-28 23:22:43 +11:00
}];
var json = JSON.stringify(obj);
console.log(obj);
localStorage.setItem("multi", json);
localStorage.setItem("name_" + acct_id, json["display_name"]);
localStorage.setItem("user_" + acct_id, json["acct"]);
localStorage.setItem("user-id_" + acct_id, json["id"]);
2018-03-31 13:39:06 +11:00
localStorage.setItem("prof_" + acct_id, avatar);
2018-02-18 16:43:11 +11:00
$("#masara").hide();
2018-01-28 23:22:43 +11:00
$("#auth").hide();
$("#tl").show();
parseColumn()
ckdb();
});
}
2018-02-18 16:43:11 +11:00
//ユーザーデータ取得(追加)
function getdataAdv(domain, at) {
var start = "https://" + domain + "/api/v1/accounts/verify_credentials";
fetch(start, {
method: 'GET',
headers: {
'content-type': 'application/json',
'Authorization': 'Bearer ' + at
},
}).then(function(response) {
return response.json();
}).catch(function(error) {
todo(error);
console.error(error);
}).then(function(json) {
console.log(json);
if (json.error) {
console.error("Error:" + json.error);
Materialize.toast("エラーが発生しました。しばらく待ってから再起動してください。Error:" + json.error,
5000);
return;
}
2018-03-31 13:39:06 +11:00
var avatar=json["avatar"];
//missingがmissingなやつ
if(avatar=="/avatars/original/missing.png"){
avatar="./img/missing.svg";
}
2018-07-07 03:51:48 +10:00
if(json["source"]["privacy"]){
var priv=json["source"]["privacy"];
}else{
var priv="public";
}
2018-02-18 16:43:11 +11:00
var add = {
at: at,
name: json["display_name"],
domain: domain,
user: json["acct"],
2018-03-31 13:39:06 +11:00
prof: avatar,
2018-06-18 00:26:45 +10:00
id: json["id"],
2018-07-07 03:51:48 +10:00
vis: priv
2018-02-18 16:43:11 +11:00
};
var multi = localStorage.getItem("multi");
var obj = JSON.parse(multi);
var target = obj.lengtth;
obj.push(add);
localStorage.setItem("name_" + target, json["display_name"]);
localStorage.setItem("user_" + target, json["acct"]);
localStorage.setItem("user-id_" + target, json["id"]);
2018-03-31 13:39:06 +11:00
localStorage.setItem("prof_" + target, avatar);
2018-02-18 16:43:11 +11:00
console.log(obj);
var json = JSON.stringify(obj);
localStorage.setItem("multi", json);
location.href="index.html";
});
}
2018-01-28 23:22:43 +11:00
2018-03-27 13:39:35 +11:00
//MarkdownやBBCodeの対応、文字数制限をチェック
2018-02-09 03:43:11 +11:00
function ckdb(acct_id) {
2018-01-28 23:22:43 +11:00
var domain = localStorage.getItem("domain_" + acct_id);
2018-02-09 03:43:11 +11:00
if(domain=="kirishima.cloud"){
localStorage.setItem("kirishima", "true");
$("#ranking-btn").show();
2018-07-07 03:51:48 +10:00
}else if(domain=="imastodon.net"){
2018-04-16 23:58:14 +10:00
localStorage.setItem("imas", "true");
2018-02-09 03:43:11 +11:00
}
2018-07-07 03:51:48 +10:00
var at = localStorage.getItem("acct_"+ acct_id + "_at");
2018-01-28 23:22:43 +11:00
var bbcode = domain + "_bbcode";
var letters = domain + "_letters";
2018-02-25 19:41:34 +11:00
if(localStorage.getItem("instance")){
var json=JSON.parse(localStorage.getItem("instance"));
if (json[bbcode]) {
if (json[bbcode] == "enabled") {
localStorage.setItem("bb_" + acct_id, "true");
} else {
localStorage.removeItem("bb_" + acct_id);
$("[data-activates='bbcode']").addClass("disabled");
$("[data-activates='bbcode']").prop("disabled", true);
}
} else {
localStorage.removeItem("bb_" + acct_id);
$("[data-activates='bbcode']").addClass("disabled");
$("[data-activates='bbcode']").addClass("disabled", true);
}
2018-04-16 23:58:14 +10:00
2018-02-25 19:41:34 +11:00
if (json[domain + "_markdown"] == "enabled") {
localStorage.setItem("md_" + acct_id, "true");
$(".markdown").show();
}else{
2018-07-05 11:26:07 +10:00
$(".anti-markdown").hide();
$(".markdown").hide();
2018-02-25 19:41:34 +11:00
localStorage.removeItem("bb_" + acct_id);
}
2018-03-20 15:55:25 +11:00
if(json[domain + "_home"]){
console.log("unique name:"+json[domain + "_home"]);
localStorage.setItem("home_" + acct_id, json[domain + "_home"]);
}
if(json[domain + "_local"]){
localStorage.setItem("local_" + acct_id, json[domain + "_local"]);
}
if(json[domain + "_public"]){
localStorage.setItem("public_" + acct_id, json[domain + "_public"]);
}
if(json[domain + "_notification"]){
localStorage.setItem("notification_" + acct_id, json[domain + "_notification"]);
}
2018-02-25 19:41:34 +11:00
}
2018-01-28 23:22:43 +11:00
}
//サポートインスタンス取得
function support() {
2018-04-01 00:55:47 +11:00
var json=JSON.parse(localStorage.getItem("instance"));
2018-01-28 23:22:43 +11:00
console.log(json);
Object.keys(json).forEach(function(key) {
var instance = json[key];
if (instance == "instance") {
templete = '<button class="btn waves-effect" onclick="login(\'' + key +
'\')">' + json[key + "_name"] + '(' + key + ')</button>';
$("#support").append(templete);
}
});
}
//アカウントを選択…を実装
2018-07-07 03:51:48 +10:00
function multiSelector() {
2018-01-28 23:22:43 +11:00
var multi = localStorage.getItem("multi");
if (!multi) {
2018-03-27 13:39:35 +11:00
var obj = [];
2018-01-28 23:22:43 +11:00
var json = JSON.stringify(obj);
localStorage.setItem("multi", json);
} else {
var obj = JSON.parse(multi);
}
var templete;
2018-05-20 16:17:10 +10:00
if(localStorage.getItem("mainuse")=="main"){
var last = localStorage.getItem("main");
}else{
var last = localStorage.getItem("last-use");
}
2018-01-28 23:22:43 +11:00
var sel;
2018-03-27 13:39:35 +11:00
console.log(obj.length)
if(obj.length<1){
$("#src-acct-sel").html('<option value="tootsearch">Tootsearch</option>');
$("#add-acct-sel").html('<option value="noauth">認証せずに見る</option>');
}else{
2018-01-28 23:22:43 +11:00
Object.keys(obj).forEach(function(key) {
var acct = obj[key];
var list = key * 1 + 1;
if (key == last) {
sel = "selected";
2018-04-16 23:58:14 +10:00
var domain = localStorage.getItem("domain_" + key);
if(idata[domain+"_letters"]){
$("#textarea").attr("data-length", idata[domain+"_letters"])
}else{
$("#textarea").attr("data-length", 500)
}
2018-03-31 13:39:06 +11:00
var profimg=localStorage.getItem("prof_"+key);
var domain=localStorage.getItem("domain_"+key);
2018-04-07 14:31:09 +10:00
if(!profimg){
profimg="./img/missing.svg";
}
2018-03-31 13:39:06 +11:00
$("#acct-sel-prof").attr("src",profimg);
$("#toot-post-btn").text("トゥート("+domain+")");
2018-06-18 00:26:45 +10:00
if(acct.background && acct.background!="def" && acct.text && acct.text!="def"){
$("#toot-post-btn").removeClass("indigo");
$("#toot-post-btn").css("background-color","#"+acct.background);
$("#toot-post-btn").css("color",acct.text);
}else{
}
2018-03-31 13:39:06 +11:00
if(domain=="kirishima.cloud"){
$("#faicon-btn").show();
}else{
$("#faicon-btn").hide();
}
2018-05-20 16:17:10 +10:00
if(domain=="imastodon.net"){
trendTag();
}else{
$("#trendtag").html("");
}
2018-01-28 23:22:43 +11:00
} else {
sel = "";
}
templete = '<option value="' + key + '" data-icon="' + acct.prof +
'" class="left circle" ' + sel + '>' + acct.user + '@' + acct.domain +
'</option>';
$(".acct-sel").append(templete);
2018-03-21 16:36:02 +11:00
2018-01-28 23:22:43 +11:00
});
2018-03-27 13:39:35 +11:00
$("#src-acct-sel").append('<option value="tootsearch">Tootsearch</option>');
$("#add-acct-sel").append('<option value="noauth">認証せずに見る</option>');
}
2018-03-21 16:36:02 +11:00
$('select').material_select('update');
2018-01-28 23:22:43 +11:00
}
2018-02-18 16:43:11 +11:00
2018-03-14 05:31:31 +11:00
//バージョンエンコ
function enc(ver){
var ver = ver.replace( /\s/g , "" );
var ver = ver.replace( /\(/g , "-" );
var ver = ver.replace( /\)/g , "" );
var ver = ver.replace( /\[/g , "_" );
var ver = ver.replace( /\]/g , "" );
return ver;
2018-03-31 13:39:06 +11:00
}