mandalorien / Sethi - Spy

// ==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;
}
`);