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

Chico Alves

REPORTAGEM

Texto que relata acontecimentos, baseado em fatos e dados observados ou verificados diretamente pelo jornalista ou obtidos pelo o a fontes jornalísticas reconhecidas e confiáveis.

Por voto impresso, bolsonaristas batem recorde de uso de robôs no Twitter

ES - VOTO/IMPRESSO - POLÍTICA - Manifestação pelo voto impresso no Espírito Santo neste domingo (1). - VINICIUS MORAES/ESTADÃO CONTEÚDO
ES - VOTO/IMPRESSO - POLÍTICA - Manifestação pelo voto impresso no Espírito Santo neste domingo (1). Imagem: VINICIUS MORAES/ESTADÃO CONTEÚDO

Colunista do UOL

02/08/2021 10h18Atualizada em 04/08/2021 13h36

A ofensiva de ontem dos bolsonaristas pelo voto impresso não teve somente manifestações em algumas cidades brasileiras e pronunciamento golpista do presidente Jair Bolsonaro. Contou também com o reforço de contas inautênticas, os chamados robôs, que fizeram postagens referentes ao tema no Twitter em quantidade fora do normal. A hashtag "brasilpelovotoauditavel" foi usada 2.444 vezes, segundo a plataforma Bot Sentinel. É o recorde do ano.

Ao todo, hashtags de grupos bolsonaristas utilizaram esse recurso 3.207 vezes no domingo, 1. Lemas como "hojevaisergigante", "votoimpressoauditavelja", "bolsonaropresidenteate2026" e outros serviram para fazer o assunto chegar ao topo do ranking de temas mais comentados no Twitter.

A Bot Sentinel é uma plataforma criada nos Estados Unidos para identificar postagens no Twitter de contas inautênticas e conteúdos tóxicos. Esses perfis podem ser de contas automatizadas ou de humanos que istram dezenas de contas ao mesmo tempo, para dar a impressão de que formam um grupo maior do que realmente são.

O Twitter enviou à coluna a seguinte nota sobre o assunto naquarta-feira, 4: "Após tomar conhecimento da publicação da coluna, o Twitter solicitou os dados do levantamento (como as @s dos perfis considerados robôs), mas não os obteve. O envio das informações possibilitaria a condução de uma investigação interna e, se fosse o caso, a tomada de medidas cabíveis nas contas que eventualmente estivessem em violação de suas regras de automação e spam. Como não teve o aos dados, o Twitter não pode comentá-lo de forma específica, mas esclarece que aplicativos de terceiros que utilizam a nossa API pública para tentar adivinhar se contas utilizam automação indevidamente para interferir no debate têm se mostrado metodologicamente falhos porque só am sinais externos das contas, informações muito limitadas em relação àquelas de que o Twitter dispõe para determinar se uma conta é ou não uma automação indevida. Tais ferramentas, por sua limitação metodológica, podem levar a falsos-positivos".