123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738 |
- /*· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·
- · ·
- · ·
- · Q V I T T E R ·
- · ·
- · ·
- · <o) ·
- · /_//// ·
- · (____/ ·
- · (o< ·
- · o> \\\\_\ ·
- · \\) \____) ·
- · ·
- · ·
- · @licstart The following is the entire license notice for the ·
- · JavaScript code in this page. ·
- · ·
- · Copyright (C) 2015 Hannes Mannerheim and other contributors ·
- · ·
- · ·
- · This program is free software: you can redistribute it and/or modify ·
- · it under the terms of the GNU Affero General Public License as ·
- · published by the Free Software Foundation, either version 3 of the ·
- · License, or (at your option) any later version. ·
- · ·
- · This program is distributed in the hope that it will be useful, ·
- · but WITHOUT ANY WARRANTY; without even the implied warranty of ·
- · MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ·
- · GNU Affero General Public License for more details. ·
- · ·
- · You should have received a copy of the GNU Affero General Public License ·
- · along with this program. If not, see <http://www.gnu.org/licenses/>. ·
- · ·
- · @licend The above is the entire license notice ·
- · for the JavaScript code in this page. ·
- · ·
- · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · */
- /* ·
- ·
- · Current time in milliseconds, to send with each request to make sure
- · we're not getting 304 responses.
- ·
- ·
- · · · · · · · · · · · · · */
- function timeNow() {
- return new Date().getTime();
- }
- /* ·
- ·
- · Get a document and replace strings
- ·
- · @param doc: the name of the document
- · @param actionOnSuccess: callback function to run on success
- ·
- · · · · · · · · · · · · · */
- function getDoc(doc, actionOnSuccess) {
- var timeNow = new Date().getTime();
- $.ajax({ url: window.fullUrlToThisQvitterApp + 'doc/' + window.selectedLanguage + '/' + doc + '.html',
- cache: false,
- type: "GET",
- success: function(data) {
- actionOnSuccess(renderDoc(data));
- },
- error: function() {
- // default to english if we can't find the doc in selected language
- $.ajax({ url: window.fullUrlToThisQvitterApp + 'doc/en/' + doc + '.html',
- cache: false,
- type: "GET",
- success: function(data) {
- actionOnSuccess(renderDoc(data));
- }
- });
- }
- });
- }
- function renderDoc(docHtml) {
- docHtml = docHtml.replace(/{instance-name}/g,window.siteTitle);
- docHtml = docHtml.replace(/{instance-url}/g,window.siteRootDomain);
- docHtml = docHtml.replace(/{instance-url-with-protocol}/g,window.siteInstanceURL);
- docHtml = docHtml.replace(/{nickname}/g,window.loggedIn.screen_name);
- docHtml = docHtml.replace(/{instance-email}/g,window.siteEmail);
- docHtml = docHtml.replace(/{instance-license-title}/g,window.siteLicenseTitle);
- docHtml = docHtml.replace(/{instance-license-url}/g,window.siteLicenseURL);
- return docHtml;
- }
- /* ·
- ·
- · Check login credentials with http basic auth
- ·
- · @param username: users screen name
- · @param password: users password
- · @param actionOnSuccess: callback function on log in success
- ·
- · · · · · · · · · */
- function checkLogin(username,password,actionOnSuccess) {
- $.ajax({ url: window.apiRoot + 'qvitter/checklogin.json',
- cache: false,
- type: 'POST',
- data: {
- username: username,
- password: password
- },
- dataType: 'json',
- error: function(data) {
- shakeLoginBox();
- if(data.status === 403) {
- showErrorMessage(window.sL.silenced);
- }
- },
- success: function(data) {
- if(typeof data.error == 'undefined' && data !== false) {
- actionOnSuccess(data);
- }
- else {
- shakeLoginBox();
- }
- }
- });
- }
- /* ·
- ·
- · Generic API GET request
- ·
- · @param stream: any api get-request e.g. 'statuses/favs/111111.json'
- · @param actionOnSuccess: callback function
- ·
- · · · · · · · · · · · · · */
- function getFromAPI(stream, actionOnSuccess) {
- var url = window.apiRoot + stream;
- $.ajax({ url: url,
- cache: false,
- type: "GET",
- dataType: 'json',
- statusCode: {
- 401:function() {
- location.reload(); // we may have been logged out in another tab, reload page
- }
- },
- success: function(data, textStatus, request) {
- // if there's no Qvitter-Notifications header, it means we're logged out
- // so if it's missing and Qvitter still thinks we're logged in, reload page
- // we've probably been logged out in another tab or something
- if(request.getResponseHeader('Qvitter-Notifications') === null && window.loggedIn !== false) {
- location.reload();
- return;
- }
- displayOrHideUnreadNotifications(request.getResponseHeader('Qvitter-Notifications'));
- // parse and cache any user arrays in header
- var userArray = false;
- if(request.getResponseHeader('Qvitter-User-Array') !== null) {
- var qvitterUserArrayHeader = request.getResponseHeader('Qvitter-User-Array');
- // quitter.se fix
- if(window.thisSiteThinksItIsHttpButIsActuallyHttps) {
- qvitterUserArrayHeader = qvitterUserArrayHeader.replace(new RegExp('http:\\\\/\\\\/' + window.siteRootDomain, 'g'), 'https:\/\/' + window.siteRootDomain);
- }
- userArray = iterateRecursiveReplaceHtmlSpecialChars($.parseJSON(qvitterUserArrayHeader));
- userArrayCacheStore(userArray);
- }
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- searchForUpdatedNoticeData(data);
- actionOnSuccess(data, userArray, request, url);
- },
- error: function(data, textStatus, errorThrown) {
- data.textStatus = textStatus;
- data.errorThrown = errorThrown;
- actionOnSuccess(false, false, data, url);
- remove_spinner();
- }
- });
- }
- /* ·
- ·
- · Hello to the API! When saying hello you will e.g. also get headers
- · with up-to-date unread notifications count to update etc
- ·
- · @param callback: function to invoke when done
- ·
- · · · · · · · · · · · · · */
- function helloAPI(callback) {
- getFromAPI('qvitter/hello.json',function(){
- if(typeof callback == 'function') {
- callback();
- }
- });
- }
- /* ·
- ·
- · Get all people we follow, all groups we're in and everyone we've blocked
- · Store in global objects
- ·
- · @param callback: function to invoke when done
- ·
- · · · · · · · · · · · · · */
- function getAllFollowsMembershipsAndBlocks(callback) {
- if(window.loggedIn === false) {
- return;
- }
- window.following = new Object();
- window.groupMemberships = new Object();
- window.groupNicknamesAndLocalAliases = new Array();
- window.allBlocking = new Array();
- getFromAPI('qvitter/allfollowing/' + window.loggedIn.screen_name + '.json',function(data){
- if(data.users) {
- $.each(data.users,function(k,v){
- if(v[2] === false) { var avatar = window.defaultAvatarStreamSize; }
- else { var avatar = v[2]; }
- if(v[3]) {
- // extract server base url
- v[3] = v[3].substring(v[3].indexOf('://')+3,v[3].lastIndexOf(v[1])-1);
- }
- v[0] = v[0] || v[1]; // if name is null we go with username there too
- window.following[k] = { 'id': k,'name': v[0], 'username': v[1],'avatar': avatar, 'url':v[3] };
- });
- }
- if(data.groups) {
- $.each(data.groups,function(k,v){
- if(v[2] === false || v[2] === null) { var avatar = window.defaultAvatarStreamSize; }
- else { var avatar = v[2]; }
- if(v[3]) {
- // extract server base url
- v[3] = v[3].substring(v[3].indexOf('://')+3);
- v[3] = v[3].substring(0, v[3].indexOf('/'));
- }
- v[0] = v[0] || v[1]; // if name is null we go with username there too
- window.groupMemberships[k] = { 'id': k,'name': v[0], 'username': v[1],'avatar': avatar, 'url':v[3] };
- window.groupNicknamesAndLocalAliases[k] = v[1];
- });
- }
- if(data.blocks) {
- window.allBlocking = data.blocks;
- markAllNoticesFromBlockedUsersAsBlockedInJQueryObject($('body'));
- }
- if(typeof callback == 'function') {
- callback();
- }
- });
- }
- /* ·
- ·
- · Get user nickname by user id
- ·
- · @param id: local user id
- · @param callback: function to invoke when done
- ·
- · · · · · · · · · · · · · */
- function getNicknameByUserIdFromAPI(id, callback) {
- display_spinner();
- getFromAPI('users/show.json?id=' + id, function(data){
- remove_spinner();
- if(data && typeof data.screen_name != 'undefined') {
- callback(data.screen_name);
- }
- else {
- callback(false);
- }
- });
- }
- /* ·
- ·
- · Get group nickname by group id
- ·
- · @param id: local group id
- · @param callback: function to invoke when done
- ·
- · · · · · · · · · · · · · */
- function getNicknameByGroupIdFromAPI(id, callback) {
- display_spinner();
- getFromAPI('statusnet/groups/show/' + id + '.json', function(data){
- remove_spinner();
- if(data && typeof data.nickname != 'undefined') {
- callback(data.nickname);
- }
- else {
- callback(false);
- }
- });
- }
- /* ·
- ·
- · Update the bookmarks
- ·
- · @param newBookmarks: the new bookmarks object to save
- ·
- · · · · · · · · · · · · · */
- function postUpdateBookmarks(newBookmarks) {
- var bookmarksString = JSON.stringify(newBookmarks);
- $.ajax({ url: window.apiRoot + 'qvitter/update_bookmarks.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- bookmarks: bookmarksString
- },
- dataType:"json",
- error: function(data){ console.log('error updating bookmarks'); },
- success: function(data) {
- // console.log('bookmarks updated successfully');
- }
- });
- }
- /* ·
- ·
- · Post new link color
- ·
- · @param newLinkColor: the new link color in hex without #
- ·
- · · · · · · · · · · · · · */
- function postNewLinkColor(newLinkColor) {
- $.ajax({ url: window.apiRoot + 'qvitter/update_link_color.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- linkcolor: newLinkColor
- },
- dataType:"json",
- error: function(data){ console.log(data); },
- success: function(data) {
- window.userLinkColor = newLinkColor;
- }
- });
- }
- /* ·
- ·
- · Post new background color
- ·
- · @param newBackgroundColor: the new background color in hex without #
- ·
- · · · · · · · · · · · · · */
- function postNewBackgroundColor(newBackgroundColor) {
- $.ajax({ url: window.apiRoot + 'qvitter/update_background_color.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- backgroundcolor: newBackgroundColor
- },
- dataType:"json",
- error: function(data){ console.log(data); },
- success: function(data) {
- // unset background image and set new color
- window.loggedIn.background_image = false;
- changeDesign({backgroundimage:false,backgroundcolor:newBackgroundColor});
- }
- });
- }
- /* ·
- ·
- · Set a profile pref
- ·
- · @param namespace: the namespace field in the db table, should be 'qvitter'
- · @param topic: the topic field in the db table,
- · @param data: the data to set
- · @param callback: function to run when finished
- ·
- · · · · · · · · · · · · · */
- function postSetProfilePref(namespace, topic, data, callback) {
- $.ajax({ url: window.apiRoot + 'qvitter/set_profile_pref.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- namespace: namespace,
- topic: topic,
- data: data
- },
- dataType:"json",
- error: function(data){ callback(false); },
- success: function(data) {
- callback(data); }
- });
- }
- /* ·
- ·
- · Post follow or unfollow user request
- ·
- · @param followOrUnfollow: either 'follow' or 'unfollow'
- · @param user_id: the user id of the user we want to follow
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function APIFollowOrUnfollowUser(followOrUnfollow,user_id,this_element,actionOnSuccess) {
- if(followOrUnfollow == 'follow') {
- var postRequest = 'friendships/create.json';
- }
- else if (followOrUnfollow == 'unfollow') {
- var postRequest = 'friendships/destroy.json';
- }
- $.ajax({ url: window.apiRoot + postRequest,
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- user_id: user_id
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false,this_element); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- actionOnSuccess(data,this_element);
- }
- });
- }
- /* ·
- ·
- · Post block or unblock user request
- ·
- · @param blockOrUnblock: either 'block' or 'unblock'
- · @param user_id: the user id of the user we want to block/unblock
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function APIBlockOrUnblockUser(blockOrUnblock,user_id,actionOnSuccess) {
- if(blockOrUnblock == 'block') {
- var postRequest = 'blocks/create.json';
- }
- else if (blockOrUnblock == 'unblock') {
- var postRequest = 'blocks/destroy.json';
- }
- $.ajax({ url: window.apiRoot + postRequest,
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- id: user_id
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- actionOnSuccess(data);
- }
- });
- }
- /* ·
- ·
- · Post sandbox or unsandbox user request
- ·
- · @param createOrDestroy: either 'create' or 'destroy'
- · @param userId: the user id of the user we want to sandbox/unsandbox
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function APISandboxCreateOrDestroy(createOrDestroy,userId,actionOnSuccess) {
- $.ajax({ url: window.apiRoot + 'qvitter/sandbox/' + createOrDestroy + '.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- id: userId
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false); console.log('sandbox error'); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- rememberStreamStateInLocalStorage();
- actionOnSuccess(data);
- }
- });
- }
- /* ·
- ·
- · Post silence or unsilence user request
- ·
- · @param createOrDestroy: either 'create' or 'destroy'
- · @param userId: the user id of the user we want to silence/unsilence
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function APISilenceCreateOrDestroy(createOrDestroy,userId,actionOnSuccess) {
- $.ajax({ url: window.apiRoot + 'qvitter/silence/' + createOrDestroy + '.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- id: userId
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false); console.log('silence error'); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- rememberStreamStateInLocalStorage();
- actionOnSuccess(data);
- }
- });
- }
- /* ·
- ·
- · Post join or leave group request
- ·
- · @param joinOrLeave: either 'join' or 'leave'
- · @param group_id: group's id
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function APIJoinOrLeaveGroup(joinOrLeave,group_id,this_element,actionOnSuccess) {
- $.ajax({ url: window.apiRoot + 'statusnet/groups/' + joinOrLeave + '.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- id: group_id
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false,this_element); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- actionOnSuccess(data,this_element);
- }
- });
- }
- /* ·
- ·
- · Post queet
- ·
- · @param queetText_txt: the text to post
- · @param in_reply_to_status_id: the local id for the queet to reply to
- · @param postToGroups: post the queet in these groups, string of ids separated by colon expected, e.g. 5:2:4
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function postQueetToAPI(queetText_txt, in_reply_to_status_id, postToGroups, actionOnSuccess) {
- $.ajax({ url: window.apiRoot + 'qvitter/statuses/update.json',
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- status: queetText_txt,
- source: 'Qvitter',
- in_reply_to_status_id: in_reply_to_status_id,
- post_to_groups: postToGroups
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- searchForUpdatedNoticeData(data);
- actionOnSuccess(data);
- }
- });
- }
- /* ·
- ·
- · Generic POST-action
- ·
- · @param action: the api action, e.q. 'statuses/retweet/1.json'
- · @param actionOnSuccess: callback function, false on error, data on success
- ·
- · · · · · · · · · · · · · */
- function postActionToAPI(action, actionOnSuccess) {
- $.ajax({ url: window.apiRoot + action,
- cache: false,
- type: "POST",
- beforeSend: function (xhr) {
- xhr.setRequestHeader('X-Qvitter-CSRF', getCookieValue('Qvitter-CSRF'));
- },
- data: {
- source: 'Qvitter'
- },
- dataType:"json",
- error: function(data){ actionOnSuccess(false); console.log(data); },
- success: function(data) {
- data = convertEmptyObjectToEmptyArray(data);
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- searchForUserDataToCache(data);
- updateUserDataInStream();
- searchForUpdatedNoticeData(data);
- actionOnSuccess(data);
- }
- });
- }
- /* ·
- ·
- · Gets favs or requeets for a queet from api
- ·
- · @param q: stream item object
- · @param qid: the queet id
- ·
- · · · · · · · · · */
- function getFavsAndRequeetsForQueet(q,qid) {
- // get immediately from localstorage cache
- var cacheData = localStorageObjectCache_GET('favsAndRequeets',qid);
- if(cacheData) {
- showFavsAndRequeetsInQueet(q, cacheData);
- }
- $.ajax({ url: window.apiRoot + "qvitter/favs_and_repeats/" + qid + ".json",
- cache: false,
- type: "GET",
- dataType: 'json',
- success: function(data) {
- data = iterateRecursiveReplaceHtmlSpecialChars(data);
- if(data.favs.length > 0 || data.repeats.length > 0) {
- localStorageObjectCache_STORE('favsAndRequeets',qid, data); // cache response
- }
- else {
- // remove from cache and DOM if all favs and repeats are deleted
- localStorageObjectCache_STORE('favsAndRequeets',qid, false);
- }
- showFavsAndRequeetsInQueet(q,data);
- },
- error: function(data) {
- remove_spinner();
- console.log(data);
- }
- });
- }
|