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

Planalto está "tratando o assunto", diz Bolsonaro sobre cerco ao Telegram

Hanrrikson de Andrade

Do UOL, em Brasília

27/01/2022 12h07Atualizada em 27/01/2022 15h16

O governo federal está "tratando o assunto", disse hoje o presidente Jair Bolsonaro (PL) ao ser questionado sobre o cerco do MPF (Ministério Público Federal) ao Telegram. Suscetível ao compartilhamento de fake news, o aplicativo de mensagens pode vir a ser alvo de medidas judiciais de curto prazo —e até mesmo suspensões temporárias— no Brasil.

Sem explicar os detalhes sobre quais ações poderiam ser tomadas pelo Planalto para interferir na questão, Bolsonaro declarou apenas que "a gente está vendo aqui". E complementou: "É uma covardia que estão querendo fazer com o Brasil, né. Covardia, né".

O Telegram é hoje uma das principais ferramentas na estratégia de comunicação do presidente da República, que também pretende utilizá-la como meio de divulgação durante a campanha eleitoral deste ano —ele deve confirmar em breve a candidatura à reeleição.

O canal de Bolsonaro no Telegram tem mais de 1 milhão de inscritos. O presidente sempre valorizou a força das mídias digitais e considera que só venceu a eleição em 2018 devido ao engajamento nas redes. À época, o pleito foi marcado por polêmicas relacionadas a fake news e disparo em massa de mensagens via WhatsApp.

Diferentemente do mensageiro WhatsApp, que pertence ao grupo Meta, do americano Mark Zuckerberg, o Telegram não possibilita mecanismos tão eficientes de controle e prevenção quanto ao compartilhamento de fake news. O aplicativo que caiu no gosto dos bolsonaristas foi desenvolvido pelo programador russo Pavel Durov, que não tem manifestado interesse em dialogar com o TSE (Tribunal Superior Eleitoral) para debater possíveis iniciativas.

A preocupação do chefe do TSE, o ministro Luis Roberto Barroso, é que o aplicativo russo acabe se tornando um vetor de notícias falsas e desinformação durante as eleições de 2022 no país.

Diálogo dificultado

No dia 6 de janeiro, o procurador do MPF em São Paulo Yuri Corrêa da Luz, responsável por um inquérito sobre o assunto, oficiou diversas plataformas e redes sociais para a notificação de espaços para denúncias de notícias falsas, que até o momento, permaneciam indisponíveis no Brasil.

Enquanto empresas como Facebook e Twitter anunciavam suas ferramentas, o Telegram continuou distante de negociações e maiores esclarecimentos no país. Pelo serviço não contar com escritório em território brasileiro e tampouco responder às solicitações de informação, os membros da Procuradoria de São Paulo consideram que será preciso "adotar qualquer providência necessária neste contexto", já que o silêncio é um sinal claro de que a empresa não irá colaborar.

"O problema é que, neste caso do Telegram, nós não estamos falando de uma postura em defesa de usuários", afirmou o procurador Yuri Luz ao Estadão.

Para o responsável pelo inquérito, o sinal se torna muito grave pois o TSE não solicitou dados de usuários, mas sim, uma conversa aberta. "Ele (Barroso) está pedindo para sentar e conversar, e isso não está sendo atendido. No caso do MPF, tampouco estamos pedindo dados. Solicitamos informações como o relatório de transparência. Não há perseguição de usuários."