;(function() { window.createMeasureObserver = (measureName) => { var markPrefix = `_uol-measure-${measureName}-${new Date().getTime()}`; performance.mark(`${markPrefix}-start`); return { end: function() { performance.mark(`${markPrefix}-end`); performance.measure(`uol-measure-${measureName}`, `${markPrefix}-start`, `${markPrefix}-end`); performance.clearMarks(`${markPrefix}-start`); performance.clearMarks(`${markPrefix}-end`); } } }; /** * Gerenciador de eventos */ window.gevent = { stack: [], RUN_ONCE: true, on: function(name, callback, once) { this.stack.push([name, callback, !!once]); }, emit: function(name, args) { for (var i = this.stack.length, item; i--;) { item = this.stack[i]; if (item[0] === name) { item[1](args); if (item[2]) { this.stack.splice(i, 1); } } } } }; var runningSearch = false; var hadAnEvent = true; var elementsToWatch = window.elementsToWatch = new Map(); var innerHeight = window.innerHeight; // timestamp da última rodada do requestAnimationFrame // É usado para limitar a procura por elementos visíveis. var lastAnimationTS = 0; // verifica se elemento está no viewport do usuário var isElementInViewport = function(el) { var rect = el.getBoundingClientRect(); var clientHeight = window.innerHeight || document.documentElement.clientHeight; // renderizando antes, evitando troca de conteúdo visível no chartbeat-related-content if(el.className.includes('related-content-front')) return true; // garante que usa ao mínimo 280px de margem para fazer o lazyload var margin = clientHeight + Math.max(280, clientHeight * 0.2); // se a base do componente está acima da altura da tela do usuário, está oculto if(rect.bottom < 0 && rect.bottom > margin * -1) { return false; } // se o topo do elemento está abaixo da altura da tela do usuário, está oculto if(rect.top > margin) { return false; } // se a posição do topo é negativa, verifica se a altura dele ainda // compensa o que já foi scrollado if(rect.top < 0 && rect.height + rect.top < 0) { return false; } return true; }; var asynxNextFreeTime = () => { return new Promise((resolve) => { if(window.requestIdleCallback) { window.requestIdleCallback(resolve, { timeout: 5000, }); } else { window.requestAnimationFrame(resolve); } }); }; var asyncValidateIfElIsInViewPort = function(promise, el) { return promise.then(() => { if(el) { if(isElementInViewport(el) == true) { const cb = elementsToWatch.get(el); // remove da lista para não ser disparado novamente elementsToWatch.delete(el); cb(); } } }).then(asynxNextFreeTime); }; // inicia o fluxo de procura de elementos procurados var look = function() { if(window.requestIdleCallback) { window.requestIdleCallback(findByVisibleElements, { timeout: 5000, }); } else { window.requestAnimationFrame(findByVisibleElements); } }; var findByVisibleElements = function(ts) { var elapsedSinceLast = ts - lastAnimationTS; // se não teve nenhum evento que possa alterar a página if(hadAnEvent == false) { return look(); } if(elementsToWatch.size == 0) { return look(); } if(runningSearch == true) { return look(); } // procura por elementos visíveis apenas 5x/seg if(elapsedSinceLast < 1000/5) { return look(); } // atualiza o último ts lastAnimationTS = ts; // reseta status de scroll para não entrar novamente aqui hadAnEvent = false; // indica que está rodando a procura por elementos no viewport runningSearch = true; const done = Array.from(elementsToWatch.keys()).reduce(asyncValidateIfElIsInViewPort, Promise.resolve()); // obtém todos os elementos que podem ter view contabilizados //elementsToWatch.forEach(function(cb, el) { // if(isElementInViewport(el) == true) { // // remove da lista para não ser disparado novamente // elementsToWatch.delete(el); // cb(el); // } //}); done.then(function() { runningSearch = false; }); // reinicia o fluxo de procura look(); }; /** * Quando o elemento `el` entrar no viewport (-20%), cb será disparado. */ window.lazyload = function(el, cb) { if(el.nodeType != Node.ELEMENT_NODE) { throw new Error("element parameter should be a Element Node"); } if(typeof cb !== 'function') { throw new Error("callback parameter should be a Function"); } elementsToWatch.set(el, cb); } var setEvent = function() { hadAnEvent = true; }; window.addEventListener('scroll', setEvent, { capture: true, ive: true }); window.addEventListener('click', setEvent, { ive: true }); window.addEventListener('resize', setEvent, { ive: true }); window.addEventListener('load', setEvent, { once: true, ive: true }); window.addEventListener('DOMContentLoaded', setEvent, { once: true, ive: true }); window.gevent.on('allJSLoadedAndCreated', setEvent, window.gevent.RUN_ONCE); // inicia a validação look(); })();
  • AssineUOL
Topo

Esse conteúdo é antigo

EUA acusam Rússia de realizar ataques cibernéticos contra Ucrânia

Do UOL, em São Paulo

18/02/2022 18h01

Os Estados Unidos acusaram a Rússia, nesta sexta-feira (18), de realizar ataques cibernéticos contra o Ministério da Defesa da Ucrânia e grandes bancos locais, segundo informaram a rede de TV americana CNN e a agência de notícias AP (Associated Press).

O anúncio de Anne Neuberger, vice-conselheira de Segurança Nacional, foi a atribuição mais apontada de responsabilidade por ataques cibernéticos que se desenrolaram à medida que as tensões aumentam entre a Rússia e a Ucrânia.

Segundo Neuberger, além de sites de dois grande bancos, os ataques derrubaram sites governamentais mas com "impacto limitado", já que as autoridades ucranianas conseguiram colocar seus sistemas em funcionamento rapidamente. Ela, no entanto, alerta que é possível que os russos estejam preparando as bases para ataques mais destrutivos.

A Rússia gosta de se mover nas sombras e conta com um longo processo de atribuição (...) À luz disso, estamos agindo rapidamente para atribuir os ataques. Acreditamos que o governo russo é responsável por ataques generalizados a bancos ucranianos esta semana. Anne Neuberger

Neuberger disse ainda que os norte-americanos têm dados que mostram que a infraestrutura conectada à agência militar da Rússia, geralmente conhecida como GRU, "foi vista transmitindo grandes volumes de comunicação para endereços e domínios IP baseados na Ucrânia".

A Rússia negou qualquer participação, em contato com a agência de notícias Reuters.

Tensão no Leste Europeu

A Rússia tem mais de 190 mil soldados, tanques e mísseis concentrados ao longo da fronteira ucraniana, mas nega a intenção de invadir o país vizinho. No entanto, o regime de Vladimir Putin reclama de uma eventual adesão de Kiev à Otan (Organização do Tratado do Atlântico Norte), aliança militar criada para fazer frente à extinta União Soviética.

Para Putin, a Otan é uma ameaça à segurança da Rússia por sua expansão na região. Por isso, o presidente quer uma declaração formal de que a Ucrânia nunca vai se filiar à aliança.

Em contrapartida, os Estados Unidos e países aliados do Ocidente (como o Reino Unido, França e a Alemanha) têm dito repetidas vezes que a Rússia pode invadir a Ucrânia "a qualquer momento" e ameaçam o país com "sanções econômicas severas" e "resposta ágil", caso a invasão ocorra.

Moscou, por sua vez, acusa os países ocidentais —em especial os Estados Unidos— de fazerem "histeria e alarmismo" sobre um ataque russo à Ucrânia, o que, segundo eles, não estaria em seus planos.

A Rússia já anexou a península ucraniana da Crimeia em 2014, o que culminou em sanções econômicas dos EUA e da União Europeia. O país também é acusado de financiar os rebeldes pró-Moscou que controlam as autoproclamadas Repúblicas de Lugansk e Donetsk, na região de Donbass.

*Com informações da agência Reuters