- // SlaveHack Utilities
- // version 0.31
- // Copyright (c) 2007-2010 Philip & (c) 2009 Satori
- // This program is free software: you can redistribute it and/or modify
- // it under the terms of the GNU General Public License as published by
- // the Free Software Foundation, either version 2 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 General Public License for more details.
- //
- // You should have received a copy of the GNU General Public License
- // along with this program. If not, see <http://www.gnu.org/licenses/>.
- ////
- // Bad idea to ban me on #slavehack, I was retiring anyway, and just wanted to
- // give this out to one person. They'd have retired in turn and the script
- // would have completely disappeared. Now it's going to be completely public.
- ////
- // CHANGELOG:
- // 0.1 - 2007-07-23
- // * Started
- // * Get our IP address from the page, rather than hard coding like certain other utilities
- // * Shrunk the foreign logfile textarea, so you don't have to scroll down to hit "edit"
- // * Remove our IP from foreign logs, and put a warning that we need to submit under the log textarea.
- // * Sort slaves in slave list by clicking on headers, and added headers for individual virus types
- // * Reverse sort on the second click
- // 0.2 - 2007-07-24
- // * Added numbering to the slave list
- // * Password and task are now not HTML stripped before sorting, so null entries will show up first (or last)
- // * Process list is sorted by IP
- // * "Internet" links on processes list
- // * fixed bug: page=internet alone sometimes has the logfile, and it isn't modified.
- // * Always show textbox to enter password
- // * Never * out the password (change input type=password to type=text).
- // 0.3 - 2007-07-25
- // * Show space used by visible programs in software list
- // * Keep track of which programs we already have
- // * Remove download links for active viruses, and for software we already have.
- // * Remove delete links for active viruses
- // * Parse time from top of screen
- // * Display time since modified instead of modification date in external host file list
- // * Display time since modified instead of modification date in software list
- // * Autosubmit log change if we automatically removed our IP
- // * Display time since last captcha
- // * Upload files is on file list on external hosts instead of a seperate page
- // * Upload files doesn't display files that are already on the host (can't upload anyway).
- // * Fixed bug: 'page=software' is similar to 'page=softwareext' (software & external HDD)
- // * Sort slave list by IP if the primary sort item is the same, so sort is deterministic
- // * Remember last sort in slave list
- // * Remove "Options" from menu
- // * Added "change password" and "change layout' options to "My Computer"
- // * Hide hide link if we can't hide it any further on external computers.
- // * Turn captcha timer in header red if 19 or more minutes since last captcha
- // * Only show files on upload menu if there is room to upload them.
- // * Automatically resubmit failed password cracking
- // 0.4 - 2007-07-27
- // * Change process list to h:m:s format
- // * Change auto-submit on process list to refresh process list instead.
- // * On process list, show "Continue" button with time remaining displayed on it
- // * Select last selected account in collect income on slave list
- // * Fixed bug on upload menu where x.0 versions didn't show up on upload menu
- // * Fixed bug on upload menu where Photo collection(ZZZ).rip didn't show up on upload menu
- // 0.5 - 2007-07-28
- // * Every page now gets "seconds remaining" replaced with h:m:s remaining on the continue button, not just process list
- // * Changes h:m:s to h:mm:ss (leading 0 in seconds and minutes if less than 10)
- // * Hilight current IP on process list
- // * Lowlight (anti-hilight) files on external computer if player doesn't have a high enough seeker to see it.
- // * Don't display 0.0 in level 0.0 hidden
- // * Added "View Upload Page" option to upload menu on external file menu
- // * Clicking on "Options" now displays our automation menu instead of the donation page.
- // * Brute Force Scan IPs - At 10 IPs per second, it would take 13.6 years to cover the entire IP range, and we take 4 seconds per IP (40 times longer).
- // 0.5 - 2007-07-29
- // * Add numbering to process list
- // * Remove unnecessary whitespace from process list
- // * Completed tasks bubble up to the front of a particular IP's tasks
- // * Slightly optimized their JS on the process list.
- // * Trim unnecessary text in slaves list
- // * MySlaves import list link added to slave list.
- // * Process list has extra spacing processes with between different IPs
- // 0.6 - 2007-10-10
- // * Updates for new code
- // * Disabled: Change javascript to hh:mm:ss format on every page
- // * Disabled: Show "Continue" button with time remaining displayed on it
- // * Temp Disabled: Autosubmit if we removed our IP
- // 0.7 - 2007-10-29
- // * Logfile auto-cleaner fixed (they intentionally broke it.)
- // 0.8 - 2007-12-5
- // * Self log camper
- // * Mark NPCs in slaves list.
- // 0.8.1 - 2007-12-6
- // * Fixed a bug in NPC marking code
- // * NPCs now get ratings too. (displayed in password field)
- // 0.9 - 2007-12-9
- // * NPCs go italic when passsword is unknown
- // * Provide "crack" link in <font color=red>The slave 7.5.7.89 was removed from your list because you no longer have the admin password anymore and no virus is active.</font>
- // * Mark NPCs in ...was removed from your list...
- // 0.10 - 2008-07-07
- // * Fixed bug where double newlines were completely removed instead of turning into single newlines in logfile.
- // * Added NPC/VPC notification
- // 0.11 - 2008-07-12
- // * Added automatic connection speed analysis
- // *******************************************
- // ********** Continued by satori ************
- // *******************************************
- // This script may only work with the Theme: Black small Layout
- // *******************************************
- // 0.12 - 2009-02-06
- // * Moddified to work with the Theme: Black small Layout
- // * Link to Slave files next to Internet link in the menu
- // * Show ones own highest app version beside slaves app version
- // * Added file images to the upload form on the files page
- // 0.13 - 2009-02-08
- // * Added previous + next NPC link on Internet screen
- // * Hilight own IP on process list (white)
- // * Added IP logging/parsing of logfiles -> checks if known/slave/npc -> otherwise the IP will be saved into GM PotentialSlaves list
- // * Added link to Internet screen which lets you go to next entry of PotentialSlaves and removes the IP from the list once visited
- // * Added time needed to upload files on slave (~95% accurate)
- // * Hide hide link on own Software page for files that can't hide any further
- // 0.14 - 2009-02-10
- // * Replace Textarea on Slaves with a DIV and added ip color highlighting
- // * Fixed SlaveSort function, asc/desc is now safed and displayed correctly
- // * Added: Display installed/active Virus(es) on Internet screen
- // * Always select highest non deleteable(AV) spam virus in files/upload list
- // * Automatically select highest spam virus that can't be deleted by the slaves AV
- // * Highlight spam viruses in upload form in red if they can be deleted by the slaves AV
- // 0.15 - 2009-02-13
- // * Added: Save Slaves Connection/Apps/Viruses into GM AllSlaveApps and display it at the Internet screen
- // * Save euros/h into GM AllSlaveApps and display it on Internet and Slaves screen
- // * Connection (MBit) and Money (euros/h) now displayed on Slave page
- // * Added highlighting of warez and ddos in upload form which can be deleted by the slaves AV
- // * Fixed autoselection of highest not deletable virus on upload page, works now properly
- // * Fixed MBit & money/h sort function on slave page
- // 0.16 - 2009-02-16
- // * Added GS detection, save GS name and show it on Slaves page
- // * Highlight last connected slave on slaves page
- // * Added: Show Slaves Apps and Viruses in a Tooltip on the Slaves page
- // 0.17 - 2009-02-17
- // * Switched to Base64 encoded images so they don't get loaded from the server all the time
- // * Fixed Slave Info Virus display issue: Move Virus from apps to activ viruses in GM AllSlaveApps if it got activated
- // * Added highlighting of highest app version on slave/files
- // * Display € per (Mbit|Gb|Mhz) on hardware screen
- // * Fixed a bug where viruses with .0 level werent highlighted as active on slaves/info tooltip
- // * Fixed Own IP detection since the html code was changed
- // * Fixed Bug that screwed up the slaves page
- // 0.18 - 2009-02-19
- // * Fixed: HDD format, IP/PW reset now showing up in process list
- // * Fixed DDoS image display on slave page
- // * Added Settings menu to turn on/off Autosubmit
- // 0.19 - 2009-02-20
- // * Fixed: Hopefully everything that was broken through the html change
- // * Fixed: IP-link problem on process page
- // * Fixed: Logfile on Internet page is now parsed properly
- // 0.20- 2009-02-21
- // * Added Auto Continue since this feature was disabled by the SH devs
- // * Fixed another bunch of things caused by the html changes
- // * Added: Remove annoying text over Logfile on Internet page
- // * Added: Move ip's with a too high Firewall to crack to the end of the potential slave list
- // * Fixed: Last Captcha displayed correctly
- // * Fixed: Autorety on failed PW crack working again
- // 0.21- 2009-02-22
- // * Fixed: Timestamps in Logfiles shown correctly again
- // * Fixed: Update of slave income working again
- // Small changes (Anonymous)
- // 0.22 - 2009-04-15
- // * Added the new NPC IPs
- // * Added the WHOIS/Buy a GS Links
- // More anonymous changes
- // 0.23 - 2009-04-22
- // * Added the Launch DDoS and Collect All Links
- // * Changed the direct slaves link to "Slaves List"
- // * Added External HDD Link
- // * Added Clear Log Link
- // *******************************************
- // ********** Continued by anonymous ************
- // *******************************************
- // 0.24 - 2009-10-24
- // * Fixed some anti-SHU behaviour
- // 0.25 - 2009-11-09
- // * Fixed last captcha
- // * Made last captcha timer more accurate
- // * Last captcha timer updates in real time.
- // * Added a few more NPC IPs from http://spreadsheets.google.com/pub?key=pHMQr9KOU6e0DY0G-c8Q_KA&gid=0
- // * Fixed Clear Home Logs
- // 0.26 - 2009-11-10
- // * Made Clear Home Logs cleaner
- // * Added reset PW link
- // * Keep track of how many times we've been run, and some related items.
- // 0.27 - 2010-06-09
- // * Not detected again.
- // 0.271 - 2010-06-09
- // * added new NPC
- // 0.28 - 2010-06-09
- // * Read the code!
- // 0.29 - 2010-06-17
- // * Workaround for an SH bug
- // 0.30 - 2010-06-20
- // * Show real filetimes on hover
- // *******************************************
- // ********** Continued by acien ************
- // *******************************************
- // 0.31 - 2011-04-20 (well idk when i last edited it but this is the date i made the edits public)
- // * Fully updated the npc list to the 5.7 fwl (last npc i think) with a dummy 0.0.0.0 npc to fix a bug of it skiping the first one in the list
- ////////////////////////////////////////
- // Ideas:
-
- // BUG: 0.29 GB free space on external file list is treated as 0.029GB
-
- // Show outstanding processes for this IP & their status in page=internet ?
- // Display Process timers on every page (ie. log edit timer)
- // Check a list of IPs to see which are still valid.
- // Add Income of all Slaves /h /day and display it somewhere
- // Remove GM Slafe/Files if pressed DELETE on slave page
- // Parse logfiles for bank transfers / account numbers and bank ip
- // NPC on dropdown menus by type? (fwl, wwl, whois, banks, vspam)
- //
-
- // Automated hack&slave (checkbox to start and stop?)
-
- ////////////////////////////////////////
- // Rejected Ideas:
- // Display in-line finances? - What if someone hacks your bank account? Effort not worth the return.
- // Simplify Uploads? - it's a POST form, so hard to do, and we simplified it enough having it be one page and removing unnecessary items
- // Highlight self on hiscore list - No good way to get our username
- // Preload log edit? - Often we care about CPU speed, so we don't always want to do this.
- // BUG: We don't handle captchas on IP scanner (IP Scanner is totally useless) -> I will probably rewrite the function to check if PotentialSlaves are available
- // Keep track of our GS? Why? For collecting software, consider software on GS part of the collection? -> with the possibility to view slave apps/viruses this is already possible
-
- ////////////////////////////////////////
- // ==UserScript==
- // @name SlaveHack Utilities
- // @name:cs SlaveHack Utilities
- // @namespace http://slavehack.com
- // @include http://*.slavehack.com/index2.php*
- // @include http://slavehack.com/index2.php*
- // @description:en SlaveHack Utilities bot
- // @description:cs SlaveHack Utilities bot
- // @version 0.0.1.20150406094739
- // @description SlaveHack Utilities bot
- // ==/UserScript==
-
- (function () { // function wrapper
- var MyIP;
- var SHTime = (new Date()).getTime(); // Default value, gets overwritten by value in the HTML later on.
- var StartTime = (new Date()).getTime();
- var isCaptcha = false;
- var numPotSlaves = GM_getValue('PotentialSlaves', '').split('|').length;
- var aSettings = new Array();
- if (GM_getValue('MenuSettings', '') != '') {
- var aSet = GM_getValue('MenuSettings', '').split('|');
- for (var j=0; j < aSet.length; j++ ) {
- var aTemp = aSet[j].split('#');
- aSettings[aTemp[0]] = aTemp[1];
- }
- }
-
- GM_setValue('RunTimes',GM_getValue('RunTimes',0)+1); // Keep track of how many times we've been executed.
-
- var NPC_IP = ["0.0.0.0", "1.1.1.1", "127.0.0.1", "2.2.2.2", "243.12.1.213", "129.94.140.59", "246.185.15.208", "255.0.255.0", "124.191.123.222", "136.208.245.59", "56.195.92.143", "251.153.56.29", "57.195.92.143", "135.132.154.124", "184.182.224.6", "121.142.212.124", "19.84.229.163", "237.139.128.181", "244.2.133.183", "102.244.136.190", "254.151.123.253", "13.232.147.158", "94.87.45.87", "0.156.244.201", "242.133.164.81", "33.53.184.126", "162.51.129.169", "109.198.68.77", "71.136.63.190", "132.21.163.202", "96.128.231.240", "7.5.7.89", "16.1.233.10", "42.7.239.13", "234.86.95.202", "48.121.47.116", "142.229.199.91", "249.11.136.34", "120.92.153.170", "214.172.152.188", "119.209.47.58", "63.203.160.21", "222.65.67.51", "3.131.143.254", "17.18.111.145", "149.201.199.233", "229.31.45.38", "129.141.138.119", "91.126.151.61", "9.195.12.154", "112.43.79.120", "101.133.111.159", "206.146.24.93", "203.103.59.47", "189.23.124.7", "19.188.239.174", "255.33.234.33", "193.198.230.16", "105.133.13.108", "152.158.115.148", "81.73.86.255", "138.76.73.28", "159.229.197.164", "243.100.166.15", "66.241.98.226", "252.81.175.188", "83.230.105.121", "247.163.249.66", "29.132.103.224", "91.112.13.12", "73.137.85.78", "227.62.179.117", "173.122.175.88", "94.192.98.31", "106.71.208.142", "61.169.234.43", "144.92.41.3", "14.233.123.137", "208.193.85.97", "207.118.73.177", "160.88.2.49", "114.198.119.21", "2.158.124.111", "12.69.38.5", "118.41.15.227", "96.154.255.246", "80.77.237.134", "15.35.62.224", "238.176.102.3", "101.52.91.79", "215.119.128.38", "250.3.107.51", "49.218.89.175", "250.117.216.18", "187.161.10.38", "225.99.248.46", "69.144.46.76", "104.248.113.147", "85.148.218.87", "68.152.119.206", "220.204.61.152", "113.113.217.204", "64.223.252.221", "247.140.133.168", "67.247.218.237", "121.15.223.76", "34.170.166.53", "58.231.184.217", "140.243.173.181", "189.63.250.247", "82.82.41.237", "172.0.47.201", "236.155.42.129", "241.105.225.118", "200.60.183.92", "51.176.101.166", "239.152.83.74", "110.38.135.166", "127.115.164.138", "213.104.0.229", "171.3.251.17", "26.223.183.134", "137.0.218.12", "254.206.104.178", "103.13.127.196", "209.222.239.129", "249.85.70.54", "96.37.77.96", "160.7.44.55", "188.40.32.42", "21.26.30.22", "115.253.239.244", "21.18.35.25", "144.25.116.39", "120.101.174.253", "173.22.203.196", "11.125.146.145", "170.4.54.69", "45.68.137.16", "135.99.182.134", "9.224.178.70", "152.11.194.106", "81.58.195.224", "168.153.111.194", "165.57.86.101", "141.56.234.45", "5.81.186.49", "56.105.200.131", "54.27.17.137", "165.92.38.152", "160.204.113.34", "58.145.5.177", "6.155.226.111", "177.240.29.129", "6.100.142.172", "232.82.137.4", "164.221.47.125", "160.125.181.166", "85.71.100.215", "222.29.243.43", "135.154.119.144", "148.90.86.220", "174.58.255.90", "169.244.20.135", "34.72.193.206", "252.115.199.40", "221.83.199.24", "132.195.23.9", "35.200.115.198", "254.201.59.25", "214.192.44.89", "19.39.19.45", "67.81.5.102", "86.91.172.8", "78.95.108.51", "25.23.182.61", "64.48.99.10", "165.111.158.1"];
-
- ////////////////////////////////////////////////////////////////////////////////
- // Base64 Encoded Images
- ////////////////////////////////////////////////////////////////////////////////
-
- var aImages = new Array();
- aImages['vspam'] = '%3D%3D';
-
- aImages['fc'] = '';
-
- aImages['rddos'] = '';
-
- ////////////////////////////////////////////////////////////////////////////////
- // Helper Functions
- ////////////////////////////////////////////////////////////////////////////////
-
- ////
- // Let the script pause for x ms
- function SleepTimer(ms){
- var zeit=(new Date()).getTime();
- var stoppZeit=zeit+ms;
- while((new Date()).getTime()<stoppZeit){};
- }
-
- ////
- // Check if IP is a NPC
- function checkIsNPC (sIp) {
- for (var o = 0; o < NPC_IP.length; o++ ) {
- if ( NPC_IP[o] == sIp ) {
- return true;
- }
- }
- return false;
- }
-
- ////
- // Parse IPs from string and sort out npcs, own ip, double ips and already known slaves
- // Added highlighting of IP's
- // Added highlighting of Date/Time
- function ParseLog(sInput, type) {
- var aTemp = new Array();
- var aTemp2 = new Array();
- var aTemp3 = new Array();
- var check;
-
- // Transform Date/Time into elapsed Time
- if ( type=='highlight' ) {
- var regExp = /(\d+)-(\d+)-(\d+) (\d+):(\d+)/gm;
- var m = sInput.match(regExp);
-
- if (m != null) {
- for ( var k = 0; k <= 1; k++) {
- if (k == 0) { // sort out double times
- aTemp = m;
- aTemp2 = new Array();
- aTemp3 = new Array();
- } else if (k == 1) { // highlight times
- aTemp = aTemp3;
- aTemp2 = new Array();
- aTemp3 = new Array();
- }
-
- for ( var j = 0; j < aTemp.length; j++) {
- check = 0;
- for (i = 0; i < aTemp2.length; i++) {
- if ( aTemp2[i] == aTemp[j] ) { check = 1; }
- }
-
- if ( check == 0 ) {
- if ( k == 0) {
- aTemp3[aTemp3.length] = aTemp[j];
- aTemp2[aTemp2.length] = aTemp[j];
- } else if ( k == 1 ) {
- // ' + aTemp[j] + '
- sInput = sInput.replace(new RegExp(aTemp[j], "gm" ) ,' <b>(' + DisplayTimeDiff(Math.floor(SHTime/60000)*60000-ParseTime(aTemp[j])) + ')</b> ago');
- }
- }
- }
- }
- }
- }
-
- var regExp = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- var m = sInput.match(regExp);
-
- if (m != null) {
- for (var k = 0; k <= 3; k++) {
- if (k == 0) { // sort out double ips
- aTemp = m;
- aTemp2 = new Array();
- aTemp3 = new Array();
- } else if (k == 1) { // sort out npcs and own ip
- aTemp = aTemp3;
- aTemp2 = NPC_IP;
- aTemp2[aTemp2.length] = MyIP;
- aTemp3 = new Array();
- } else if (k == 2) { // sort out already known potential slaves
- aTemp = aTemp3;
- aTemp2 = GM_getValue('PotentialSlaves', '').split('|');
- aTemp3 = new Array();
- } else if (k == 3) { // sort out own slaves
- aTemp = aTemp3;
- aTemp2 = GM_getValue('AllSlaves', '').split('|');
- aTemp3 = new Array();
- }
-
- for ( var j = 0; j < aTemp.length; j++) {
- check = 0;
- for ( var i = 0; i < aTemp2.length; i++) {
- aTemp2[i] = ((k==3) ? aTemp2[i].split('#')[0] : aTemp2[i]);
- if ( aTemp2[i] == aTemp[j] ) { check = 1; }
- }
-
- if ( type=='highlight' && k>0 && check==1 ) {
- if ( k == 1 ) {
- var hlc = ((aTemp[j] == MyIP) ? 'green' : '#FF33FF');
- } else if ( k == 2 ) {
- var hlc = 'red';
- } else if ( k == 3 ) {
- var hlc = 'blue';
- }
- sInput = sInput.replace(new RegExp(aTemp[j], "gm" ) ,' <a href="index2.php?page=internet&var2=' + aTemp[j] + '"><font style="color: ' + hlc + '; font-weight: bold;">' + aTemp[j] + '</font></a> ');
- }
-
- if ( check==0 ) {
- aTemp3[aTemp3.length] = aTemp[j];
- if (k == 0) { aTemp2[aTemp2.length] = aTemp[j]; }
- }
- }
- }
- }
-
- if ( type=='highlight' ) {
- return sInput;
- } else if (type=='collect' && m != null) {
- GM_setValue('PotentialSlaves', GM_getValue('PotentialSlaves', '') + ((GM_getValue('PotentialSlaves', '') == '' || aTemp3.length == 0) ? '' : '|') + aTemp3.join('|'));
-
- if ( aTemp3.length > 0 ) {
- GM_log('New Pot. Slaves: ' + aTemp3.join('|'));
- }
- }
- }
-
- ////
- // Function to keep track of our Slaves
- function manageSlaves(sIp, aData, sAction, sTyp) {
- if ( sTyp == 'slave' ) {
- var aAllSlaves = GM_getValue('AllSlaves', '').split('|');
- } else if ( sTyp == 'files' ) {
- var aAllSlaves = GM_getValue('AllSlaveApps', '').split('|');
- }
-
- var aOut = new Array();
- var found = false;
- var delIP = '';
- // check if ip is in list
- for ( var j = 0; j < aAllSlaves.length; j++) {
- var aTemp = aAllSlaves[j].split('#');
- if ( aTemp[0] == sIp && (sAction == 'update' || sAction == 'get') ) {
- found = j;
- break;
- }
-
- if ( (aTemp[0] != sIp && sAction == 'delete' && aData == '') || (aTemp[6] != sIp && sAction == 'delete' && aData == 'id') ) {
- aOut[aOut.length] = aAllSlaves[j];
- } else if ( sAction == 'delete' ) {
- GM_log('deleted: ' + aAllSlaves[j]); // debug show deleted entry
- delIP = aTemp[0];
- }
- }
-
- if ( sAction == 'update' ) {
- if ( sTyp == 'slave' ) {
- // 0: IP, 1: PW, 2: V1, 3: V2, 4: V3, 5: Typ
- var regExp = / \d{1}\.\d{1}/;
-
- if ( aData != '' ) {
- aOut[0] = sIp;
- aOut[1] = ((aData[2] == '<i>No Spam virus</i>' ) ? '0' : ((aData[2].match(regExp) != null) ? aData[2].match(regExp)[0].replace(' ', '') : '0'));
- aOut[2] = ((aData[3] == '<i>No DDoS virus</i>' ) ? '0' : ((aData[3].match(regExp) != null) ? aData[3].match(regExp)[0].replace(' ', '') : '0'));
- aOut[3] = ((aData[4] == '<i>No sharewarez virus</i>' ) ? '0' : ((aData[4].match(regExp) != null) ? aData[4].match(regExp)[0].replace(' ', '') : '0'));
- aOut[4] = ((aData[5] == 'Spam relay ' ) ? 'S' : ((aData[5] == 'DDoS bot' ) ? 'D' : ((aData[5] == 'File Share' ) ? 'W' : 'N')));
- aOut[5] = ((found == false) ? SHTime : ((aAllSlaves[j].split('#')[5] != 'undefined') ? aAllSlaves[j].split('#')[5] : SHTime));
- aOut[6] = ((aData[7] != '' ) ? (aData[7].match(/DELETE=\d+/gm)[0].split('=')[1]) : (aAllSlaves[j].split('#')[6]));
- } else {
- aOut = new Array(sIp, '', '', '', '', SHTime, '');
- //GM_log('updated: ' + aOut.join('#'));
- }
- //GM_log(aOut.join('#'));
-
- if ( found != false) {
- aAllSlaves[found] = aOut.join('#');
- } else {
- aAllSlaves[aAllSlaves.length] = aOut.join('#');
- }
-
- GM_setValue('AllSlaves', aAllSlaves.join('|'));
- } else if ( sTyp == 'files' ) {
- // 0: IP, 1: MBIT, 2: Money/h, 3: apps, 4: viruses, 5: last update, 6: GSname
-
- // Move Virus app to Active Viruses if activated
- if ( aData[0] == 'app2vir' ) {
- //manageSlaves(ConnectedToIP, new Array('app2vir', aTemp[0], aTemp[1]), 'update', 'files');
- if ( found != false ) {
- var aTemp = aAllSlaves[found].split('#');
- var aApp = ((aTemp[3] != '') ? aTemp[3].split('@') : '' );
- var aVir = ((aTemp[4] != '') ? aTemp[4].split('@') : '' );
-
- if ( aApp != '' ) {
- if ( aTemp[3] != (aData[1] + ' ' + aData[2]) ) {
- var aNew = new Array();
- for (var j=0; j<aApp.length; j++) {
- var aApps = aApp[j].split(' ');
- if ( aApps[0] == aData[1] && aApps[1] == aData[2] ) {} else {
- aNew[aNew.length] = aApp[j];
- }
- }
- aTemp[3] = '';
- aTemp[3] = aNew.join('@');
- } else {
- aTemp[3] = '';
- }
-
- if ( aVir != '' ) {
- aTemp[4][aTemp[4].length] = aData[1] + ' ' + aData[2];
- var aNew = new Array();
- aNew['vspam'] = new Array();
- aNew['vshare'] = new Array();
- aNew['vddos'] = new Array();
- var added = false;
- for (var j=0; j<aVir.length; j++) {
- var aVirs = aVir[j].split(' ');
- aNew[aVirs[0]][aNew[aVirs[0]].length] = aVir[j];
- }
-
- aNew[aData[1]][aNew[aData[1]].length] = aData[1] + ' ' + aData[2];
- aNew[aData[1]].sort();
- aNew[aData[1]].reverse();
-
- aTemp[4] = aNew['vspam'].join('@');
- if ( aTemp[4] == '' ) {
- aTemp[4] = aNew['vshare'].join('@');
- } else if ( aNew['vshare'].join('@') != '' ) {
- aTemp[4] = aTemp[4] + '@' + aNew['vshare'].join('@');
- }
-
- if ( aTemp[4] == '' ) {
- aTemp[4] = aNew['vddos'].join('@');
- } else if ( aNew['vddos'].join('@') != '' ) {
- aTemp[4] = aTemp[4] + '@' + aNew['vddos'].join('@');
- }
-
- } else {
- aTemp[4] = aData[1] + ' ' + aData[2];
- }
-
- aAllSlaves[found] = aTemp.join('#');
- GM_setValue('AllSlaveApps', aAllSlaves.join('|'));
- }
- }
- return '';
- } else {
- aOut[0] = sIp;
-
- for ( var i = 1; i <= 6; i++) {
- aOut[i] = ((aData[i] != '') ? aData[i] : ((found != false) ? (aAllSlaves[found].split('#')[i]) : '' ));
- }
-
- if ( found != false) {
- aAllSlaves[found] = aOut.join('#');
- } else {
- aAllSlaves[aAllSlaves.length] = aOut.join('#');
- }
-
- GM_setValue('AllSlaveApps', aAllSlaves.join('|'));
- }
- }
- }
-
- if ( sAction == 'get' ) {
- if ( found != false) {
- return aAllSlaves[found];
- } else {
- return '';
- }
- }
-
- if ( sAction == 'delete' ) {
- if ( sTyp == 'slave' ) {
- GM_setValue('AllSlaves', aOut.join('|'));
- if ( aData == 'id' ) {
- manageSlaves(delIP, '', 'delete', 'files');
- }
- } else if ( sTyp == 'files' ) {
- GM_setValue('AllSlaveApps', aOut.join('|'));
- }
- }
- }
-
- ////
- // Calculate Up/Download time
- // Accuracy ~95%
- function getUpDownloadTime(iSize, iSpeed, sOutput) {
- var iSec = parseInt(iSize.replace(/(0\.00|0\.0|0\.|\.)/gm, '')*(1000/iSpeed)*1.045+3);
-
- if ( sOutput == 'sec' ) {
- return iSec;
- }
- var iMin = 0;
- var iHou = 0;
-
- while ( iSec >= 60 ) {
- iMin = iMin +1;
- iSec = iSec - 60;
- }
-
- while ( iMin >= 60 ) {
- iHou = iHou + 1;
- iMin = iMin - 60;
- }
-
- return ((iHou>0) ? (iHou + 'h') : '') + ((iMin>0) ? (((iHou>0) ? ' ' : '') + iMin + 'm') : '') + ((iSec>0) ? (((iHou>0 || iMin>0) ? ' ' : '') + iSec + 's') : '');
- }
-
- ////
- // Parse human readable time into javascript format.
- function ParseTime(str) {
- // Time as shown is UTC+2, but since we're using the same ParseTime function,
- // it shouldn't matter as we're just doing time differences
-
- // As a side effect, returns current time if we can't parse the time.
- // This is intentional, as it's the best "sane" value to default to. (but still not "good")
- if ( str != '' && typeof str != 'undefined' ) {
- var retval = new Date();
- var reTime = /(\d+)-(\d+)-(\d+) (\d+):(\d+):(\d+)\.(\d+)/;
-
- if (str.match(reTime)) {
- var match = reTime.exec(str);
- retval.setMilliseconds(match[7]);
- retval.setSeconds(match[6]);
- retval.setMinutes(match[5]);
- retval.setHours(match[4]);
- retval.setDate(match[1]);
- retval.setMonth(match[2]);
- retval.setFullYear(match[3]);
- return retval.getTime();
- }
-
- reTime = /(\d+)-(\d+)-(\d+) (\d+):(\d+):(\d+).(\d+)/;
- if (str.match(reTime)) {
- var match = reTime.exec(str);
- retval.setMilliseconds(0);
- retval.setSeconds(match[6]);
- retval.setMinutes(match[5]);
- retval.setHours(match[4]);
- retval.setDate(match[1]);
- retval.setMonth(match[2]);
-
- retval.setFullYear(match[3]);
- return retval.getTime();
- }
-
- reTime = /(\d+)-(\d+)-(\d+) (\d+):(\d+)/;
- if (str.match(reTime)) {
- var match = reTime.exec(str);
- retval.setMilliseconds(0);
- retval.setSeconds(0);
- retval.setMinutes(match[5]);
- retval.setHours(match[4]);
- retval.setDate(match[1]);
- retval.setMonth(match[2]);
- retval.setFullYear(match[3]);
- return retval.getTime();
- }
- return retval.getTime();
- } else {
- return '';
- }
- }
-
- ////
- // Display Time diff in a human readable form
- function DisplayTimeDiff(diff) {
- var ret = '';
- diff = Math.abs(diff);
- // Milliseconds, if applicable
- if (diff%1000 > 0) {
- if (diff%1000 < 10) {
- ret = '.00'+diff%1000;
- } else if (diff%1000 < 100) {
- ret = '.0'+diff%1000;
- } else {
- ret = '.'+diff%1000;
- }
- }
- diff=Math.floor(diff/1000);
-
- // Seconds
- if ((diff%60 == 0) && (ret=='')) {
- // Do nothing
- } else if (diff%60 < 10) {
- ret = ':0' + (diff%60) + ret;
- } else {
- ret = ':' + (diff%60) + ret;
- }
- diff=Math.floor(diff/60);
-
- // Minutes
- if (diff%60 < 10) {
- ret = '0' + (diff%60) + ret;
- } else {
- ret = '' + (diff%60) + ret;
- }
- diff=Math.floor(diff/60);
-
- // Hours
- if (diff%24 < 10) {
- ret = '0' + (diff%24) + ':' + ret;
- } else {
- ret = '' + (diff%24) + ':' + ret;
- }
- diff=Math.floor(diff/24);
-
- // Days if applicable
- if (diff == 1) {
- ret = ''+diff+' day ' + ret;
- } else if (diff > 1) {
- ret = ''+diff+' days ' + ret;
- }
-
- return ret;
- }
-
- ////////////////////////////////////////////////////////////////////////////////
- // The Code
- ////////////////////////////////////////////////////////////////////////////////
-
- ////
- // Place a Table beside slavehack logo to manage the settings
- {
- var regExp = /layout2_logo\.jpg/gm;
- var allImg = document.getElementsByTagName('img');
- var doOnce = 0;
- for (var i = 0; i < allImg.length; i++) {
- var m = allImg[i].src.match(regExp);
- if (m != null) {
- if ( doOnce == 0 ) {
-
- var sTableRow1 = '<td width="50" align="center"><b>-SHU-</b></td><td width="20"></td><td>Auto Submit</td><td width="20"></td><td>Auto Continue</td>';
- var sTableRow2 = '<td><b>Menu</b></td><td></td><td><div id="submit" style="font-weight:bold; color:' + ((aSettings['submit']==1) ? '#00FF00' : '#FF0000') + '">' + ((aSettings['submit']==1) ? 'On' : 'Off') + '</div><td></td><td><div id="continue" style="font-weight:bold; color:' + ((aSettings['continue']==1) ? '#00FF00' : '#FF0000') + '">' + ((aSettings['continue']==1) ? 'On' : 'Off') + '</div></td>';
-
- var sTableRow = '<table cellpadding="0" border="0" cellspacing="0"><tr align="center"><td rowspan="2" valign="top"><img src="templates/layout2_logo.jpg"></td><td width=40></td>' + sTableRow1 + '</tr><tr align=center><td></td>' + sTableRow2 + '</tr></table>';
-
- newElement = document.createElement('div');
- newElement.innerHTML = sTableRow;
-
- doOnce = 1;
- allImg[i].parentNode.insertBefore(newElement, allImg[i]);
- } else if ( doOnce == 1 ) {
- doOnce = 2;
- allImg[i].style.display = 'none';
- }
- }
- }
- }
-
- ////
- // Switch settings on/off
- function changeSettings(sTyp) {
- var sSettings = GM_getValue('MenuSettings', '');
- if ( sSettings.match(sTyp) ) {
-
- var aSet = sSettings.split('|');
-
- for (var i = 0; i < aSet.length; i++) {
- var aTemp = aSet[i].split('#');
-
- if ( aTemp[0] == sTyp ) {
- aSet[i] = sTyp + '#' + ((aTemp[1] == 1) ? 0 : 1);
- }
- }
- sSettings = aSet.join('|');
-
- } else {
- sSettings = sSettings + ((sSettings != '' ) ? '|' : '') + sTyp + '#1';
- }
-
- document.getElementById(sTyp).innerHTML = ((document.getElementById(sTyp).innerHTML == 'On') ? 'Off' : 'On');
- document.getElementById(sTyp).style.color = ((document.getElementById(sTyp).innerHTML == 'On') ? '#00FF00' : '#FF0000');
- aSettings[sTyp] = ((document.getElementById(sTyp).innerHTML == 'On') ? '1' : '0');
-
- GM_setValue('MenuSettings', sSettings);
- }
-
- ////
- // Settings Eventlistener
- document.addEventListener('click', function(event) {
- target = event.target;
- //GM_log(target.nodeName);
- if (target.nodeName == 'DIV') {
- if (target.id == 'submit' || target.id == 'continue') {
- changeSettings(target.id);
- }
- }
- }, true);
-
- ////
- // Get our IP and put it on the MyIP var
- {
- var allSmall = document.getElementsByTagName('small');
- // For each <small> tag
- for (var i = 0; i < allSmall.length; i++) {
- // If it contains Computer time: ..., retrieve and set data for later use
- var thisSmall = allSmall[i];
- var re = /Computer\s(time|time\sformat):\s(\d+)\sStandard\s(time|time\sformat):\s(.*)\s\[(.*?)(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})(.*?)\]/gm;
- var thisMatch = re.exec(thisSmall.innerHTML);
-
- if (thisSmall.innerHTML.match(re)) {
- MyIP = thisMatch[6];
- SHTime = Math.floor(ParseTime(thisMatch[4])/1000+(thisMatch[2]%60))*1000;
-
- // Add last Captcha time
- var TimeDiff = Math.abs((Math.floor(SHTime/1000)-GM_getValue("LastCaptcha", SHTime)))*1000;
- if (TimeDiff >= 19*60*1000) { // If more than 19 minutes since last captcha, turn red
- thisSmall.innerHTML = thisSmall.innerHTML + " <span id=\"LastCaptcha\" style=\"color: red;\">Last captcha: " + (DisplayTimeDiff(TimeDiff))+"</span>";
- } else {
- thisSmall.innerHTML = thisSmall.innerHTML + " <span id=\"LastCaptcha\">Last captcha: " + (DisplayTimeDiff(TimeDiff))+"</span>";
- }
-
- function CaptchaClock() {
- var TimeDiff = Math.abs((Math.floor((SHTime+((new Date()).getTime()-StartTime))/1000)-GM_getValue("LastCaptcha", SHTime)))*1000;
- document.getElementById("LastCaptcha").innerHTML="Last captcha: " + (DisplayTimeDiff(TimeDiff));
- if (TimeDiff >= 19*60*1000) { // If more than 19 minutes since last captcha, turn red
- document.getElementById("LastCaptcha").style.color = "red";
- } else {
- document.getElementById("LastCaptcha").style.color = "white";
- }
- }
- window.setInterval(CaptchaClock, 1000); // Tick once per second
- // Theoretically, there is a good chance of an unsmooth update every so often, but not worth the cpu cost to fix by ticking 10 times per second instead of once.
- }
- }
- }
-
- ////
- // Some generic countermeasures, only runs for dedicated users or people who look here
- if (GM_getValue('RunTimes',0) > 1000)
- {
- var allScript = document.getElementsByTagName('script');
- // For each <script> tag
- for (var i = 0; i < allScript.length; i++) {
- var thisScript = allScript[i];
- var re = /function (.+)\(\) \{ if\(document\.body\.innerHTML\.indexOf/;
- var thisMatch = re.exec(thisScript.innerHTML);
-
- if (thisScript.innerHTML.match(re)) {
- unsafeWindow[thisMatch[1]] = function() {};
- }
- }
- clicked = false;
- document.addEventListener('click', function(event) { clicked = true; }, true);
- if (Math.abs(GM_getValue('LastRunTime',0)-parseInt(StartTime/1000))>3600)
- {
- document.addEventListener('onbeforeunload', function(event) {
- if (!clicked) { return 'Document is trying to navigate away without user interaction. This may be due to anti-shu measures. It is recommended that you disable SHU, report this, and check for updates. Pressing cancel will avoid detection.'; }
- }, true);
- }
- }
-
- ////
- // Check if we've been captcha'ed
- {
- var allImg = document.getElementsByTagName('img');
- for (var i = 0; i < allImg.length; i++) {
- if (allImg[i].src.match(/workimage.php\?(rand|random)=/gm)) {
- isCaptcha = true;
- }
- }
- }
-
- ////
- // Save last Captcha time
- if (isCaptcha || document.body.innerHTML.match('<script type="text/javascript" src="http://api.recaptcha.net/challenge?')) {
- GM_setValue("LastCaptcha", Math.floor(SHTime/1000));
- GM_setValue("CaptchaSolved",0);
- // Set the captcha timer to unload time rather than load time. If this event doesn't fire, we still have load time set.
- window.addEventListener("unload", function(event) {
- if (GM_getValue("CaptchaSolved",0)==0) // Catch race conditions if multiple copies of the captcha are opened, only count from the first solution.
- {
- GM_setValue("LastCaptcha", Math.floor((SHTime+((new Date()).getTime()-StartTime))/1000));
- GM_setValue("CaptchaSolved",1);
- }
- }, false);
- } else { // no chaptcha - start
-
- ////
- // Always display "collect income" on slaves list
- // Automatically resubmit failed password cracking
- {
- var allA = document.getElementsByTagName('a');
- // For each <a> tag
- for (var i = 0; i < allA.length; i++) {
- if (allA[i].href.substr(allA[i].href.indexOf('/index2.php?page=software'))=='/index2.php?page=software') {
- allA[i].innerHTML='Main HDD';
- }
- if (allA[i].href.substr(allA[i].href.indexOf('/index2.php?page=slaves'))=='/index2.php?page=slaves') {
- allA[i].href='/index2.php?page=slaves';
- allA[i].innerHTML='Slaves List';
- }
-
- //http://www.slavehack.com/index2.php?page=internet&var2=174.58.255.90&var3=crack&var4=
- if ( allA[i].innerHTML.match('Try again') ) {
- window.location.href = allA[i].href;
- }
- /*if ( allA[i].href.match(/\?page=internet&var2(.*?)&action=crack$/) ) { // (OLD VERSION)
- allA[i].href = allA[i].href + '&crack=true';
- }*/
- }
- }
-
- ////
- // Auto-Continue
- if ( aSettings['continue'] == 1 ) {
- var continueScript = document.createElement('script');
- continueScript.type = 'text/javascript';
-
- var sContScript = '' +
- 'if ( document.getElementsByTagName("script").length > 0 ) {\n' +
- ' function continueFunction() {\n' +
- ' var allForm = document.getElementsByTagName("form");\n' +
- ' var sFound = 0;' +
- ' for (var i = 0; i < allForm.length; i++) {\n' +
- ' if ( allForm[i].innerHTML.match("Continue") ) {\n' +
- ' allForm[i].submit();\n' +
- ' sFound = 1;\n' +
- ' }\n' +
- ' }\n' +
- ' if ( sFound == 0 ) {\n' +
- ' window.setTimeout("continueFunction()", 100);\n' +
- ' }\n' +
- ' }\n' +
- ' window.setTimeout("continueFunction()", 100);' +
- '}\n';
- continueScript.innerHTML = sContScript;
- document.getElementsByTagName('head')[0].appendChild(continueScript);
- }
-
- ////
- // Check if current ip is in potential slave list and if yes delete it from the list
- // http://www.slavehack.com/index2.php?gow=74.198.141.249&page=internet
- var regExp = /(\?page=internet\&var2=(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}))/gm;
- if ((window.location.href.match(regExp))) {
- var aTemp = GM_getValue('PotentialSlaves', '').split('|');
- var aTemp2 = new Array();
-
- var regExp = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/;
- var m = window.location.href.match(regExp);
-
- if (m != null) {
- for (var i = 0; i < aTemp.length; i++) {
- if ( aTemp[i] != m[0] ) {
- aTemp2[aTemp2.length] = aTemp[i];
- }
- }
- GM_setValue('PotentialSlaves', aTemp2.join('|'));
- }
- }
-
- ////
- // Move IP tp potential slaves list if wwl is too low
- if ( document.body.innerHTML.match('You cannot crack this system, a firewall is active and you haven\'t got a firewall bypasser which is good enough for this firewall.') ) {
- var thisIP = window.location.href.match(/(\d+\.\d+\.\d+\.\d+)/);
- if ( thisIP != null ) {
- if ( checkIsNPC(thisIP[0]) == false ) {
- var sTemp = GM_getValue('PotentialSlaves', '');
- sTemp = sTemp + ((sTemp == '') ? '' : '|') + thisIP[0];
- GM_setValue('PotentialSlaves', sTemp);
- }
- }
- }
-
- ////
- // Create new link to slave Files, next to Internet link
- var allTD = document.getElementsByTagName('A');
- // For each <td> tag
- for (var i = 0; i < allTD.length; i++) {
- if (allTD[i].innerHTML==('Internet')) {
- //GM_log(allTD[i].parentNode.innerHTML);
- ///////////////////////////////////////////
- // WHOIS LIST
- ///////////////////////////////////////////
- extra = "<strong>WHOIS Servers</strong>";
- extra += "<li> <a href='index2.php?var2=1.1.1.1&page=internet'>WHOIS 1 [Louis]</a></li>";
- extra += "<li> <a href='index2.php?var2=132.21.163.202&page=internet'>WHOIS 2 [Fav]</a></li>";
- extra += "<li> <a href='index2.php?var2=152.158.115.148&page=internet'>WHOIS 3 [Alex]</a></li>";
- // BANKS
- extra += "<br /><strong>Banks</strong>";
- // banks!
- extra += "<li> <a href='index2.php?var2=135.132.154.124&page=internet'>Ypesteiner [135]</a></li>";
- extra += "<li> <a href='index2.php?var2=33.53.184.126&page=internet'>Ratepel [33]</a></li>";
- extra += "<li> <a href='index2.php?var2=71.136.63.190&page=internet'>Mounstar [71]</a></li>";
- extra += "<li> <a href='index2.php?var2=63.203.160.21&page=internet'>Cenmyr [63]</a></li>";
- extra += "<li> <a href='index2.php?var2=207.118.73.177&page=internet'>Esmob [207]</a></li>";
- extra += "<li> <a href='index2.php?var2=121.15.223.76&page=internet'>Schiedam [121]</a></li>";
- ///////////////////////////////////////////
- // EXTRA LINKS
- extra += "<br />";
- // extra += "<li> <a href='index2.php?var2=&page=internet'>Link Name</a></li>";
- extra += "<strong>Misc Links</strong>";
- extra += "<li> <a href='index2.php?var2=152.11.194.106&page=internet'>Buy a GS</a></li>";
- extra += "<li> <a href='index2.php?page=mycomputer&var2=changepass&var3=&var4='>Reset PW</a></li>";
- // No user editable sections below
- extra += "<br /><br />";
- ////////////////////////////////////////// END
- allTD[i].parentNode.innerHTML = allTD[i].parentNode.innerHTML.replace('<br>', '').replace('<br>', '') + '- <a href="http://www.slavehack.com/index2.php?page=internet&var3=files">Files</a><br /><br />'+extra;
- }
- if (allTD[i].innerHTML==('Slaves List')){
- // Slaves options...
- ext = "";
- ext += "<li> <a href='index2.php?page=slaves&collect=1&slave=all'>Collect all</a></li>";
- ext += "<li> <a href='index2.php?page=slaves&ddos=1'>Launch DDoS</a></li>";
- ext += "<br />";
- allTD[i].parentNode.innerHTML = allTD[i].parentNode.innerHTML.replace('<br>', '').replace('<br>', '') +ext;
- }
- if (allTD[i].innerHTML==('Main HDD')){
- ext2 = "";
- ext2 += "<li> <a href='index2.php?page=softwareext'>External HDD</a></li>";
- ext2 += "<li> <a href='index2.php?page=logs&var3=&aktie=&var2=&editlog=%20'>Clear Home Logs</a></li>";
- allTD[i].parentNode.innerHTML = allTD[i].parentNode.innerHTML.replace('<br>', '').replace('<br>', '') +ext2;
- }
- }
-
- ////
- // Calculate €/(Mhz|Gb|Mbit) for every Hardware
- if (window.location.href.match('page=hardware&var5=')) {
- var allTR = document.getElementsByTagName('tr');
- var found = false;
- if ( window.location.href.match('var5=HD') || window.location.href.match('var5=extgb') ) {
- var sTyp = 'Gb';
- } else if ( window.location.href.match('var5=cpu') ) {
- var sTyp = 'Mhz';
- } else if ( window.location.href.match('var5=connection') ) {
- var sTyp = 'Mbit';
- }
-
- for (var i = 0; i < allTR.length; i++) {
- if ( found == true ) {
- var sTemp = allTR[i].innerHTML;
- regExp = /((\d+)|(\d+)\s(\d+))\.(\d+)\s(Gb|Mbit|Mhz)/gm;
- var iSize = parseFloat(sTemp.match(regExp)[0].replace(' ', '').replace(' ', '').replace(sTyp, ''));
- regExp = /((\d+)|(\d+)\s(\d+))\s(\d+)\seuros/gm;
- var iPrice = parseFloat(sTemp.match(regExp)[0].replace(' ', '').replace(' ', '').replace('euros', ''));
- var iPricePerSize = (iPrice/iSize).toFixed(2);
- allTR[i].innerHTML = allTR[i].innerHTML + '<td></td><td>' + iPricePerSize + '</td>';
- }
-
- if ( allTR[i].innerHTML == '<td><b>Name</b></td><td><b>Stock</b></td><td><b>Capacity</b></td><td width="10"></td><td align="right"><b>Price</b></td>' || allTR[i].innerHTML == '<td><b>Name</b></td><td><b>Stock</b></td><td><b>Speed</b></td><td width="10"></td><td align="right"><b>Price</b></td>' ) {
-
- allTR[i].innerHTML = allTR[i].innerHTML + '<td></td><td width="30"></td><td><b>€ / ' + sTyp + '</b></td>';
- found = true;
- }
- }
- }
-
- ////
- // Let us know if this is a VPC or NPC
- // Added links to next and previous npc
- // Added link to Next PotentialSlaves IP
- if (window.location.href.match(/page=internet/)) {
- var allInput = document.getElementsByTagName('input');
- var npcNum = '';
-
- var aPotTemp = GM_getValue('PotentialSlaves', '').split('|');
- var sPotTemp = '<font color="#000000" size="-2">PS: ';
-
- if ( aPotTemp.length >= 1 && aPotTemp[0] != '' ) {
- sPotTemp = sPotTemp + '<a href="http://www.slavehack.com/index2.php?page=internet&var2=' + ((aPotTemp.length > 0) ? aPotTemp[0] : '') + '">Next</a> ['+aPotTemp.length+']' + ((aPotTemp.length-numPotSlaves > 0) ? ' (+' + (aPotTemp.length-numPotSlaves) + ')' : '') + '</font>';
- } else {
- sPotTemp = sPotTemp + 'No more left :(</font>';
- }
-
- for (var i = 0; i < allInput.length; i++) {
- if (allInput[i].name == 'var2') {
- var isNPC = false;
- for (var j = 0; j < NPC_IP.length; j++) {
- isNPC = isNPC || (allInput[i].value == NPC_IP[j]);
- if ( isNPC && npcNum == '' ) {
- npcNum = j;
- }
- var ConnectedToIP = allInput[i].value;
- }
-
- // Remove entry form AllSlaveApps if there is no VPC running any more
- var regExp = /There is no webservice running at \<u\>(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- if ( document.body.innerHTML.match(regExp) != null ) {
- manageSlaves(ConnectedToIP, '', 'delete', 'files');
- }
-
- // Check if PW has been Cracked, if yes add ip to GM AllSlaves
- if ( document.body.innerHTML.match('You cracked and decrypted the password.') != null ) {
- manageSlaves(ConnectedToIP, '', 'update', 'slave');
- }
-
- // Check if Virus has been activated, if yes update GM AllSlaves
- if ( document.body.innerHTML.match('Virus install finished !') != null ) {
- var regExp = /(vspam|vddos|vshare)\s(\d{1}\.\d{1})/gm;
- var m = document.body.innerHTML.match(regExp);
-
- if ( m != null ) {
- var thisSlave = manageSlaves(ConnectedToIP, '', 'get', 'slave').split('#');
- var aTemp = m[0].split(' ');
- thisSlave[0] = ConnectedToIP;
- thisSlave[2] = ((aTemp[0] == 'vspam') ? m[0] : '<i>No Spam virus</i>');
- thisSlave[3] = ((aTemp[0] == 'vddos') ? m[0] : '<i>No DDoS virus</i>');
- thisSlave[4] = ((aTemp[0] == 'vshare') ? m[0] : '<i>No sharewarez virus</i>');
- thisSlave[5] = '';
- thisSlave[6] = '';
- thisSlave[7] = '';
- //thisSlave[5] = ((aTemp[0] == 'vspam' ) ? 'Spam relay ' : ((aTemp[0] == 'vddos' ) ? 'DDoS bot' : ((aTemp[0] == 'vshare' ) ? 'File Share' : 'N')));
-
- manageSlaves(ConnectedToIP, thisSlave, 'update', 'slave');
-
- //Move Virus App to Virus active
- manageSlaves(ConnectedToIP, new Array('app2vir', aTemp[0], aTemp[1]), 'update', 'files');
- }
- }
-
- var allh1 = document.getElementsByTagName('h1');
- var regExp = /\<img src=.?layout\/theinternet\.jpg.?\>/gm
-
- for (var i = 0; i < allh1.length; i++) {
- //if(allh1[i].innerHTML.search(regExp) >= 0 && allh1[i].innerHTML.search(regExp) < 50) {
- if(allh1[i].innerHTML == 'Internet') {
- var sVpcNpc = '';
- if (isNPC) {
- var nextNPC = '';
- var prevNPC = '';
- if (npcNum > 1) {
- prevNPC = ' - <a href="http://www.slavehack.com/index2.php?page=internet&var2='+NPC_IP[(npcNum-1)]+'"><<</a>';
- }
- if (npcNum < NPC_IP.length-1) {
- nextNPC = ' - <a href="http://www.slavehack.com/index2.php?page=internet&var2='+NPC_IP[(npcNum+1)]+'">>></a>';
- }
- sVpcNpc = "<font color=\"#000080\" size=\"-2\"><b>NPC " + npcNum + prevNPC + nextNPC + "</b></font>";
- } else {
- sVpcNpc = "<font color=\"#008000\" size=\"-2\"><b>VPC</b></font>";
- }
-
- // Display slave status in right Internet corner
- var isSlave = manageSlaves(ConnectedToIP, '', 'get', 'slave');
- sStatus = '<table cellspacing="0" cellpadding="0" border="0" align="right" style="font-family: Verdana; font-size: 10px; color: #000000;"><tr align="center">';
-
- if ( isSlave != '' ) {
- var aTemp = isSlave.split('#');
- //GM_log('is slave: ' + isSlave);
-
- if ( aTemp[1] > 0 ) {
- aTemp[1] = ((aTemp[4]=='S') ? ('<font style="background-color:#B5FFB3; font-weight: bold;">' + aTemp[1] + '</font>') : aTemp[1]);
- sStatus = sStatus + '<td width="30" style="border-right: 2px solid #333333;"><img border="0" src="' + aImages['vspam'] + '"><br>' + aTemp[1] + '</td>';
- }
-
- if ( aTemp[2] > 0 ) {
- aTemp[2] = ((aTemp[4]=='D') ? ('<font style="background-color:#B5FFB3; font-weight: bold;">' + aTemp[2] + '</font>') : aTemp[2]);
- sStatus = sStatus + '<td width="30" style="border-right: 2px solid #333333;"><img border="0" src="' + aImages['rddos'] + '"><br>' + aTemp[2] + '</td>';
- }
-
- if ( aTemp[3] > 0 ) {
- aTemp[3] = ((aTemp[4]=='W') ? ('<font style="background-color:#B5FFB3; font-weight: bold;">' + aTemp[3] + '</font>') : aTemp[3]);
- sStatus = sStatus + '<td width="30" style="border-right: 2px solid #333333;"><img border="0" src="' + aImages['fc'] + '"><br>' + aTemp[3] + '</td>';
- }
-
- // 0: IP, 1: MBIT, 2: Money/h, 3: apps, 4: viruses, 5: last update
- var SlaveApps = manageSlaves(ConnectedToIP, '', 'get', 'files');
-
- if ( SlaveApps != '' ) {
- var aTemp2 = SlaveApps.split('#');
-
- if ( aTemp2[1] != '' ) {
- sStatus = sStatus + '<td width="40" style="border-right: 2px solid #333333;"><b>MBit</b><br>' + aTemp2[1] + '</td>';
- }
-
- if ( aTemp2[2] != '' ) {
- sStatus = sStatus + '<td width="55" style="border-right: 2px solid #333333;"><b>euros/h</b><br>' + aTemp2[2] + '</td>';
- }
- }
-
- sStatus = sStatus + '<td width="90"><b>Slaved:</b><br>' + DisplayTimeDiff(SHTime-aTemp[5]) + '</td>';
- }
-
- sStatus = sStatus + '</tr></table>';
-
- var sTable = '<table cellspacing="0" cellpadding="3" border="0" width="600" style="background-color:#FFFFFF; color: #000000;"><tr><td width="5" rowspan="2"></td><td width="200">';
- sTable = sTable + sVpcNpc + '</td><td align="right" rowspan="2">' + sStatus + '</td></tr><tr><td>' + sPotTemp + '</td></table>';
-
- var thisTable = document.createElement('div');
- thisTable.innerHTML = sTable;
-
- allh1[i].parentNode.insertBefore(thisTable, allh1[i].nextSibling);
- break;
- }
- }
- }
- }
- }
-
- ////
- // LOGFILE
- // Remove any line with our IP from foreign log files.
- // Autosubmit if we removed our IP
- // Scan for unknown IPs in the logfile
- // Buggy: Remove text over log file <form> disappear mysteriously
- // Replace Textarea with a DIV for better Highlighting
- // Added Clear logfile button
- if ((window.location.href.indexOf('var3=log') >= 0) || (window.location.href.indexOf('page=logs') >= 0) || (window.location.href.match(/page=internet$/))) {
- var MyIPInLog = false;
-
- // Remove text over logfile
- var allDIV = document.getElementsByTagName('div');
- for (var i = 0; i < allDIV.length; i++) {
- //GM_log(allDIV[i].innerHTML);
- if ( allDIV[i].innerHTML.match('<h1>Log file</h1>') ) {
- allDIV[i].innerHTML = allDIV[i].innerHTML.replace(/\<h1\>Log\sfile\<\/h1\>(.*?)The\slogfile\scan\snot\sexceed\s1\sGb\.\<br\>/gm, '<h1>Log file</h1>');
- }
- }
-
- // Search Textarea
- var allTextareas = document.getElementsByTagName('textarea');
- for (var i = 0; i < allTextareas.length; i++) {
- var thisTextarea = allTextareas[i];
- if (thisTextarea.rows > 1) {
- thisTextarea.rows = 15;
- var sTemp = thisTextarea.value;
-
- MyIPInLog = MyIPInLog || (thisTextarea.value.indexOf(MyIP) >= 0);
- thisTextarea.value = thisTextarea.value.replace(new RegExp( "^.*"+MyIP+".*(\n|$)", "gm" ) ,"");
-
- // This fixes the bug where \ becomes \\ and counts against you in edit time.
- thisTextarea.value.replace(/\\\\/g, "\\");
-
-
- // Check for unknown IPs
- ParseLog(thisTextarea.value, 'collect');
-
- // Add Clear Log beside Edit Log
- var allInput = document.getElementsByTagName('input');
- for (var j = 0; j < allInput.length; j++) {
- if ( allInput[j].type == 'submit' && allInput[j].value == ' Edit logfile ' ) {
- //GM_log(allInput[j].type);
- var clearLog = document.createElement('input');
- clearLog.type = 'button';
- clearLog.value = ' Clear logfile ';
-
- clearLog.addEventListener('click', function(event) {
- thisTextarea.value = '';
-
- var allForms = document.getElementsByTagName('form');
- for (var i = 0; i < allForms.length; i++) {
- if ((allForms[i].method=='post') && (allForms[i].style[0]!="visibility")) {
- allForms[i].submit();
- }
- }
-
-
- }, true);
-
- allInput[j].parentNode.insertBefore(clearLog, allInput[j].nextSibling);
- }
- }
-
- if (MyIPInLog) {
- var Message = document.createElement('div');
- Message.innerHTML = '<div style="font-size: large; color: #ff0000;">Own IP removed, submit changes.</div>';
- thisTextarea.parentNode.insertBefore(Message, thisTextarea.nextSibling);
- if ( aSettings['submit'] == 1 ) {
- var allForms = document.getElementsByTagName('form');
- for (var i = 0; i < allForms.length; i++) {
- if ((allForms[i].method=='post') && (allForms[i].style[0]!="visibility")) {
- allForms[i].submit();
- }
- }
- }
- }
-
- if (!MyIPInLog || (MyIPInLog && aSettings['submit'] == 0) || (MyIPInLog && aSettings['submit'] == 0) ) {
-
- // Replace Textarea with a DIV and add color highlighting
- var replaceDiv = document.createElement('div');
- var regExp = /-*?\n/gm;
- var regExp2 = /\s{2}/gm;
- var aText = ParseLog(sTemp.replace(regExp, '<br>'), 'highlight').replace(regExp2, '<br>').split('<br>');
- thisTextarea.id = thisTextarea.name;
-
- var sStyle = '<style type="text/css">#dl { border-right: 2px solid #333333; padding-left: 3px; width: 20px; font-weight: bold; } #dr { padding-left: 3px; } #tr { text-align:left; vertical-align:top; }</style>';
- var sTable = sStyle + '<table align="left" cellpadding="0" border="0" cellspacing="0" style="color: #000000; font-size: 11px; font-family: Courier New, Andale Mono, Courier; width: 704;"><tr><td colspan="2"><div style="background-color: #FFFFFF; position: absolute; border-bottom: 2px solid #333333; width: 704;"><table width="100%" cellpadding="0" border="0" cellspacing="0" style="color: #000000; font-size: 11px; font-family: Courier New, Andale Mono, Courier; width: 704;"><tr><td id="dl">Nr</td><td id="dr" width="80" height="20"><b>Text</b></td><td align="right"><a href="javascript:switchDisplay();" style="font-weight:bold;">Switch to write mode</a></td></tr></table></div></td></tr><tr><td colspan="2" height="22"> </td></tr>';
-
- for (var j = 0; j < aText.length; j++) {
- if ( aText[j].indexOf(MyIP) >= 0 ) {
- aText[j] = '<font style="background-color: purple;" color="#FFFFFF"><i>' + aText[j] + '</i></font>';
- }
- sTable = sTable + '<tr id="tr"><td id="dl">' + (j+1) + '</td><td id="dr">' + aText[j] + '</td>';
- }
-
- sTable = sTable + '<tr><td id="dl" height="100%"></td><td></td></tr></table>';
-
- replaceDiv.innerHTML = sTable;
- replaceDiv.id = 'logedt_div';
- replaceDiv.style.width = 720;
- replaceDiv.style.height = 234;
- replaceDiv.style.background = '#FFFFFF';
- replaceDiv.style.overflow = 'auto';
-
-
- thisTextarea.style.display = 'none';
- thisTextarea.parentNode.insertBefore(replaceDiv, thisTextarea.nextSibling);
-
- var script = document.createElement('script');
- script.type="text/javascript";
- script.innerHTML = 'function switchDisplay() { document.getElementsByName("editlog")[0].style.display="block"; document.getElementById("logedt_div").style.display="none"; }';
- document.getElementsByTagName("head")[0].appendChild(script);
- }
- }
- }
- }
-
- ////
- // Sort slave list
- // Save and restore last selected account
- // Mark NPCs.
- // http://www.slavehack.com/index2.php?page=slaves&slave=all&collect=1
- if (window.location.href.match('page=slaves') && !window.location.href.match('ddos=1')) {
-
- // Calculate Money per hour
- if ( document.body.innerHTML.match('Collecting from all slaves....') ) {
- sSlaveIncome = document.body.innerHTML;
- var allTD = sSlaveIncome.split('<td>');
- for (var j = 0; j < allTD.length; j++) {
- if ( allTD[j].match('Collecting from all slaves') ) {
- var aSlaves = allTD[j].split('<hr>');
- for (var i = 1; i < (aSlaves.length-1); i++) {
- var thisSlave = aSlaves[i];
-
- var sTime = thisSlave.match(/\d+:\d{1,2}/gm)[0];
- if ( sTime != '0:0' ) {
-
- var aTime = sTime.split(':');
- var sIp = thisSlave.match(/(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm)[0];
-
- if ( thisSlave.indexOf('times sold') >= 0 ) {
- var sMoney = thisSlave.match(/Income:\s(\d+\.\d{1,2}|\d+)/gm)[0].split(' ')[1];
- } else {
- var sMoney = thisSlave.match(/(\d+\.\d{1,2}|\d+)\seuros/gm)[0].split(' ')[0];
- }
-
- var sMin = parseInt(aTime[1]);
- var sHour = parseInt(aTime[0]);
- while (sHour > 0) {
- sMin = sMin + 60;
- sHour = sHour - 1;
- }
-
- //var sMoneyPerHour = Math.floor((sMoney*60)/sMin);
- var sMoneyPerHour = Math.round((sMoney*60)/sMin);
- //var sMoneyPerHour = ((sMoney*60)/sMin).toFixed(2);
- //GM_log('>> ip: ' + sIp + ' | time: ' + aTime.join(':') + ' | money: ' + sMoney + ' | mph: ' + sMoneyPerHour);
-
- // 0: IP, 1: MBIT, 2: Money/h, 3: apps, 4: viruses, 5: last update , 6: GS-Name
- manageSlaves(sIp, new Array(sIp, '', sMoneyPerHour, '', '', '', ''), 'update', 'files');
- }
- }
- }
- }
- } else {
-
- // Remove entrys from GM AllSlaves and AllSlaveApps if deleted from slave list
-
- // Provide "crack" link in <font color=red>The slave 7.5.7.89 was removed from your list because you no longer have the admin password anymore and no virus is active.</font>
- // Mark NPCs in the same line
- var LastConnectedIP = GM_getValue('LastConnectedIP', '');
- var aAllSlaves = GM_getValue('AllSlaves', '').split('|');
- var allFont = document.getElementsByTagName('font');
- var sTemp = '';
- var aDeleted = new Array();
- for (var i = 0; i < allFont.length; i++) {
- if (allFont[i].innerHTML.indexOf('was removed from your list') >= 0) {
- var isNPC = false;
- var numNpc = '';
- for (var j = 0; j < NPC_IP.length; j++) {
- isNPC = isNPC || (allFont[i].innerHTML.indexOf(NPC_IP[j]) >= 0);
- if ( isNPC && numNpc == '' ) {
- numNpc = j;
- }
- }
-
- // Remove Slave from GM AllSlaves
- var regExp = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- var delIP = allFont[i].innerHTML.match(regExp)[0];
- aDeleted[aDeleted.length] = delIP;
- manageSlaves(delIP, '', 'delete', 'slave');
-
- var sSlaveApps = manageSlaves(delIP, '', 'get', 'files');
- var sStats = '';
- if ( sSlaveApps != '' ) {
- var aSlaveApps = sSlaveApps.split('#');
-
- sStats = sStats + ((aSlaveApps[1] != '') ? ('MBit: ' + aSlaveApps[1]) : '');
- sStats = sStats + ((sStats != '' && aSlaveApps[2] != '') ? ' | ' : '');
- sStats = sStats + ((aSlaveApps[2] != '') ? ('€/h: ' + aSlaveApps[2]) : '');
-
- if ( sStats != '' ) {
- sStats = ' [' + sStats + ']';
- }
- }
-
- var re = / (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- allFont[i].innerHTML = allFont[i].innerHTML.replace(re, " <a href=\"http://www.slavehack.com/index2.php?page=internet&var2=$1&var3=crack&var4=\">$1" + ((isNPC) ? ' [NPC '+numNpc+']' : '') + sStats + "</a>");
-
- if (isNPC) {
- allFont[i].innerHTML = "<font color='#FF33FF'>"+allFont[i].innerHTML+"</font>";
- } else {
- // If VPC is removed from our slave list, readd the ip to the potential slaves list
- var regExp = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- var m = allFont[i].innerHTML.match(regExp);
-
- if ( m != null ) {
- if (sTemp != '') {
- sTemp = sTemp + ' - ';
- }
- sTemp = sTemp + m[0];
- }
- }
- }
- }
-
- if (sTemp != '') { // The above readd is actually here
- ParseLog(sTemp, 'collect');
- }
-
- if (window.location.href.indexOf('collect=1') >= 0) {
- // Restore last selected account
- var allSelect = document.getElementsByTagName('select');
- for (var i = 0; i < allSelect.length; i++) {
- if (allSelect[i].name=='account') {
- allSelect[i].selectedIndex = GM_getValue("LastCollectAccount", 1);
- }
- }
-
- // Save last selected account
- function SaveAccount() {
- var allSelect = document.getElementsByTagName('select');
- for (var i = 0; i < allSelect.length; i++) {
- if (allSelect[i].name=='account') {
- GM_setValue("LastCollectAccount", allSelect[i].selectedIndex);
- GM_setValue("LastCollectTime", SHTime);
- }
- }
- }
- window.addEventListener('submit', SaveAccount, true);
- }
-
- // Sort slave list
- var allTR = document.getElementsByTagName('tr');
- var MySlaves = new Array(); // [row#][0=IP, 1=Password, 2=SpamVir, 3=DDoSVir, 4=WarezVir, 5=Task, 6=TimeWorked]
- var SlaveTable;
- var LastSort = '<b>IP</b>';
- var aGSnames = new Array();
- for (var i = 0; i < allTR.length; i++) {
- var thisTR = allTR[i];
- // Rewrite slave list header to show individual virus types
- if (thisTR.innerHTML == '<td><b>IP</b></td><td><b>Password</b></td><td><b>Virusses</b></td><td></td><td></td><td><b>Task</b></td><td><b>Time worked</b></td>') {
- thisTR.innerHTML = '<td><b>IP</b></td><td><b>Password</b></td><td><b>Spam Virus</b></td><td><b>DDoS Virus</b></td><td><b>Warez Virus</b></td><td><b>Task</b></td><td><b>Time worked</b></td>';
- }
-
- // Parse slave table into an array
- // Trim unnecessary text
- // Also, parse IPs into a string for the data URI
- if ( (thisTR.innerHTML.indexOf('delete') >= 0) && (thisTR.innerHTML.indexOf('Time worked') < 0) ) {
- var ThisSlave = new Array();
- ThisSlave[0] = thisTR.childNodes[0].innerHTML;
- ThisSlave[1] = thisTR.childNodes[1].innerHTML;
- ThisSlave[2] = thisTR.childNodes[2].innerHTML;
- ThisSlave[3] = thisTR.childNodes[3].innerHTML;
- ThisSlave[4] = thisTR.childNodes[4].innerHTML;
- ThisSlave[5] = thisTR.childNodes[5].innerHTML;
- ThisSlave[6] = thisTR.childNodes[6].innerHTML;
- ThisSlave[7] = thisTR.childNodes[7].innerHTML;
-
- // Update GM AllSlaves
- var regExp = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- var thisIP = ThisSlave[0].match(regExp)[0]
- var check = 0;
- for ( var k=0; k < aDeleted.length; k++ ) { // To make sure these slaves stay deleted
- if ( thisIP == aDeleted[k] ) {
- check = 1;
- }
- }
-
- if ( check == 0 ) {
- manageSlaves(thisIP, ThisSlave, 'update', 'slave');
- }
-
- // Add €/h and MBit
- var sSlaveApps = manageSlaves(thisIP, '', 'get', 'files');
- if ( sSlaveApps != '' ) {
- //GM_log(sSlaveApps);
- var aSlaveApps = sSlaveApps.split('#');
- ThisSlave[8] = ((aSlaveApps[1] != '') ? aSlaveApps[1] : ' ');
- ThisSlave[9] = ((aSlaveApps[2] != '') ? aSlaveApps[2] : ' ');
-
- // If the server is a GS save the name for later use into aGSnames array
- if ( typeof aSlaveApps[6] != 'undefined' && aSlaveApps[6] != '' ) {
- aGSnames[aSlaveApps[0]] = aSlaveApps[6];
- }
- } else {
- ThisSlave[8] = ' ';
- ThisSlave[9] = ' ';
- }
-
- // Mark NPCs.
- for (var j = 0; j < NPC_IP.length; j++) {
- if (ThisSlave[0].indexOf(NPC_IP[j]) >= 0) {
- //ThisSlave[0] = "<i><b>"+ThisSlave[0]+"</b></i>";
- ThisSlave[0] = "<a href='index2.php?page=internet&var2="+NPC_IP[j]+"'><font color='#FF33FF'>"+NPC_IP[j]+"</font></a>";
- ThisSlave[1] = "NPC " + j;
- if (j < 100) { ThisSlave[1] = "NPC 0" + j; }
- if (j < 10) { ThisSlave[1] = "NPC 00" + j;}
- }
- }
-
- if (thisTR.childNodes[1].innerHTML == "<i>Password unknown</i>") {
- ThisSlave[1] = "<i>Unknown</i>";
- }
-
- // Remove " virus" from virus names link.
- ThisSlave[2]=ThisSlave[2].replace(' virus', '');
- ThisSlave[3]=ThisSlave[3].replace(' virus', '');
- ThisSlave[4]=ThisSlave[4].replace(' virus', '');
- // Remove " profit" from "Collect profit" link.
- ThisSlave[6]=ThisSlave[6].replace(' profit', '');
-
- MySlaves[MySlaves.length] = ThisSlave;
- //GM_log(MySlaves[MySlaves.length-1].join('-'));
-
- // Only need this once, but no harm resetting it each time.
- SlaveTable = thisTR.parentNode;
- }
- }
-
- function sortSlaves(str) {
- var disp = false;
- var aStr = GM_getValue("LastSort", "<b>IP</b>|asc").split('|');
- var inc = 0;
-
- if (str == '') {
- str = aStr[0];
- inc = 1;
- }
-
- function stripHTMLcompare(a,b) {
- var re = /(<([^>]+)>)/ig;
- var a1 = a.replace(re,"");
- var b1 = b.replace(re,"");
-
- return ((a1 < b1) ? -1 : ((a1 > b1) ? 1 : 0));
- }
-
- function stripINTcompare(a,b) {
- var a1 = parseInt(a);
- var b1 = parseInt(b);
-
- if (isNaN(a1)) { a1 = 0; };
- if (isNaN(b1)) { b1 = 0; };
-
- return ((a1 < b1) ? -1 : ((a1 > b1) ? 1 : 0));
- }
-
- // If one of the table headers was clicked, sort by it.
- if (str == '<b>IP</b>') {
- MySlaves.sort(function(a,b) { return stripHTMLcompare(a[0], b[0]); });
- disp = true;
- }
- if (str == '<b>Password</b>') { // No idea why anyone would, but for completeness
- MySlaves.sort(function(a,b) { return ((a[1] < b[1]) ? -1 : ((a[1] > b[1]) ? 1 : stripHTMLcompare(a[0], b[0]))); });
- disp = true;
- }
- if (str == '<b>Spam</b>') {
- MySlaves.sort(function(a,b) { return (stripHTMLcompare(a[2], b[2])==0)?stripHTMLcompare(a[0], b[0]):stripHTMLcompare(a[2], b[2]); });
- disp = true;
- }
- if (str == '<b>DDoS</b>') {
- MySlaves.sort(function(a,b) { return (stripHTMLcompare(a[3], b[3])==0)?stripHTMLcompare(a[0], b[0]):stripHTMLcompare(a[3], b[3]); });
- disp = true;
- }
- if (str == '<b>Warez</b>') {
- MySlaves.sort(function(a,b) { return (stripHTMLcompare(a[4], b[4])==0)?stripHTMLcompare(a[0], b[0]):stripHTMLcompare(a[4], b[4]); });
- disp = true;
- }
- if (str == '<b>Task</b>') {
- MySlaves.sort(function(a,b) { return ((a[5] < b[5]) ? -1 : ((a[5] > b[5]) ? 1 : stripHTMLcompare(a[0], b[0]))); });
- disp = true;
- }
- if (str == '<b>Time worked</b>') {
- MySlaves.sort(function(a,b) { return (stripHTMLcompare(a[6], b[6])==0)?stripINTcompare(b[8], a[8]):stripHTMLcompare(a[6], b[6]); });
- disp = true;
- }
- if (str == '<b>MBit</b>') {
- MySlaves.sort(function(a,b) { return stripINTcompare(a[8], b[8]); });
- disp = true;
- }
- if (str == '<b>euros/h</b>') {
- MySlaves.sort(function(a,b) { return stripINTcompare(a[9], b[9]); });
- disp = true;
- }
-
- // Output the sorted table
- if (disp) {
- // Clicking the same sort column twice reverses the sort order.
- //GM_log(str + ' | ' + aStr[0] + ' - ' + aStr[1]);
- if ( (inc == 1 && aStr[1] == 'asc') || (inc == 0 && str == aStr[0] && aStr[1] == 'desc') || (inc == 0 && str != aStr[0]) ) {
- aStr[1] = 'asc';
- if ( str != '<b>Time worked</b>' ) {
- MySlaves.reverse();
- }
- } else {
- aStr[1] = 'desc';
- if ( str == '<b>Time worked</b>' ) {
- MySlaves.reverse();
- }
- }
-
- if ( inc == 0 ) {
- GM_setValue("LastSort", str + '|' + aStr[1]); // Save sort method for when we return.
- }
-
- // Actual creation of the new table.
- // Added 2 new Collums -> MBit and €/h
- var newTable = '<tr><td><b>#</b></td><td><b>IP</b></td><td><b>Password</b></td><td align="center"><b>Spam</b></td><td><b align="center">DDoS</b></td><td align="center"><b>Warez</b></td><td align="center"><b>Task</b></td><td align="center"><b>Time worked</b></td><td> </td><td align="center"><b>MBit</b></td><td align="center"><b>euros/h</b></td><td align="center"><b>Info (A/V)</b></td></tr>';
-
- var regExp = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- for (var i=0; i<MySlaves.length; i++) {
- var bgColor = '#444444';
- if (i%2) {
- bgColor = '#222222';
- }
-
- if ( MySlaves[i][0].match(LastConnectedIP) ) {
- bgColor = '#BBC4FF';
- }
-
- newTable = newTable + '<tr bgcolor=' + bgColor + '>';
-
- newTable = newTable + '<td><b>' + (i+1) + '.</b></td>';
-
- var GSname = '';
- var thisIP = '';
- for (var j=0; j<(MySlaves[i].length+1); j++) {
-
- //aGSnames['143.12.245.243']
- if ( j == 0 ) {
- var aIp = MySlaves[i][0].match(regExp);
- if ( aIp != null) {
- thisIP = aIp[0];
- if ( typeof aGSnames[aIp[0]] != 'undefined' ) {
- GSname = '<b>' + aGSnames[aIp[0]] + '</b>';
- }
- }
- }
-
- if ( j == 0 && GSname != '' ) {
- newTable = newTable + '<td>' + MySlaves[i][j] + ' ' + GSname + '</td>';
-
- } else if ( j == 2 ) {
- if ( MySlaves[i][j] == '<i>No spam</i>' ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('No spam', '<i><small>None</small></i>') + '</td>';
- } else {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('Spam', '<img border="0" src="' + aImages['vspam'] + '">') + '</td>';
- }
-
- } else if ( j == 3 ) {
- if ( MySlaves[i][j] == '<i>No DDoS</i>' ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('No DDoS', '<i><small>None</small></i>') + '</td>';
- } else {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('DDoS', '<img border="0" src="' + aImages['rddos'] + '">') + '</td>';
- }
-
- } else if ( j == 4 ) {
- if ( MySlaves[i][j] == '<i>No sharewarez</i>' ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('No sharewarez', '<i><small>None</small></i>') + '</td>';
- } else {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('ShareWarez', '<img border="0" src="' + aImages['fc'] + '">') + '</td>';
- }
-
- } else if ( j == 5 ) {
- if ( MySlaves[i][j] == 'Spam relay ' ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('Spam relay ', '<img border="0" src="' + aImages['vspam'] + '">') + '</td>';
- } else if ( MySlaves[i][j] == 'File Share' ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('File Share', '<img border="0" src="' + aImages['fc'] + '">') + '</td>';
- } else if ( MySlaves[i][j] == 'DDoS bot' ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('DDoS bot', '<img border="0" src="' + aImages['rddos'] + '">') + '</td>';
- } else {
- newTable = newTable + '<td align="center">' + MySlaves[i][j].replace('No task assigned', 'None') + '</td>';
-
- }
-
- } else if ( j == 6 || j == 8 || j == 9 ) {
- newTable = newTable + '<td align="center">' + MySlaves[i][j] + '</td>';
-
- } else if ( j == 10 ) {
- if ( MySlaves[i][8] != ' ' ) {
- var sThisSlaveApps = manageSlaves(thisIP, '', 'get', 'files');
- var sThisSlave = manageSlaves(thisIP, '', 'get', 'slave');
- if ( sThisSlaveApps != '' ) {
- var aThisSlaveApps = sThisSlaveApps.split('#');
- if ( aThisSlaveApps[5] != '' && typeof aThisSlaveApps[5] != 'undefined' ) {
- aThisSlaveApps[5] = DisplayTimeDiff(SHTime-aThisSlaveApps[5]) + ' ago';
- }
-
- newTable = newTable + '<td align="center"><font onMouseOver="Tip(generateTooltip(\'' + sThisSlave + '\', \'' + aThisSlaveApps.join('#') + '\'));" onMouseOut="UnTip()"><b>Show</b> <small>(' + ((aThisSlaveApps[3] != '') ? aThisSlaveApps[3].split('@').length : '0') + '/' + ((aThisSlaveApps[4] != '') ? aThisSlaveApps[4].split('@').length : '0') + ')</small></font></td>';
- } else {
- newTable = newTable + '<td> </td>';
- }
- } else {
- newTable = newTable + '<td> </td>';
- }
- } else {
- newTable = newTable + '<td>' + MySlaves[i][j] + '</td>';
- }
- }
- newTable = newTable + '</tr>\n';
- }
- SlaveTable.innerHTML = newTable;
- }
- }
-
- // Sort by last sort, (and add #)
- sortSlaves('');
-
- // Catch clicks, to allow user to sort.
- document.addEventListener('click', function(event) {
- sortSlaves(event.target.parentNode.innerHTML)
- }, true);
- }
- }
-
- ////
- // PROZESS
- // Sort process list by IP
- // Make IPs in process list clickable
- // Change auto-submit to refresh process list instead.
- // Hilight processes for current IP on process list
- // Add count to process list
- if (window.location.href.indexOf('page=processes') >= 0) {
- var allTR = document.getElementsByTagName('tr');
- var MyProcs = new Array();
- var ProcHeaders = new Array();
- var ProcHeader = 0;
- var ProcTable;
-
- var reFindCurrIP = /Currently connected to (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})\./;
- var CurrIP = '0.0.0.0';
- if (document.body.innerHTML.match(reFindCurrIP)) {
- CurrIP = reFindCurrIP.exec(document.body.innerHTML)[1];
- }
-
- // Parse process list into an array
- for (var i = 0; i < allTR.length; i++) {
- var thisTR = allTR[i];
- // Rewrite slave list header to show individual virus types
- if (thisTR.innerHTML.match(/^<td><img src\=\"layout\/processicon\.jpg\"> <b>.* processes<\/b><\/td>/)) {
- ProcHeader += 1;
- ProcHeaders[ProcHeader] = thisTR.innerHTML;
- MyProcs[ProcHeader] = new Array();
- ProcTable = thisTR.parentNode; // Only need it once, but no harm setting it repeatedly if more than one process type.
- } else if (ProcHeader > 0) {
- //var re = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/m;
- var re = /Kill\sprocess/m;
- if (thisTR.innerHTML.match(re))
- { MyProcs[ProcHeader][MyProcs[ProcHeader].length] = thisTR.innerHTML; }
- }
- }
-
- // Sort process lists
- for ( var i = 1; i < MyProcs.length; i++) {
- function FindAndCompareIPs(a,b) {
- var re = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/m;
- if (a.match(re)) {
- var match = re.exec(a);
- a1 = match[0];
- } else { a1=a; }
- if (b.match(re)) {
- var match = re.exec(b);
- b1 = match[0];
- } else { b1=b; }
- if ((a1 == b1) && (a.indexOf('has been finished') >= 0)) {
- return -1;
- }
- if ((a1 == b1) && (b.indexOf('has been finished') >= 0)) {
- return 1;
- }
- return ((a1 < b1) ? -1 : ((a1 > b1) ? 1 : 0));
- }
- MyProcs[i].sort(FindAndCompareIPs);
- }
-
- // Output process list
- var outHTML = '';
- ct = 0;
- for ( var i = 1; i < MyProcs.length; i++) {
- outHTML = outHTML + '<tr height=2><td></td><td><img src="layout/pixel.gif"></td></tr>';
- outHTML = outHTML + "<tr bgcolor=#333333 valign=middle>" + ProcHeaders[i] + "</tr>\n";
- var LastIP = '';
- for ( var j = 0; j < MyProcs[i].length; j++) {
-
- if (j>0) { outHTML = outHTML + '<tr height=2><td></td><td><img src="layout/pixel.gif"></td></tr>'; }
- ct = ct+1;
- var re = /(\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/m;
- if (MyProcs[i][j].match(re)) {
- var matches = re.exec(MyProcs[i][j]);
- if (!(matches[0] == LastIP)) {
- if (!(LastIP == '')) {
- outHTML = outHTML + "<tr><td></td></tr>\n";
- }
- LastIP = matches[0];
- }
- }
- MyProcs[i][j] = MyProcs[i][j].replace("<td><small>", "<td>"+ct+".<br><small>");
- MyProcs[i][j] = MyProcs[i][j].replace("<br><br>", "");
- outHTML = outHTML + "<tr bgcolor=#222222 valign=top>" + MyProcs[i][j] + "</tr>\n";
-
- }
- }
- // http://www.slavehack.com/index2.php?gow=58.37.107.87&page=internet
- // Convert IPs into links
- var re = / (\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3})/gm;
- outHTML = outHTML.replace(re, " <a href=\"http://www.slavehack.com/index2.php?page=internet&var2=$1\">$1</a>");
-
- // Highlight current IP with yellow background
- var prevHTML = '';
- while (!(prevHTML == outHTML)) {
- prevHTML = outHTML;
- outHTML = outHTML.replace('?page=internet&var2='+CurrIP+'\">'+CurrIP+'</a>', '?page=internet&var2='+CurrIP+'\" style=\"background-color:yellow\"><b>'+CurrIP+'</b></a>');
- }
-
- // Highlight own IP with white background
- var prevHTML = '';
- while (!(prevHTML == outHTML)) {
- prevHTML = outHTML;
- outHTML = outHTML.replace('?page=internet&var2='+MyIP+'\">'+MyIP+'</a>', '?page=internet&var2='+MyIP+'\" style=\"background-color:white\"><b>'+MyIP+'</b></a>');
- }
-
- if (ProcHeader > 0)
- { ProcTable.innerHTML = outHTML; }
- }
-
- ////
- // Always show password textbox, and never * it out.
- if (window.location.href.match('var3=login')) {
- var allForm = document.getElementsByTagName('form');
- for (var i = 0; i < allForm.length; i++) {
- var thisForm = allForm[i];
- // <td>Username</td><td>Admin</td></tr><tr><td>Password</td><td> ???</td>
- if (thisForm.innerHTML.match('<td>Username</td><td>Admin</td>')) {
- thisForm.innerHTML = thisForm.innerHTML.replace("???", "<input name=loginpass type=text><tr><td><td><input type=submit value=login>");
- }
- }
- allForm = document.getElementsByTagName('input');
- for ( var i = 0; i < allForm.length; i++) {
- var thisForm = allForm[i];
- if (thisForm.type=="password") {
- thisForm.type="text";
- }
- }
- }
-
- ////
- // OWN FILES/SOFTWRE
- // Add up file sizes
- // Change actual time to time diff
- // Hide hide link for files we can't hide further
- if ( window.location.href.match(/page=software$/) ) {
- var allTR = document.getElementsByTagName('tr');
- var MySoft = new Array();
- var SpaceUsed = 0;
- var AllSoft = '';
-
- // Find our hider level
- var allSmall = document.getElementsByTagName('small');
- var HiderLevel = 0;
- var maxUploadSpeed = 0;
- for (var i = 0; i < allSmall.length; i++) {
- if (allSmall[i].innerHTML.substr(0,43) == "Your hide software can hide files to level ") {
- HiderLevel = allSmall[i].innerHTML.substr(43);
- HiderLevel = parseFloat(HiderLevel.substr(0,HiderLevel.length-1));
- }
- }
-
- // Find highest seeker.
- var HighSeeker = 0;
- for (var i = 0; i < allTR.length; i++) {
- if (allTR[i].innerHTML.substr(0,22) == "<td bgcolor=\"#000000\">") {
- var allTD = allTR[i].innerHTML.split('</td>');
- if (allTD[1].indexOf('.skr') >= 0) {
- HighSeeker = (HighSeeker > parseFloat(allTD[2].substr(4)))?HighSeeker:parseFloat(allTD[2].substr(4));
- }
- }
- }
-
- // Parse software list into an array
- for (var i = 0; i < allTR.length; i++) {
- var thisTR = allTR[i];
- if (thisTR.innerHTML.substr(0,22) == "<td bgcolor=\"#000000\">") {
- var allTD = thisTR.innerHTML.split("</td>");
- // Active viruses are not actually available
- if (!(allTD[0] == "<td bgcolor=\"#000000\"><img src=\"layout/activevspam.jpg\" border=\"0\">")) {
- // Keep track of all software
- if (AllSoft == '') {
- AllSoft = AllSoft + allTD[1].replace("<td> ","") + " " + allTD[2].replace("<td>","");
- } else {
- AllSoft = AllSoft + "|" + allTD[1].replace("<td> ","") + " " + allTD[2].replace("<td>","");
- }
- }
- // Display time diff instead of time
- allTD[4] = '<td><a title="'+allTD[4].substr(4)+'">' + DisplayTimeDiff(SHTime-ParseTime(allTD[4])) + ' ago</a>';
-
- // Calc size
- var ThisSize = allTD[3].replace("<td>","");
- var reGB = /GB/i;
- ThisSize=ThisSize.replace(" ","");
- if (ThisSize.match(reGB)) { // GB
- ThisSize = parseFloat(ThisSize);
- ThisSize = ThisSize * 1024; // 1GB = 1024MB
- } else { // MB
- ThisSize = parseFloat(ThisSize);
- }
-
- SpaceUsed = SpaceUsed + ThisSize;
- SpaceUsed = Math.round(SpaceUsed*1000000)/1000000;
-
- // Hide hide link if applicable
- if (parseFloat(allTD[6].substr(40)) >= HiderLevel ) {
- allTD[6] = allTD[6].replace("<img src=\"layout/hide.jpg\" border=\"0\">",'');
- }
-
- // Remove hide level 0.0
- allTD[6] = allTD[6].replace('0.0',' ');
-
- // Replace file line
- allTR[i].innerHTML = allTD.join('</td>');
- }
- }
-
- GM_setValue("AllSoft", AllSoft);
-
- // Add Visible Space Used
- if (SpaceUsed < 1024) {
- SpaceUsed = SpaceUsed + " mb";
- } else {
- SpaceUsed = (SpaceUsed/1024) + " gb";
- }
-
- textnodes = document.evaluate(
- "//text()",
- document,
- null,
- XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,
- null);
- for (var i = 0; i < textnodes.snapshotLength; i++) {
- node = textnodes.snapshotItem(i);
- if (node.data.indexOf("Total space:") >= 0) {
- TotalSpace = node.data.substr((node.data.indexOf("Total space: ")+13),
- (node.data.indexOf(" gb.") - (node.data.indexOf("Total space:")+13)));
- // GM_log(node.data + " :: (" + TotalSpace+")");
- // TODO: convert total space to # DDOSes required to 555
- }
- if (node.data.indexOf("Free:") >= 0) {
- newElement = document.createElement('div');
- newElement.innerHTML = "\t\tVisible Used: " + SpaceUsed + ".<br>\n";
- node.parentNode.insertBefore(newElement, node);
- }
- }
- }
-
- // SLAVE FILES/SOFTWRE
- // Remove download links for active viruses, and for software we already have.
- // Remove delete links for active viruses
- // Display time diff since edit instead of time
- // Add upload file box
- // Hide hide link for files we can't hide further
- // Show Uploadtime for every file in upload Form
- if (window.location.href.indexOf('var3=files') >= 0) {
-
- // Set LastConnectedIP
- GM_setValue('LastConnectedIP', ConnectedToIP);
-
- ////
- // Get highest app version, compared to slaves one
- function getHighestAppVersion(toCheck) {
- var MySoft = GM_getValue("AllSoft", "").split('|');
- var version = 'NA';
- var aTyp = toCheck.split('.');
- //GM_log(toCheck);
- if (aTyp[1] == 'img' || aTyp[1] == 'txt' || aTyp[1] == 'exe' || toCheck.substr(0,6) == '<td><a') {
- return '';
- } else {
- for (var j = 0; j < MySoft.length; j++) {
- var aTemp = MySoft[j].split(' ');
- if ( MySoft[j] != '' ) {
- var ver = aTemp[(aTemp.length)-1]
- //GM_log(MySoft[j]);
- var aMyTyp = aTemp[(aTemp.length)-2].split('.');
- if (aTyp[1] == aMyTyp[1] && (version == 'NA' || ver > version) ) { version = ver; }
- }
- }
-
- // Trim X.0 Versions to X
- if ( version.length > 1 ) {
- aTemp = version.split('.');
- if ( aTemp[1] == 0 ) { version = aTemp[0]; }
- }
- return version;
- }
- }
-
- // Find our hider level
- var allSmall = document.getElementsByTagName('small');
- var HiderLevel = 0;
- var maxUploadSpeed = 0;
- var aApps = '';
- var aViruses = '';
- var GSname = '';
- for (var i = 0; i < allSmall.length; i++) {
- if (allSmall[i].innerHTML.substr(0,43) == "Your hide software can hide files to level ") {
- HiderLevel = allSmall[i].innerHTML.substr(43);
- HiderLevel = parseFloat(HiderLevel.substr(0,HiderLevel.length-1));
- }
-
- // Get max file upload speed
- searchString = 'You can upload files with a speed of ';
- var pos = allSmall[i].innerHTML.indexOf(searchString);
- if (pos >= 0) {
- maxUploadSpeed = allSmall[i].innerHTML.substr(searchString.length, 20).split(' ')[0];
- }
-
- var pos = allSmall[i].innerHTML.indexOf("(Target computer download speed: ");
- if (pos >= 0) {
- Upspeed = allSmall[i].innerHTML.substr(pos+33,((allSmall[i].innerHTML.indexOf(" Kb/s", pos+33))-(pos+33)));
- Upspeed = Math.round(Upspeed / 113.7); // Upspeed is now the mbit speed of the overall connection
- newElement = document.createElement('div');
- newElement.innerHTML = "<small>" + Upspeed + " Mbit connection.</small>";
- allSmall[i].parentNode.insertBefore(newElement, allSmall[i].nextSibling);
- }
- }
-
- var FreeSpace = document.body.innerHTML.substr(document.body.innerHTML.indexOf("Free: ")+6, 10);
- FreeSpace = FreeSpace.substr(0,FreeSpace.indexOf(' '));
- FreeSpace = 1000*FreeSpace;
-
- var allTR = document.getElementsByTagName('tr');
- var MySoft = GM_getValue("AllSoft", "").split('|');
- var SoftHere = new Array();
- //GM_log(GM_getValue("AllSoft", ""));
-
- // Find highest seeker.
- var HighSeeker = 0;
- for (var i = 0; i < allTR.length; i++) {
- if (allTR[i].innerHTML.substr(0,22) == "<td bgcolor=\"#000000\">") {
- var allTD = allTR[i].innerHTML.split('</td>');
- if (allTD[1].indexOf('.skr') >= 0) {
- HighSeeker = (HighSeeker > parseFloat(allTD[2].substr(4)))?HighSeeker:parseFloat(allTD[2].substr(4));
- }
- }
- }
-
- // Parse software list on external host
- // Get highest AV version
- var highestAV = '0.1';
- for (var i = 0; i < allTR.length; i++) {
-
- // Check if Slave is a GS, if yes get Name
- var regExp = /Property of \<b\>\[.*]\<\/b\>/gm;
- if ( allTR[i].innerHTML.match(regExp) ) {
- m = allTR[i].innerHTML.match(regExp);
- if ( m != null ) {
- GSname = m[0].split('Property of ')[1].replace('<b>', '').replace('</b>', '');
- }
- }
-
- if (allTR[i].innerHTML.substr(0,22) == "<td bgcolor=\"#000000\">") {
- var allTD = allTR[i].innerHTML.split('</td>');
- var ThisSoft = allTD[1].replace("<td> ","") + " " + allTD[2].replace("<td>","");
- // Remove download and delete links for active viruses
- if ( (allTD[0] == "<td bgcolor=\"#000000\"><img src=\"layout/activevspam.jpg\" border=\"0\">")
- || (allTD[0] == "<td bgcolor=\"#000000\"><img src=\"layout/activevshare.jpg\" border=\"0\">")
- || (allTD[0] == "<td bgcolor=\"#000000\"><img src=\"layout/activevddos.jpg\" border=\"0\">") ) {
-
- allTD[5] = '<td bgcolor="#000000">';
- allTD[8] = '<td bgcolor="#000000">';
-
- if ( allTD[2].replace("<td>","") != '' ) {
- if ( aViruses != '' ) { aViruses = aViruses + '@'; }
- aViruses = aViruses + allTD[1].split('.')[1] + " " + allTD[2].replace("<td>","");
- }
-
- } else {
- // Make a list of all software on this system
- SoftHere[SoftHere.length] = allTD[1].replace("<td> ","") + " " + allTD[2].replace("<td>","");
-
- if ( allTD[2].replace("<td>","") != '' ) {
- if ( aApps != '' ) { aApps = aApps + '@'; }
- aApps = aApps + allTD[1].split('.')[1] + " " + allTD[2].replace("<td>","");
- }
-
- // Get highest AV version
- if ( allTD[1].indexOf('.av') >= 0 ) {
- var vers = allTD[2].replace("<td>","");
- if ( vers > highestAV ) {
- highestAV = vers;
- }
- }
-
- // Display own File Versione beside Server version and make the higher one bold
- var myFileVersion = getHighestAppVersion(allTD[1].replace("<td> ",""));
- myFileVersion = ((myFileVersion == 'NA') ? '0.1' : myFileVersion);
- var iCompareSlave = parseInt(allTD[2].replace('<td>', '').replace('.', ''));
- var iCompareOwn = (myFileVersion.length == 1) ? parseInt(myFileVersion + '0') : parseInt(myFileVersion.replace('.', ''));
- allTD[2] = ((iCompareSlave > 0) ? (( iCompareSlave > iCompareOwn ) ? ('<td><b>' + allTD[2].replace('<td>', '') + '</b> (' + ((myFileVersion == '0.1') ? 'NA' : myFileVersion) + ')') : (allTD[2] + ' <b>(' + myFileVersion + ')</b>')) : '<td>');
- }
-
- // Remove download links for software we already have
- for (var j = 0; j < MySoft.length; j++) {
- if (MySoft[j] == ThisSoft) {
- allTD[8] = '<td bgcolor="#000000">';
- break;
- }
- }
-
- // Display time diff instead of actual time
- allTD[4] = '<td><a title="'+allTD[4].substr(4)+'">' + DisplayTimeDiff(SHTime-ParseTime(allTD[4])) + ' ago</a>';
-
- // Hide hide link if applicable
- if (parseFloat(allTD[6].substr(40)) >= HiderLevel ) {
- allTD[6] = allTD[6].replace("<img src=\"layout/hide.jpg\" border=\"0\">",'');
- }
-
- // Remove hide level 0.0
- allTD[6] = allTD[6].replace('0.0',' ');
-
- // Lowlight (!hilight) if player can't see it.
- if (parseFloat(allTD[6].substr(40)) > HighSeeker) {
- allTD[1] = allTD[1].replace('<td>','<td><i><font color=tan>');
- allTD[1] = allTD[1]+'</font></i>';
- allTD[2] = allTD[2].replace('<td>','<td><i><font color=tan>');
- allTD[2] = allTD[2]+'</font></i>';
- allTD[3] = allTD[3].replace('<td>','<td><i><font color=tan>');
- allTD[3] = allTD[3]+'</font></i>';
- allTD[4] = allTD[4].replace('<td>','<td><i><font color=tan>');
- allTD[4] = allTD[4]+'</font></i>';
- }
-
- // Replace file line
- allTR[i].innerHTML = allTD.join('</td>');
- }
- }
-
- // 0: IP, 1: MBIT, 2: Money/h, 3: apps, 4: viruses, 5: last update, 6: GS-Name
- manageSlaves(ConnectedToIP, new Array(ConnectedToIP, Upspeed, '', aApps, aViruses, SHTime, GSname), 'update', 'files');
-
- // Add upload form to file menu (instead of it being a seperate page)
- var allA = document.getElementsByTagName('a');
- var replaceMe;
- for (var i = 0; i < allA.length; i++) {
- //if (allA[i].innerHTML == '<small>Upload a file</small>') {
- if (0) { // Disabled for now
- replaceMe = allA[i];
- GM_xmlhttpRequest({
- method: 'GET',
- url: allA[i].href,
- onload: function(responseDetails) {
- var newForm = document.createElement('form');
- var reSelect = /(<select name=upload>.*?<\/select>)/;
- var sFileStyle = '';
- var sFileImage = '';
- var aFiles = new Array("wwl", "crc", "fwl", "vspam", "mailer","av", "ana", "vshare", "fc", "skr", "hdr", "enc", "dec", "rip", "vddos", "rddos", "txt", "img", "exe");
- var mySelect = 'no';
- var aNewOptions = new Array();
- newForm.method = 'post';
- newForm.action = replaceMe.href;
- if (responseDetails.responseText.match(reSelect)) {
- var selectOptions = (reSelect.exec(responseDetails.responseText))[1].split('<option');
- var newHTML = '<select name=upload>';
-
- // Only allow uploads of files that don't already exist here.
- for(var j=1;j < selectOptions.length; j++) {
- var OnThisPage = false;
- var reOption = / (\d+\.?\d*) \[(.*?) *\]/;
- if (selectOptions[j].match(reOption)) {
- var SelectMatch = reOption.exec(selectOptions[j]);
- for(var k = 0; k < SoftHere.length; k++) {
- OnThisPage = OnThisPage || ((SelectMatch[2]+' '+SelectMatch[1]) == SoftHere[k]);
- }
- }
-
- var FileSize = selectOptions[j].substr(selectOptions[j].indexOf("]")+3);
- FileSize = FileSize.substr(0,FileSize.indexOf(' '))*1000;
-
- selectOptions[j]=selectOptions[j].replace("</select>","");
-
- if (!OnThisPage && (FileSize <= FreeSpace)) {
- aNewOptions[aNewOptions.length] = selectOptions[j];
- }
- }
-
- for(var j=0;j < aNewOptions.length; j++) {
- var fileSize = aNewOptions[j].match(/\d{1}\.\d{3}/gm)[0];
- var selected = '';
- var deleteable = '';
-
- for(var k=0; k < aFiles.length; k++) {
- if (aNewOptions[j].indexOf(aFiles[k]) > 0) {
- sFileImage = aFiles[k];
- // Red out deletable virus
- if ( aFiles[k] == 'vshare' || aFiles[k] == 'vddos' || aFiles[k] == 'vspam') {
- var regExp = /(vshare|vddos|vspam)\s((\d{1}\.\d{1})|(\d{1}))/gm;
- var m = aNewOptions[j].match(regExp);
- if ( m != null ) {
- if ( m[0].split(' ')[1] <= highestAV ) {
- deleteable = ' background-color: #FFD5D5;';
- }
- }
- }
-
- if (aFiles[k] == 'rip') {
- sFileImage = 'warez';
- } else if (aFiles[k] == 'vshare') {
- sFileImage = 'fc';
- } else if (aFiles[k] == 'vspam') {
- //GM_log('-' + highestAV + '-');
-
- if ( mySelect == 'no' ) {
- selected = 'selected ';
- mySelect = 'ok';
-
- if ( getUpDownloadTime(fileSize, maxUploadSpeed, 'sec') > 120 ) {
- if ( aNewOptions.length > (j+1) ) {
- var m2 = aNewOptions[(j+1)].match(/vspam\s((\d{1}\.\d{1})|(\d{1}))/gm);
- if ( m2 != null ) {
- if ( m2[0].split(' ')[0] == 'vspam' ) {
- if ( m2[0].split(' ')[1] > highestAV ) {
- selected = '';
- mySelect = 'no';
- }
- }
- }
- }
- }
- }
- }
-
- sFileStyle = 'style="padding-left: 20;' + deleteable + ' background-image: url(\'./layout/' + sFileImage + '.jpg\'); background-repeat: no-repeat;" ';
- }
- }
-
- // Calculate upload time for each file
- var uploadTime = getUpDownloadTime(fileSize, maxUploadSpeed, '');
-
- newHTML = newHTML + "<option " + selected + sFileStyle + aNewOptions[j].replace(' ]', ']') + ' [' + uploadTime + "]\n";
- }
- newHTML = newHTML + '<option value=\'\'>View Upload Page';
- newHTML = newHTML + '</select>';
- newHTML = newHTML + "<input type=submit value=\"Upload File\" class=form>";
- newForm.innerHTML = newHTML;
- replaceMe.parentNode.insertBefore(newForm, replaceMe);
- replaceMe.parentNode.removeChild(replaceMe);
- }
- }
- });
- }
- }
- }
-
- if ( window.location.href.match('page=slaves') ) {
-
- //////////////////////////////////////////////////////
- //////////// ADD AND CONFIGURE TOOLTIP ///////////////
- //////////////////////////////////////////////////////
-
- // BASE64 Encoded Images // URL to encoder: http://www.greywyvern.com/code/php/binary2base64
- var sImages = "var bas64Images = new Array();\n" +
- "bas64Images['wwl'] = '';\n" +
- "bas64Images['crc'] = '';\n" +
- "bas64Images['fwl'] = '%3D%3D';\n" +
- "bas64Images['vspam'] = '%3D%3D';\n" +
- "bas64Images['mailer'] = '%3D';\n" +
- "bas64Images['av'] = '%3D%3D';\n" +
- "bas64Images['ana'] = '%3D%3D';\n" +
- "bas64Images['vshare'] = bas64Images['vspam'];\n" +
- "bas64Images['fc'] = '';\n" +
- "bas64Images['skr'] = '%3D%3D';\n" +
- "bas64Images['hdr'] = '';\n" +
- "bas64Images['enc'] = '%3D';\n" +
- "bas64Images['dec'] = '%3D%3D';\n" +
- "bas64Images['rip'] = '%3D';\n" +
- "bas64Images['warez'] = bas64Images['rip'];\n" +
- "bas64Images['vddos'] = bas64Images['vspam'];\n" +
- "bas64Images['rddos'] = '';\n" +
- "bas64Images['txt'] = '%3D%3D';\n" +
- "bas64Images['img'] = '';\n" +
- "bas64Images['exe'] = '%3D%3D';\n" +
- "bas64Images['activespam'] = '%3D';\n";
-
- // Function to generate Apps/Viruses Info for Slaves
-
- var sAppsTable = 'function generateTooltip(sSlave, sFiles) {\n' + sImages +
- ' var aFiles = new Array();\n' +
- ' aFiles["wwl"] = "Waterwall";\n' +
- ' aFiles["crc"] = "Password";\n' +
- ' aFiles["fwl"] = "Firewall";\n' +
- ' aFiles["vspam"] = "SpamVirus";\n' +
- ' aFiles["mailer"] = "MarketingMailer";\n' +
- ' aFiles["av"] = "AntiVirus";\n' +
- ' aFiles["ana"] = "Analyse";\n' +
- ' aFiles["vshare"] = "ShareWarez";\n' +
- ' aFiles["fc"] = "FtpCash";\n' +
- ' aFiles["skr"] = "Seeker";\n' +
- ' aFiles["hdr"] = "Hider";\n' +
- ' aFiles["enc"] = "Encryptor";\n' +
- ' aFiles["dec"] = "Decrypter";\n' +
- ' aFiles["rip"] = "Warez";\n' +
- ' aFiles["vddos"] = "DDoSVirus";\n' +
- ' aFiles["rddos"] = "RemoteDestruction";\n' +
- ' aFiles["txt"] = "TextFile";\n' +
- ' aFiles["img"] = "ImageFile";\n' +
- ' aFiles["exe"] = "Forum";\n' +
- ' aSlave = sSlave.split("#");\n' +
- ' aFile = sFiles.split("#");\n' +
- ' var aMark = new Array();\n' +
- ' aMark["vspam"] = "";\n' +
- ' aMark["vddos"] = "";\n' +
- ' aMark["vshare"] = "";\n' +
- ' var sTable = "<table><tr><td colspan=\\\"2\\\"><table><tr><td>Last Updated: </td><td>" + aFile[5] + "</td></tr></table></td></tr><tr><td valign=\\\"top\\\"><table><tr bgcolor=\\\"#222222\\\"><td width=\\\"16\\\"></td><td><b>Files</b></td><td width=\\\"10\\\"><b>Level</b></td></tr>";\n' +
- ' for (var i=0; i<=1; i++) {\n' +
- ' if ( i == 1 ) {\n' +
- ' sTable = sTable + "</table></td>";\n' +
- ' sTable = sTable + "<td valign=\\\"top\\\"><table><tr bgcolor=\\\"#222222\\\"><td width=\\\"16\\\"></td><td><b>Viruses</b></td><td width=\\\"10\\\"><b>Level</b></td></tr>";\n' +
- ' }\n' +
- ' if ( (aFile[3] != "" && i == 0) || (aFile[4] != "" && i == 1) ) {\n' +
- ' var aApps = aFile[((i==0) ? 3 : 4)].split("@");\n' +
- ' for (var j=0; j < aApps.length; j++) {\n' +
- ' var aApp = aApps[j].split(" ");\n' +
- ' //alert(aApp[0] + " == vddos && " + aMark["vspam"] + " == && " + aApp[1].replace(".0", "") + " == " + aSlave[2].replace(".0", "") );\n' +
- ' var color = "#000000";\n' +
- ' if ( i == 1 && aApp[0] == "vspam" && aMark["vspam"] == "" && aApp[1].replace(".0", "") == aSlave[1].replace(".0", "") ) {\n' +
- ' aMark["vspam"] = "found"\n' +
- ' var bgColor = ((aSlave[4] == "S") ? "#B5FFB3" : "#FFD5D5");\n' +
- ' } else if ( i == 1 && aApp[0] == "vddos" && aMark["vddos"] == "" && aApp[1].replace(".0", "") == aSlave[2].replace(".0", "") ) {\n' +
- ' aMark["vddos"] = "found"\n' +
- ' var bgColor = ((aSlave[4] == "D") ? "#B5FFB3" : "#FFD5D5");\n' +
- ' } else if ( i == 1 && aApp[0] == "vshare" && aMark["vshare"] == "" && aApp[1].replace(".0", "") == aSlave[3].replace(".0", "") ) {\n' +
- ' aMark["vshare"] = "found"\n' +
- ' var bgColor = ((aSlave[4] == "W") ? "#B5FFB3" : "#FFD5D5");\n' +
- ' } else {\n' +
- ' var bgColor = "#444444";\n' +
- ' var color = "#FFFFFF";\n' +
- ' if (j%2) {\n' +
- ' bgColor = "#222222";\n' +
- ' }\n' +
- ' }\n' +
- ' if ( i == 0 ) {\n' +
- ' sTable = sTable + "<tr bgcolor=\\\"" + bgColor + "\\\"><td bgcolor=\\\"#000000\\\"><img border=\\\"0\\\" src=\\\"" + bas64Images[((aApp[0] == \'rip\') ? \'warez\' : aApp[0])] + "\\\"></td><td>" + aFiles[aApp[0]] + "." + aApp[0] + "</td><td><b>" + aApp[1] + "</b></td></tr>";\n' +
- ' } else if ( i == 1 ) {\n' +
- ' sTable = sTable + "<tr bgcolor=\\\"" + bgColor + "\\\"><td bgcolor=\\\"#000000\\\"><img border=\\\"0\\\" src=\\\"" + bas64Images["activespam"] + "\\\"></td><td><font color=\\\"" + color + "\\\">" + aFiles[aApp[0]] + "." + aApp[0] + "</font></td><td><font color=\\\"" + color + "\\\"><b>" + aApp[1] + "</b></font></td></tr>";\n' +
- ' }\n' +
- ' }\n' +
- ' }\n' +
- ' }\n' +
- ' sTable = sTable + "</table></td></tr></table>";\n' +
- ' return sTable;\n' +
- '}';
-
-
- var sTooltip = 'var config = new Object(); var tt_Debug = true; var tt_Enabled = true; var TagsToTip = true; config. Above = false; config. BgColor = "#E2E7FF"; config. BgImg = ""; config. BorderColor = "#003099"; config. BorderStyle = "solid"; config. BorderWidth = 1; config. CenterMouse = false; config. ClickClose = false; config. ClickSticky = false; config. CloseBtn = false; config. CloseBtnColors = ["#990000", "#FFFFFF", "#DD3333", "#FFFFFF"]; config. CloseBtnText = " X "; config. CopyContent = true; config. Delay = 0; config. Duration = 0; config. Exclusive = false; config. FadeIn = 100; config. FadeOut = 100; config. FadeInterval = 30; config. Fix = null; config. FollowMouse = true; config. FontColor = "#000044"; config. FontFace = "Verdana,Geneva,sans-serif"; config. FontSize = "8pt"; config. FontWeight = "normal"; config. Height = 0; config. JumpHorz = false; config. JumpVert = true; config. Left = false; config. OffsetX = 14; config. OffsetY = 8; config. Opacity = 100; config. Padding = 3; config. Shadow = false; config. ShadowColor = "#C0C0C0"; config. ShadowWidth = 5; config. Sticky = false; config. TextAlign = "left"; config. Title = ""; config. TitleAlign = "left"; config. TitleBgColor = ""; config. TitleFontColor = "#FFFFFF"; config. TitleFontFace = ""; config. TitleFontSize = ""; config. TitlePadding = 2; config. Width = 0;\n' +
- 'function Tip() { tt_Tip(arguments, null); }\n' +
- 'function TagToTip() { var t2t = tt_GetElt(arguments[0]); if(t2t) { tt_Tip(arguments, t2t); } }\n' +
- 'function UnTip() { tt_OpReHref(); if(tt_aV[DURATION] < 0 && (tt_iState & 0x2)) { tt_tDurt.Timer("tt_HideInit()", -tt_aV[DURATION], true); } else if(!(tt_aV[STICKY] && (tt_iState & 0x2))) { tt_HideInit(); } }\n' +
- 'var tt_aElt = new Array(10); var tt_aV = new Array(); var tt_sContent; var tt_t2t; var tt_t2tDad; var tt_musX; var tt_musY; var tt_over; var tt_x; var tt_y; var tt_w; var tt_h;\n' +
- 'function tt_Extension() { tt_ExtCmdEnum(); tt_aExt[tt_aExt.length] = this; return this; }\n' +
- 'function tt_SetTipPos(x, y) { var css = tt_aElt[0].style; tt_x = x; tt_y = y; css.left = x + "px"; css.top = y + "px"; if(tt_ie56) { var ifrm = tt_aElt[tt_aElt.length - 1]; if(ifrm) { ifrm.style.left = css.left; ifrm.style.top = css.top; } } }\n' +
- 'function tt_HideInit() { if(tt_iState) { tt_ExtCallFncs(0, "HideInit"); tt_iState &= ~(0x4 | 0x8); if(tt_flagOpa && tt_aV[FADEOUT]) { tt_tFade.EndTimer(); if(tt_opa) { var n = Math.round(tt_aV[FADEOUT] / (tt_aV[FADEINTERVAL] * (tt_aV[OPACITY] / tt_opa))); tt_Fade(tt_opa, tt_opa, 0, n); return; } } tt_tHide.Timer("tt_Hide();", 1, false); } }\n' +
- 'function tt_Hide() { if(tt_db && tt_iState) { tt_OpReHref(); if(tt_iState & 0x2) { tt_aElt[0].style.visibility = "hidden"; tt_ExtCallFncs(0, "Hide"); } tt_tShow.EndTimer(); tt_tHide.EndTimer(); tt_tDurt.EndTimer(); tt_tFade.EndTimer(); if(!tt_op && !tt_ie) { tt_tWaitMov.EndTimer(); tt_bWait = false; } if(tt_aV[CLICKCLOSE] || tt_aV[CLICKSTICKY]) { tt_RemEvtFnc(document, "mouseup", tt_OnLClick); } tt_ExtCallFncs(0, "Kill"); if(tt_t2t && !tt_aV[COPYCONTENT]) { tt_UnEl2Tip(); } tt_iState = 0; tt_over = null; tt_ResetMainDiv(); if(tt_aElt[tt_aElt.length - 1]) { tt_aElt[tt_aElt.length - 1].style.display = "none"; } } }\n' +
- 'function tt_GetElt(id) { return(document.getElementById ? document.getElementById(id) : document.all ? document.all[id] : null); }\n' +
- 'function tt_GetDivW(el) { return(el ? (el.offsetWidth || el.style.pixelWidth || 0) : 0); }\n' +
- 'function tt_GetDivH(el) { return(el ? (el.offsetHeight || el.style.pixelHeight || 0) : 0); }\n' +
- 'function tt_GetScrollX() { return(window.pageXOffset || (tt_db ? (tt_db.scrollLeft || 0) : 0)); }\n' +
- 'function tt_GetScrollY() { return(window.pageYOffset || (tt_db ? (tt_db.scrollTop || 0) : 0)); }\n' +
- 'function tt_GetClientW() { return tt_GetWndCliSiz("Width"); }\n' +
- 'function tt_GetClientH() { return tt_GetWndCliSiz("Height"); }\n' +
- 'function tt_GetEvtX(e) { return (e ? ((typeof(e.pageX) != tt_u) ? e.pageX : (e.clientX + tt_GetScrollX())) : 0); }\n' +
- 'function tt_GetEvtY(e) { return (e ? ((typeof(e.pageY) != tt_u) ? e.pageY : (e.clientY + tt_GetScrollY())) : 0); }\n' +
- 'function tt_AddEvtFnc(el, sEvt, PFnc) { if(el) { if(el.addEventListener) { el.addEventListener(sEvt, PFnc, false); } else { el.attachEvent("on" + sEvt, PFnc); } } }\n' +
- 'function tt_RemEvtFnc(el, sEvt, PFnc) { if(el) { if(el.removeEventListener) { el.removeEventListener(sEvt, PFnc, false); } else { el.detachEvent("on" + sEvt, PFnc); } } }\n' +
- 'function tt_GetDad(el) { return(el.parentNode || el.parentElement || el.offsetParent); }\n' +
- 'function tt_MovDomNode(el, dadFrom, dadTo) { if(dadFrom) { dadFrom.removeChild(el); } if(dadTo) { dadTo.appendChild(el); } }\n' +
- 'var tt_aExt = new Array(); var tt_db; var tt_op; var tt_ie; var tt_ie56; var tt_bBoxOld; var tt_body; var tt_ovr_; var tt_flagOpa; var tt_maxPosX; var tt_maxPosY; var tt_iState = 0; var tt_opa; var tt_bJmpVert; var tt_bJmpHorz; var tt_elDeHref; var tt_tShow = new Number(0); var tt_tHide = new Number(0); var tt_tDurt = new Number(0); var tt_tFade = new Number(0); var tt_tWaitMov = new Number(0); var tt_bWait = false; var tt_u = "undefined";\n' +
- 'function tt_Init() { tt_MkCmdEnum(); if(!tt_Browser() || !tt_MkMainDiv()) { return; } tt_IsW3cBox(); tt_OpaSupport(); tt_AddEvtFnc(document, "mousemove", tt_Move); if(TagsToTip || tt_Debug) { tt_SetOnloadFnc(); } tt_AddEvtFnc(window, "unload", tt_Hide); }\n' +
- 'function tt_MkCmdEnum() { var n = 0; for(var i in config) { eval("window." + i.toString().toUpperCase() + " = " + n++); } tt_aV.length = n; }\n' +
- 'function tt_Browser() { var n; var nv; var n6; var w3c; n = navigator.userAgent.toLowerCase(); nv = navigator.appVersion; tt_op = (document.defaultView && typeof(eval("w" + "indow" + "." + "o" + "p" + "er" + "a")) != tt_u); tt_ie = n.indexOf("msie") != -1 && document.all && !tt_op; if(tt_ie) { var ieOld = (!document.compatMode || document.compatMode == "BackCompat"); tt_db = !ieOld ? document.documentElement : (document.body || null); if(tt_db) { tt_ie56 = parseFloat(nv.substring(nv.indexOf("MSIE") + 5)) >= 5.5 && typeof document.body.style.maxHeight == tt_u; } } else { tt_db = document.documentElement || document.body || (document.getElementsByTagName ? document.getElementsByTagName("body")[0] : null); if(!tt_op) { n6 = document.defaultView && typeof document.defaultView.getComputedStyle != tt_u; w3c = !n6 && document.getElementById; } } tt_body = (document.getElementsByTagName ? document.getElementsByTagName("body")[0] : (document.body || null)); if(tt_ie || n6 || tt_op || w3c) { if(tt_body && tt_db) { if(document.attachEvent || document.addEventListener) { return true; } } else { tt_Err("wz_tooltip.js must be included INSIDE the body section, immediately after the opening <body> tag.", false); } } tt_db = null; return false; }\n' +
- 'function tt_MkMainDiv() { if(tt_body.insertAdjacentHTML) { tt_body.insertAdjacentHTML("afterBegin", tt_MkMainDivHtm()); } else if(typeof tt_body.innerHTML != tt_u && document.createElement && tt_body.appendChild) { tt_body.appendChild(tt_MkMainDivDom()); } if(window.tt_GetMainDivRefs && tt_GetMainDivRefs()) { return true; } tt_db = null; return false; }\n' +
- 'function tt_MkMainDivHtm() { return( \'<div id="WzTtDiV"></div>\' + (tt_ie56 ? (\'<iframe id="WzTtIfRm" src="javascript:false" scrolling="no" frameborder="0" style="filter:Alpha(opacity=0);position:absolute;top:0px;left:0px;display:none;"></iframe>\') : "") ); }\n' +
- 'function tt_MkMainDivDom() { var el = document.createElement("div"); if(el) { el.id = "WzTtDiV"; } return el; }\n' +
- 'function tt_GetMainDivRefs() { tt_aElt[0] = tt_GetElt("WzTtDiV"); if(tt_ie56 && tt_aElt[0]) { tt_aElt[tt_aElt.length - 1] = tt_GetElt("WzTtIfRm"); if(!tt_aElt[tt_aElt.length - 1]) { tt_aElt[0] = null; } } if(tt_aElt[0]) { var css = tt_aElt[0].style; css.visibility = "hidden"; css.position = "absolute"; css.overflow = "hidden"; return true; } return false; }\n' +
- 'function tt_ResetMainDiv() { tt_SetTipPos(0, 0); tt_aElt[0].innerHTML = ""; tt_aElt[0].style.width = "0px"; tt_h = 0; }\n' +
- 'function tt_IsW3cBox() { var css = tt_aElt[0].style; css.padding = "10px"; css.width = "40px"; tt_bBoxOld = (tt_GetDivW(tt_aElt[0]) == 40); css.padding = "0px"; tt_ResetMainDiv(); }\n' +
- 'function tt_OpaSupport() { var css = tt_body.style; tt_flagOpa = (typeof(css.KhtmlOpacity) != tt_u) ? 2 : (typeof(css.KHTMLOpacity) != tt_u) ? 3 : (typeof(css.MozOpacity) != tt_u) ? 4 : (typeof(css.opacity) != tt_u) ? 5 : (typeof(css.filter) != tt_u) ? 1 : 0; }\n' +
- 'function tt_SetOnloadFnc() { tt_AddEvtFnc(document, "DOMContentLoaded", tt_HideSrcTags); tt_AddEvtFnc(window, "load", tt_HideSrcTags); if(tt_body.attachEvent) { tt_body.attachEvent("onreadystatechange", function() { if(tt_body.readyState == "complete") { tt_HideSrcTags(); } } ); } if(/WebKit|KHTML/i.test(navigator.userAgent)) { var t = setInterval(function() { if(/loaded|complete/.test(document.readyState)) { clearInterval(t); tt_HideSrcTags(); } }, 10); } }\n' +
- 'function tt_HideSrcTags() { if(!window.tt_HideSrcTags || window.tt_HideSrcTags.done) { return; } window.tt_HideSrcTags.done = true; if(!tt_HideSrcTagsRecurs(tt_body)) { tt_Err("There are HTML elements to be converted to tooltips. If you want these HTML elements to be automatically hidden, you must edit wz_tooltip.js, and set TagsToTip in the global tooltip configuration to true.", true); } }\n' +
- 'function tt_HideSrcTagsRecurs(dad) { var ovr; var asT2t; var a = dad.childNodes || dad.children || null; for(var i = a ? a.length : 0; i;) { --i; if(!tt_HideSrcTagsRecurs(a[i])) { return false; } ovr = a[i].getAttribute ? (a[i].getAttribute("onmouseover") || a[i].getAttribute("onclick")) : (typeof a[i].onmouseover == "function") ? (a[i].onmouseover || a[i].onclick) : null; if(ovr) { asT2t = ovr.toString().match(/TagToTip\\\s*\\\(\\\s*\\\'[^\\\'.]+\'\\\s*[\\\),]/); if(asT2t && asT2t.length) { if(!tt_HideSrcTag(asT2t[0])) { return false; } } } } return true; }\n' +
- 'function tt_HideSrcTag(sT2t) { var id; var el; id = sT2t.replace(/.+\'([^\'.]+)\'.+/, "$1"); el = tt_GetElt(id); if(el) { if(tt_Debug && !TagsToTip) { return false; } else { el.style.display = "none"; } } else { tt_Err("Invalid ID" + id + "passed to TagToTip(). There exists no HTML element with that ID.", true); } return true; }\n' +
- 'function tt_Tip(arg, t2t) { if(!tt_db || (tt_iState & 0x8)) { return; } if(tt_iState) { tt_Hide(); } if(!tt_Enabled) { return; } tt_t2t = t2t; if(!tt_ReadCmds(arg)) { return; } tt_iState = 0x1 | 0x4; tt_AdaptConfig1(); tt_MkTipContent(arg); tt_MkTipSubDivs(); tt_FormatTip(); tt_bJmpVert = false; tt_bJmpHorz = false; tt_maxPosX = tt_GetClientW() + tt_GetScrollX() - tt_w - 1; tt_maxPosY = tt_GetClientH() + tt_GetScrollY() - tt_h - 1; tt_AdaptConfig2(); tt_OverInit(); tt_ShowInit(); tt_Move(); }\n' +
- 'function tt_ReadCmds(a) { var i; i = 0; for(var j in config) { tt_aV[i++] = config[j]; } if(a.length & 1) { for(i = a.length - 1; i > 0; i -= 2) { tt_aV[a[i - 1]] = a[i]; } return true; } tt_Err("Incorrect call of Tip() or TagToTip(). Each command must be followed by a value.", true); return false; }\n' +
- 'function tt_AdaptConfig1() { tt_ExtCallFncs(0, "LoadConfig"); if(!tt_aV[TITLEBGCOLOR].length) { tt_aV[TITLEBGCOLOR] = tt_aV[BORDERCOLOR]; } if(!tt_aV[TITLEFONTCOLOR].length) { tt_aV[TITLEFONTCOLOR] = tt_aV[BGCOLOR]; } if(!tt_aV[TITLEFONTFACE].length) { tt_aV[TITLEFONTFACE] = tt_aV[FONTFACE]; } if(!tt_aV[TITLEFONTSIZE].length) { tt_aV[TITLEFONTSIZE] = tt_aV[FONTSIZE]; } if(tt_aV[CLOSEBTN]) { if(!tt_aV[CLOSEBTNCOLORS]) { tt_aV[CLOSEBTNCOLORS] = new Array("", "", "", ""); } for(var i = 4; i;) {--i; if(!tt_aV[CLOSEBTNCOLORS][i].length) { tt_aV[CLOSEBTNCOLORS][i] = (i & 1) ? tt_aV[TITLEFONTCOLOR] : tt_aV[TITLEBGCOLOR]; }} if(!tt_aV[TITLE].length) { tt_aV[TITLE] = " "; } } if(tt_aV[OPACITY] == 100 && typeof tt_aElt[0].style.MozOpacity != tt_u && !Array.every) { tt_aV[OPACITY] = 99; } if(tt_aV[FADEIN] && tt_flagOpa && tt_aV[DELAY] > 100) { tt_aV[DELAY] = Math.max(tt_aV[DELAY] - tt_aV[FADEIN], 100); } }\n' +
- 'function tt_AdaptConfig2() { if(tt_aV[CENTERMOUSE]) { tt_aV[OFFSETX] -= ((tt_w - (tt_aV[SHADOW] ? tt_aV[SHADOWWIDTH] : 0)) >> 1); tt_aV[JUMPHORZ] = false; } }\n' +
- 'function tt_MkTipContent(a) { if(tt_t2t) { if(tt_aV[COPYCONTENT]) { tt_sContent = tt_t2t.innerHTML; } else { tt_sContent = ""; } } else { tt_sContent = a[0]; } tt_ExtCallFncs(0, "CreateContentString"); }\n' +
- 'function tt_MkTipSubDivs() { var sCss = "position:relative;margin:0px;padding:0px;border-width:0px;left:0px;top:0px;line-height:normal;width:auto;"; var sTbTrTd = \' cellspacing="0" cellpadding="0" border="0" style="\' + sCss + \'"><tbody style="\' + sCss + \'"><tr><td \'; tt_aElt[0].style.width = tt_GetClientW() + "px"; tt_aElt[0].innerHTML = ("" + (tt_aV[TITLE].length ? (\'<div id="WzTiTl" style="position:relative;z-index:1;">\' + \'<table id="WzTiTlTb"\' + sTbTrTd + \'id="WzTiTlI" style="\' + sCss + \'">\' + tt_aV[TITLE] + "</td>" + (tt_aV[CLOSEBTN] ? (\'<td align="right" style="\' + sCss + \'text-align:right;">\' + \'<span id="WzClOsE" style="position:relative;left:2px;padding-left:2px;padding-right:2px;\' + \'cursor:\' + (tt_ie ? \'hand\' : \'pointer\') + \';" onmouseover="tt_OnCloseBtnOver(1)" onmouseout="tt_OnCloseBtnOver(0)" onclick="tt_HideInit()">\' + tt_aV[CLOSEBTNTEXT] + \'</span></td>\') : "") + "</tr></tbody></table></div>") : "") + \'<div id="WzBoDy" style="position:relative;z-index:0;">\' + "<table" + sTbTrTd + \'id="WzBoDyI" style="\' + sCss + \'">\' + tt_sContent + "</td></tr></tbody></table></div>" + (tt_aV[SHADOW] ? (\'<div id="WzTtShDwR" style="position:absolute;overflow:hidden;"></div><div id="WzTtShDwB" style="position:relative;overflow:hidden;"></div>\') : "") ); tt_GetSubDivRefs(); if(tt_t2t && !tt_aV[COPYCONTENT]) { tt_El2Tip(); } tt_ExtCallFncs(0, "SubDivsCreated"); }\n' +
- 'function tt_GetSubDivRefs() { var aId = new Array("WzTiTl", "WzTiTlTb", "WzTiTlI", "WzClOsE", "WzBoDy", "WzBoDyI", "WzTtShDwB", "WzTtShDwR"); for(var i = aId.length; i; --i) { tt_aElt[i] = tt_GetElt(aId[i - 1]); } }\n' +
- 'function tt_FormatTip() { var css; var w; var h; var pad = tt_aV[PADDING]; var padT; var wBrd = tt_aV[BORDERWIDTH]; var iOffY; var iOffSh; var iAdd = (pad + wBrd) << 1; if(tt_aV[TITLE].length) { padT = tt_aV[TITLEPADDING]; css = tt_aElt[1].style; css.background = tt_aV[TITLEBGCOLOR]; css.paddingTop = css.paddingBottom = padT + "px"; css.paddingLeft = css.paddingRight = (padT + 2) + "px"; css = tt_aElt[3].style; css.color = tt_aV[TITLEFONTCOLOR]; if(tt_aV[WIDTH] == -1) { css.whiteSpace = "nowrap"; } css.fontFamily = tt_aV[TITLEFONTFACE]; css.fontSize = tt_aV[TITLEFONTSIZE]; css.fontWeight = "bold"; css.textAlign = tt_aV[TITLEALIGN]; if(tt_aElt[4]) { css = tt_aElt[4].style; css.background = tt_aV[CLOSEBTNCOLORS][0]; css.color = tt_aV[CLOSEBTNCOLORS][1]; css.fontFamily = tt_aV[TITLEFONTFACE]; css.fontSize = tt_aV[TITLEFONTSIZE]; css.fontWeight = "bold"; } if(tt_aV[WIDTH] > 0) { tt_w = tt_aV[WIDTH]; } else { tt_w = tt_GetDivW(tt_aElt[3]) + tt_GetDivW(tt_aElt[4]); if(tt_aElt[4]) { tt_w += pad; } if(tt_aV[WIDTH] < -1 && tt_w > -tt_aV[WIDTH]) { tt_w = -tt_aV[WIDTH]; } } iOffY = -wBrd; } else { tt_w = 0; iOffY = 0; } css = tt_aElt[5].style; css.top = iOffY + "px"; if(wBrd) { css.borderColor = tt_aV[BORDERCOLOR]; css.borderStyle = tt_aV[BORDERSTYLE]; css.borderWidth = wBrd + "px"; } if(tt_aV[BGCOLOR].length) { css.background = tt_aV[BGCOLOR]; } if(tt_aV[BGIMG].length) { css.backgroundImage = "url(" + tt_aV[BGIMG] + ")"; } css.padding = pad + "px"; css.textAlign = tt_aV[TEXTALIGN]; if(tt_aV[HEIGHT]) { css.overflow = "auto"; if(tt_aV[HEIGHT] > 0) { css.height = (tt_aV[HEIGHT] + iAdd) + "px"; } else { tt_h = iAdd - tt_aV[HEIGHT]; } } css = tt_aElt[6].style; css.color = tt_aV[FONTCOLOR]; css.fontFamily = tt_aV[FONTFACE]; css.fontSize = tt_aV[FONTSIZE]; css.fontWeight = tt_aV[FONTWEIGHT]; css.textAlign = tt_aV[TEXTALIGN]; if(tt_aV[WIDTH] > 0) { w = tt_aV[WIDTH]; } else if(tt_aV[WIDTH] == -1 && tt_w) { w = tt_w; } else { w = tt_GetDivW(tt_aElt[6]); if(tt_aV[WIDTH] < -1 && w > -tt_aV[WIDTH]) { w = -tt_aV[WIDTH]; } } if(w > tt_w) { tt_w = w; } tt_w += iAdd; if(tt_aV[SHADOW]) { tt_w += tt_aV[SHADOWWIDTH]; iOffSh = Math.floor((tt_aV[SHADOWWIDTH] * 4) / 3); css = tt_aElt[7].style; css.top = iOffY + "px"; css.left = iOffSh + "px"; css.width = (tt_w - iOffSh - tt_aV[SHADOWWIDTH]) + "px"; css.height = tt_aV[SHADOWWIDTH] + "px"; css.background = tt_aV[SHADOWCOLOR]; css = tt_aElt[8].style; css.top = iOffSh + "px"; css.left = (tt_w - tt_aV[SHADOWWIDTH]) + "px"; css.width = tt_aV[SHADOWWIDTH] + "px"; css.background = tt_aV[SHADOWCOLOR]; } else { iOffSh = 0; } tt_SetTipOpa(tt_aV[FADEIN] ? 0 : tt_aV[OPACITY]); tt_FixSize(iOffY, iOffSh); }\n' +
- 'function tt_FixSize(iOffY, iOffSh) { var wIn; var wOut; var h; var add; var pad = tt_aV[PADDING]; var wBrd = tt_aV[BORDERWIDTH]; var i; tt_aElt[0].style.width = tt_w + "px"; tt_aElt[0].style.pixelWidth = tt_w; wOut = tt_w - ((tt_aV[SHADOW]) ? tt_aV[SHADOWWIDTH] : 0); wIn = wOut; if(!tt_bBoxOld) { wIn -= (pad + wBrd) << 1; } tt_aElt[5].style.width = wIn + "px"; if(tt_aElt[1]) { wIn = wOut - ((tt_aV[TITLEPADDING] + 2) << 1); if(!tt_bBoxOld) { wOut = wIn; } tt_aElt[1].style.width = wOut + "px"; tt_aElt[2].style.width = wIn + "px"; } if(tt_h) { h = tt_GetDivH(tt_aElt[5]); if(h > tt_h) { if(!tt_bBoxOld) { tt_h -= (pad + wBrd) << 1; } tt_aElt[5].style.height = tt_h + "px"; } } tt_h = tt_GetDivH(tt_aElt[0]) + iOffY; if(tt_aElt[8]) { tt_aElt[8].style.height = (tt_h - iOffSh) + "px"; } i = tt_aElt.length - 1; if(tt_aElt[i]) { tt_aElt[i].style.width = tt_w + "px"; tt_aElt[i].style.height = tt_h + "px"; } }\n' +
- 'function tt_DeAlt(el) { var aKid; if(el) { if(el.alt) { el.alt = ""; } if(el.title) { el.title = ""; } aKid = el.childNodes || el.children || null; if(aKid) { for(var i = aKid.length; i;) { tt_DeAlt(aKid[--i]); } } } }\n' +
- 'function tt_OpDeHref(el) { if(!tt_op) { return; } if(tt_elDeHref) { tt_OpReHref(); } while(el) { if(el.hasAttribute && el.hasAttribute("href")) { el.t_href = el.getAttribute("href"); el.t_stats = window.status; el.removeAttribute("href"); el.style.cursor = "hand"; tt_AddEvtFnc(el, "mousedown", tt_OpReHref); window.status = el.t_href; tt_elDeHref = el; break; } el = tt_GetDad(el); } }\n' +
- 'function tt_OpReHref() { if(tt_elDeHref) { tt_elDeHref.setAttribute("href", tt_elDeHref.t_href); tt_RemEvtFnc(tt_elDeHref, "mousedown", tt_OpReHref); window.status = tt_elDeHref.t_stats; tt_elDeHref = null; } }\n' +
- 'function tt_El2Tip() { var css = tt_t2t.style; tt_t2t.t_cp = css.position; tt_t2t.t_cl = css.left; tt_t2t.t_ct = css.top; tt_t2t.t_cd = css.display; tt_t2tDad = tt_GetDad(tt_t2t); tt_MovDomNode(tt_t2t, tt_t2tDad, tt_aElt[6]); css.display = "block"; css.position = "static"; css.left = css.top = css.marginLeft = css.marginTop = "0px"; }\n' +
- 'function tt_UnEl2Tip() { var css = tt_t2t.style; css.display = tt_t2t.t_cd; tt_MovDomNode(tt_t2t, tt_GetDad(tt_t2t), tt_t2tDad); css.position = tt_t2t.t_cp; css.left = tt_t2t.t_cl; css.top = tt_t2t.t_ct; tt_t2tDad = null; }\n' +
- 'function tt_OverInit() { if(window.event) { tt_over = window.event.target || window.event.srcElement; } else { tt_over = tt_ovr_; } tt_DeAlt(tt_over); tt_OpDeHref(tt_over); }\n' +
- 'function tt_ShowInit() { tt_tShow.Timer("tt_Show()", tt_aV[DELAY], true); if(tt_aV[CLICKCLOSE] || tt_aV[CLICKSTICKY]) { tt_AddEvtFnc(document, "mouseup", tt_OnLClick); } }\n' +
- 'function tt_Show() { var css = tt_aElt[0].style; css.zIndex = Math.max((window.dd && dd.z) ? (dd.z + 2) : 0, 1010); if(tt_aV[STICKY] || !tt_aV[FOLLOWMOUSE]) { tt_iState &= ~0x4; } if(tt_aV[EXCLUSIVE]) { tt_iState |= 0x8; } if(tt_aV[DURATION] > 0) { tt_tDurt.Timer("tt_HideInit()", tt_aV[DURATION], true); } tt_ExtCallFncs(0, "Show"); css.visibility = "visible"; tt_iState |= 0x2; if(tt_aV[FADEIN]) { tt_Fade(0, 0, tt_aV[OPACITY], Math.round(tt_aV[FADEIN] / tt_aV[FADEINTERVAL])); } tt_ShowIfrm(); }\n' +
- 'function tt_ShowIfrm() { if(tt_ie56) { var ifrm = tt_aElt[tt_aElt.length - 1]; if(ifrm) { var css = ifrm.style; css.zIndex = tt_aElt[0].style.zIndex - 1; css.display = "block"; } } }\n' +
- 'function tt_Move(e) { if(e) { tt_ovr_ = e.target || e.srcElement; } e = e || window.event; if(e) { tt_musX = tt_GetEvtX(e); tt_musY = tt_GetEvtY(e); } if(tt_iState & 0x4) { if(!tt_op && !tt_ie) { if(tt_bWait) { return; } tt_bWait = true; tt_tWaitMov.Timer("tt_bWait = false;", 1, true); } if(tt_aV[FIX]) { tt_iState &= ~0x4; tt_PosFix(); } else if(!tt_ExtCallFncs(e, "MoveBefore")) { tt_SetTipPos(tt_Pos(0), tt_Pos(1)); } tt_ExtCallFncs([tt_musX, tt_musY], "MoveAfter") } }\n' +
- 'function tt_Pos(iDim) { var iX; var bJmpMod; var cmdAlt; var cmdOff; var cx; var iMax; var iScrl; var iMus; var bJmp; if(iDim) { bJmpMod = tt_aV[JUMPVERT]; cmdAlt = ABOVE; cmdOff = OFFSETY; cx = tt_h; iMax = tt_maxPosY; iScrl = tt_GetScrollY(); iMus = tt_musY; bJmp = tt_bJmpVert; } else { bJmpMod = tt_aV[JUMPHORZ]; cmdAlt = LEFT; cmdOff = OFFSETX; cx = tt_w; iMax = tt_maxPosX; iScrl = tt_GetScrollX(); iMus = tt_musX; bJmp = tt_bJmpHorz; } if(bJmpMod) { if(tt_aV[cmdAlt] && (!bJmp || tt_CalcPosAlt(iDim) >= iScrl + 16)) { iX = tt_PosAlt(iDim); } else if(!tt_aV[cmdAlt] && bJmp && tt_CalcPosDef(iDim) > iMax - 16) { iX = tt_PosAlt(iDim); } else { iX = tt_PosDef(iDim); } } else { iX = iMus; if(tt_aV[cmdAlt]) { iX -= cx + tt_aV[cmdOff] - (tt_aV[SHADOW] ? tt_aV[SHADOWWIDTH] : 0); } else { iX += tt_aV[cmdOff]; } } if(iX > iMax) { iX = bJmpMod ? tt_PosAlt(iDim) : iMax; } if(iX < iScrl) { iX = bJmpMod ? tt_PosDef(iDim) : iScrl; } return iX; }\n' +
- 'function tt_PosDef(iDim) { if(iDim) { tt_bJmpVert = tt_aV[ABOVE]; } else { tt_bJmpHorz = tt_aV[LEFT]; } return tt_CalcPosDef(iDim); }\n' +
- 'function tt_PosAlt(iDim) { if(iDim) { tt_bJmpVert = !tt_aV[ABOVE]; } else { tt_bJmpHorz = !tt_aV[LEFT]; } return tt_CalcPosAlt(iDim); } function tt_CalcPosDef(iDim) { return iDim ? (tt_musY + tt_aV[OFFSETY]) : (tt_musX + tt_aV[OFFSETX]); } function tt_CalcPosAlt(iDim) { var cmdOff = iDim ? OFFSETY : OFFSETX; var dx = tt_aV[cmdOff] - (tt_aV[SHADOW] ? tt_aV[SHADOWWIDTH] : 0); if(tt_aV[cmdOff] > 0 && dx <= 0) { dx = 1; } return((iDim ? (tt_musY - tt_h) : (tt_musX - tt_w)) - dx); }\n' +
- 'function tt_PosFix() { var iX; var iY; if(typeof(tt_aV[FIX][0]) == "number") { iX = tt_aV[FIX][0]; iY = tt_aV[FIX][1]; } else { if(typeof(tt_aV[FIX][0]) == "string") { el = tt_GetElt(tt_aV[FIX][0]); } else { el = tt_aV[FIX][0]; } iX = tt_aV[FIX][1]; iY = tt_aV[FIX][2]; if(!tt_aV[ABOVE] && el) { iY += tt_GetDivH(el); } for(; el; el = el.offsetParent) { iX += el.offsetLeft || 0; iY += el.offsetTop || 0; } } if(tt_aV[ABOVE]) { iY -= tt_h; } tt_SetTipPos(iX, iY); }\n' +
- 'function tt_Fade(a, now, z, n) { if(n) { now += Math.round((z - now) / n); if((z > a) ? (now >= z) : (now <= z)) { now = z; } else { tt_tFade.Timer( "tt_Fade(" + a + "," + now + "," + z + "," + (n - 1) + ")", tt_aV[FADEINTERVAL], true ); } } now ? tt_SetTipOpa(now) : tt_Hide(); }\n' +
- 'function tt_SetTipOpa(opa) { tt_SetOpa(tt_aElt[5], opa); if(tt_aElt[1]) { tt_SetOpa(tt_aElt[1], opa); } if(tt_aV[SHADOW]) { opa = Math.round(opa * 0.8); tt_SetOpa(tt_aElt[7], opa); tt_SetOpa(tt_aElt[8], opa); } }\n' +
- 'function tt_OnCloseBtnOver(iOver) { var css = tt_aElt[4].style; iOver <<= 1; css.background = tt_aV[CLOSEBTNCOLORS][iOver]; css.color = tt_aV[CLOSEBTNCOLORS][iOver + 1]; }\n' +
- 'function tt_OnLClick(e) { e = e || window.event; if(!((e.button && e.button & 2) || (e.which && e.which == 3))) { if(tt_aV[CLICKSTICKY] && (tt_iState & 0x4)) { tt_aV[STICKY] = true; tt_iState &= ~0x4; } else if(tt_aV[CLICKCLOSE]) tt_HideInit(); } }\n' +
- 'function tt_Int(x) { var y; return(isNaN(y = parseInt(x)) ? 0 : y); }\n' +
- 'Number.prototype.Timer = function(s, iT, bUrge) { if(!this.value || bUrge) { this.value = window.setTimeout(s, iT); } }\n' +
- 'Number.prototype.EndTimer = function() { if(this.value) { window.clearTimeout(this.value); this.value = 0; } }\n' +
- 'function tt_GetWndCliSiz(s) { var db; var y = window["inner" + s]; var sC = "client" + s; var sN = "number"; if(typeof y == sN) { var y2; return( ((db = document.body) && typeof(y2 = db[sC]) == sN && y2 && y2 <= y) ? y2 : ((db = document.documentElement) && typeof(y2 = db[sC]) == sN && y2 && y2 <= y) ? y2 : y ); } return( ((db = document.documentElement) && (y = db[sC])) ? y : document.body[sC] ); } function tt_SetOpa(el, opa) { var css = el.style; tt_opa = opa; if(tt_flagOpa == 1) { if(opa < 100) { if(typeof(el.filtNo) == tt_u) { el.filtNo = css.filter; } var bVis = css.visibility != "hidden"; css.zoom = "100%"; if(!bVis) { css.visibility = "visible"; } css.filter = "alpha(opacity=" + opa + ")"; if(!bVis) css.visibility = "hidden"; } else if(typeof(el.filtNo) != tt_u) css.filter = el.filtNo; } else { opa /= 100.0; switch(tt_flagOpa) { case 2: css.KhtmlOpacity = opa; break; case 3: css.KHTMLOpacity = opa; break; case 4: css.MozOpacity = opa; break; case 5: css.opacity = opa; break; } } } function tt_Err(sErr, bIfDebug) { if(tt_Debug || !bIfDebug) alert("Tooltip Script Error Message:" + sErr); } function tt_ExtCmdEnum() { var s; for(var i in config) { s = "window." + i.toString().toUpperCase(); if(eval("typeof(" + s + ") == tt_u")) { eval(s + " = " + tt_aV.length); tt_aV[tt_aV.length] = null; } } } function tt_ExtCallFncs(arg, sFnc) { var b = false; for(var i = tt_aExt.length; i;) {--i; var fnc = tt_aExt[i]["On" + sFnc]; if(fnc && fnc(arg)) { b = true; } } return b; } tt_Init();\n';
-
- var script = document.createElement('script');
- script.type="text/javascript";
- script.innerHTML = sTooltip;
- document.getElementsByTagName('head')[0].appendChild(script);
-
- var script = document.createElement('script');
- script.type="text/javascript";
- script.innerHTML = '\nconfig. Delay = 0;\nconfig. Left = true;\nconfig. ShadowWidth = 1;\nconfig. ShadowColor = "#FFFFFF";\nconfig. BgColor = "#000000";\nconfig. BorderWidth = 2;\nconfig. BorderColor = "#FFFFFF";\n' + sAppsTable;
- document.getElementsByTagName('head')[0].appendChild(script);
- }
- } // no chaptcha - end
-
- GM_setValue('LastRunTime',parseInt(StartTime/1000));
-
- })(); // function wrapper