;(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

Geisy Arruda é proibida de comer em Portugal após problema em site do SUS

Geisy Arruda ou por perrengue para comprovar vacinação em dia contra o coronavírus após queda do site do SUS - Imagem: Reprodução/Instagram@geisy_arruda
Geisy Arruda ou por perrengue para comprovar vacinação em dia contra o coronavírus após queda do site do SUS Imagem: Imagem: Reprodução/Instagram@geisy_arruda

Colaboração para Splash, em Alagoas

13/12/2021 15h46

A influenciadora digital Geisy Arruda, de 32 anos, relatou que enfrentou dificuldades para se alimentar em Portugal, por não conseguir comprovar que está com a vacinação contra o coronavírus em dia, após problemas no site do SUS (Sistema Único de Saúde) que saiu do ar na semana ada, devido ao ataque de hackers.

Por meio de seu perfil no Twitter, a famosa contou que foi a um estabelecimento para se alimentar, mas eles não conseguiram ler seu aporte de vacina, devido ao fato de o SUS permanecer "fora do ar". Ainda, ela diz ter sido "proibida" de comer.

"A mulher não conseguiu ler meu aporte de vacina. O E-São Paulo não se lê aqui. O do SUS está fora do ar. [Ela] não me vendeu comida. Disse que eu tinha que fazer um [teste] PCR, um PCR para comer! Eu quero minha mãe, meu país", publicou Geisy Arruda ao falar sobre o "perrengue" no país europeu.

Os sites do Ministério da Saúde e do ConecteSUS estão fora do ar após um ataque hacker na última sexta-feira (10). Segundo o governo federal, alguns sistemas foram comprometidos e a PF (Polícia Federal) e o GSI (Gabinete de Segurança Institucional) da Presidência da República foram acionados para investigar o caso.

Em nota oficial, a Saúde usou o termo "incidente", mas o ministro Marcelo Queiroga confirmou que foi um ataque cibernético. Ele afirmou que "os dados não serão perdidos", e que há backup dos dados.

O Ministério da Saúde informou que está atuando com "máxima agilidade" para reestabelecer os sistemas e a expectativa" é que tudo seja resolvido nesta semana.