NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @namespace https://openuserjs.org/users/mandalorien // @name Sethi - Spy // @author mandalorien // @version 0.1.2 // @description enregistre les espionnages recu , puis regroupement de données . // @copyright 2020, mandalorien (https://openuserjs.org/users/mandalorien) // @license GPL-2.0-only // @require https://code.jquery.com/jquery-3.4.1.min.js // @require https://openuserjs.org/install/mandalorien/Sethi_-_Functions.user.js // @match https://*.ogame.gameforge.com/game/index.php?page=* // @match https://*.ogame.gameforge.com/game/index.php?page=ingame&component=galaxy* // @match https://*.ogame.gameforge.com/game/index.php?page=messages* // @match https://*.ogame.gameforge.com/game/index.php?page=ingame&component=preferences* // @updateURL https://openuserjs.org/meta/mandalorien/Sethi_-_Spy.meta.js // @downloadURL https://openuserjs.org/install/mandalorien/Sethi_-_Spy.user.js // @grant GM_xmlhttpRequest // @grant GM_addStyle // @run-at document-end // ==/UserScript== // ==OpenUser JS== // @author mandalorien // ==OpenUser JS== var db; var KEYS = [37,38,39,40]; //left,high,right,low var META_UNIVERSE = $('meta[name="ogame-universe"').attr("content"); var UNIVERSE = 0; const regex = /s(.*)\-|U/; let m; var _BackgroundTable =''; var _MODE_DEV = false; $(document).ready(function(){ if ((m = regex.exec(META_UNIVERSE)) !== null) { // The result can be accessed through the `m`-variable. if(window.openDatabase){ db = openDatabase('sethi', '1.0', 'database', 1000000000); db.transaction(function (tx) { tx.executeSql('CREATE TABLE IF NOT EXISTS LOGS (id_spy,Universe,PlayerName,PlayerAlliance,PlanetName,HaveMoon,SizeMoon,GalaxyAttaker,SystemAttaker,PlanetAttaker,Timer,GalaxyDefender,SystemDefender,PlanetDefender)'); }); } UNIVERSE = parseFloat(m[1]); } //-----------------------------PAGE RECAP var _MENU = $('#menuTableTools'); var _LINK = '<li id="optionTopRaider"><span class="menu_icon"><a id="iconeUpdate" href="https://s'+ UNIVERSE +'-fr.ogame.gameforge.com/game/index.php?page=ingame&component=overview&sethi=recap"></a></span><a id="affOptionsTR" class="menubutton " href="https://s'+ UNIVERSE +'-fr.ogame.gameforge.com/game/index.php?page=ingame&component=overview&sethi=recap" accesskey="" target="_self"><span class="textlabel">Recap</span></a></li>'; if($_GET('sethi') == 'recap'){ //on prepare le tableau var _TABLE = "<table id='sethi_information' width='657px' background='"+ _BackgroundTable +"';>"; _TABLE +="<tr>"; _TABLE +='<th><input width="100px" type="text" id="searchPlayer" class="ogl-formatInput"></th>'; _TABLE +="<th colspan='24'>Heures :</th>"; _TABLE +="</tr>"; _TABLE +="<tr>"; _TABLE +="<th>Joueurs</th>"; for(var _H = 0;_H < 24;_H++){ _TABLE +="<th width='15px' style='padding:3px;'>"+ _H +"</th>"; } _TABLE +="</tr>"; _TABLE +="</table>"; $("#middle").html(_TABLE); } $(_MENU).append(_LINK); var GALAXY = parseFloat($("#galaxy_input").val()); var SYSTEM = parseFloat($("#system_input").val()); spyMessage(UNIVERSE); //show more spy $("#planetList .smallplanet").each(function(){ var _E = $(this); var _pla = $(_E).find('.planetlink').prepend('<span class="infospy"></span>'); var _mo = $(_E).find('.moonlink').prepend('<span class="infospy"></span>'); var _C = $(_E).find('.planet-koords').text(); var positions = _C.split(':'); var _Gcheck = parseFloat(positions[0].substr(1,positions[0].length)); var _Scheck = parseFloat(positions[1]); var _Pcheck = parseFloat(positions[2].substr(0,positions[0].length)); db.transaction(function (tx) { tx.executeSql('SELECT * FROM LOGS WHERE GalaxyDefender = ? AND SystemDefender = ? AND PlanetDefender = ?', [_Gcheck,_Scheck,_Pcheck], function (tx, results) { let amountMoon = 0; let amountPlanet = 0; $(results.rows).each(function(i,ele){ if(ele.HaveMoon == 0){ amountPlanet++; }else{ amountMoon ++; } }); $(_pla).find('.infospy').text(amountPlanet); $(_mo).find('.infospy').text(amountMoon); }); }); }); }); //https://xxx.ogame.gameforge.com/game/index.php?page=messages&tab=20&ajax=1 page Spy //https://xxx.ogame.gameforge.com/game/index.php?page=messages&tab=25&ajax=1 page corbeille function spyMessage(UNIVERSE){ let _R; _R = 'https://s'+ UNIVERSE +'-fr.ogame.gameforge.com/game/index.php?page=messages&tab=20&ajax=1'; if(_MODE_DEV){ console.log(_R); } $.ajax({ method: "GET", url: _R, dataType:'html' }) .done(function(_RESULT){ let _HTML = $.parseHTML(_RESULT); let _LI = $(_HTML).find('.tab_inner li.msg'); if(_LI.length < 50){ alert("Veuillez changer Nombre de messages par page :50 , actuellement votre nombre de messages affiché simultanément est "+ _LI.length +""); return; } //Todo : faire un compteur $(_LI).each(function(index,li){ let DATE_SPY = $(li).find('.msg_head').find('.fright').find('.msg_date').text().trim(); let SPY_MSG = $(li).find('.msg_content').find('.espionageDefText').text().trim(); let SPY_HTML = $(li).find('.msg_content').find('.espionageDefText'); // console.log(SPY_MSG); let SPY_ID_MSG = $(li).attr('data-msg-id'); if(SPY_MSG != ""){ let coordAttaker = findCoord(SPY_HTML,SPY_MSG.trim(),0); let coordDefender = findCoord(SPY_HTML,SPY_MSG.trim(),1); let PLAYERNAME = findPlayerName(SPY_MSG); let TP = -1; let TM = -1; if(coordAttaker.isMoon == 0){ TP = 0; }else{ TM = 0; } if(_MODE_DEV){ console.log(coordAttaker); console.log(coordDefender); } let _Data = [ SPY_ID_MSG, UNIVERSE, PLAYERNAME, '', '', coordAttaker.isMoon, '', coordAttaker.galaxy, coordAttaker.system, coordAttaker.planet, DATE_SPY, coordDefender.galaxy, coordDefender.system, coordDefender.planet ]; if(window.openDatabase){ db.transaction(function (tx) { /* LOGS id unique,id_spy,Universe,PlayerName,PlayerAlliance,PlanetName,HaveMoon,SizeMoon,GalaxyAttaker,SystemAttaker,PlanetAttaker,Timer,GalaxyDefender,SystemDefender,PlanetDefender */ tx.executeSql('SELECT * FROM LOGS WHERE id_spy = ?', [SPY_ID_MSG], function (tx, results) { var len = parseFloat(results.rows.length, i); if(len <= 0){ var _REQ = 'INSERT INTO LOGS '; _REQ += '(id_spy,Universe,PlayerName,PlayerAlliance,PlanetName,HaveMoon,SizeMoon,GalaxyAttaker,SystemAttaker,PlanetAttaker,Timer,GalaxyDefender,SystemDefender,PlanetDefender) '; _REQ += 'VALUES '; _REQ += '(?,?,?,?,?,?,?,?,?,?,?,?,?,?) '; if(_MODE_DEV){ console.log(_REQ); } tx.executeSql(_REQ,_Data, function (tx, results) { console.log("save : "+ _Data[2] + ' ' + _Data[10]); }); } }, null); }); } } }); }); _R = 'https://s'+ UNIVERSE +'-fr.ogame.gameforge.com/game/index.php?page=messages&tab=25&ajax=1'; if(_MODE_DEV){ console.log(_R); } $.ajax({ method: "GET", url: _R, dataType:'html' }) .done(function(_RESULT){ let _HTML = $.parseHTML(_RESULT); let _LI = $(_HTML).find('.tab_inner li.msg'); //Todo : faire un compteur $(_LI).each(function(index,li){ let DATE_SPY = $(li).find('.msg_head').find('.fright').find('.msg_date').text().trim(); let SPY_MSG = $(li).find('.msg_content').find('.espionageDefText').text().trim(); let SPY_HTML = $(li).find('.msg_content').find('.espionageDefText'); // console.log(SPY_MSG); let SPY_ID_MSG = $(li).attr('data-msg-id'); if(SPY_MSG != ""){ let coordAttaker = findCoord(SPY_HTML,SPY_MSG.trim(),0); let coordDefender = findCoord(SPY_HTML,SPY_MSG.trim(),1); let PLAYERNAME = findPlayerName(SPY_MSG); let TP = -1; let TM = -1; if(coordAttaker.isMoon == 0){ TP = 0; }else{ TM = 0; } if(_MODE_DEV){ console.log(coordAttaker); console.log(coordDefender); } let _Data = [ SPY_ID_MSG, UNIVERSE, PLAYERNAME, '', '', coordAttaker.isMoon, '', coordAttaker.galaxy, coordAttaker.system, coordAttaker.planet, DATE_SPY, coordDefender.galaxy, coordDefender.system, coordDefender.planet ]; if(window.openDatabase){ db.transaction(function (tx) { /* LOGS id unique,id_spy,Universe,PlayerName,PlayerAlliance,PlanetName,HaveMoon,SizeMoon,GalaxyAttaker,SystemAttaker,PlanetAttaker,Timer,GalaxyDefender,SystemDefender,PlanetDefender */ tx.executeSql('SELECT * FROM LOGS WHERE id_spy = ?', [SPY_ID_MSG], function (tx, results) { var len = parseFloat(results.rows.length, i); if(len <= 0){ var _REQ = 'INSERT INTO LOGS '; _REQ += '(id_spy,Universe,PlayerName,PlayerAlliance,PlanetName,HaveMoon,SizeMoon,GalaxyAttaker,SystemAttaker,PlanetAttaker,Timer,GalaxyDefender,SystemDefender,PlanetDefender) '; _REQ += 'VALUES '; _REQ += '(?,?,?,?,?,?,?,?,?,?,?,?,?,?) '; if(_MODE_DEV){ console.log(_REQ); } tx.executeSql(_REQ,_Data, function (tx, results) { console.log("save : "+ _Data[2] + ' ' + _Data[10]); }); } }, null); }); } } }); }); } /**** * PARAM : param is text focus get url parameters * ****/ function $_GET(param) { var vars = {}; window.location.href.replace( location.hash, '' ).replace( /[?&]+([^=&]+)=?([^&]*)?/gi, // regexp function( m, key, value ) { // callback vars[key] = value !== undefined ? value : ''; } ); if ( param ) { return vars[param] ? vars[param] : null; } return vars; } /**** * PARAM : Data is array object container data send * ****/ function sendData(Data){ let _R = "url to send data"; $.ajax({ method: "POST", url: _R, data: Data, dataType:'json' }) .done(function(_RESULT){ }); } function findCoord(htmlb,text,iindex){ const regex = /\[[^[\]]*\]/gm; let m; let _array = []; while ((m = regex.exec(text)) !== null) { // This is necessary to avoid infinite loops with zero-width matches if (m.index === regex.lastIndex) { regex.lastIndex++; } let coord = m[0]; _array.push(coord); } /* pour savoir de ou a ou */ var _Moon = 0; if($($(htmlb).find('figure')[1]).length > 0){ if($($(htmlb).find('figure')[1]).hasClass('moon')){ _Moon = 1; } }else{ _Moon = 0; } let position = _array[iindex].split(':'); return { galaxy:parseFloat(position[0].substr(1,position[0].length)), system:parseFloat(position[1]), planet:parseFloat(position[2].substr(0,position[0].length)), isMoon:_Moon }; } function findPlayerName(text){ const regex = /\((.*)\)/; let m; if ((m = regex.exec(text)) !== null) { // The result can be accessed through the `m`-variable. let playerName = m[1]; return playerName; } } GM_addStyle(` span.infospy{ position:absolute; top:28px; left:2px; font-size:8px!important; } `);