Seguro que te interesa (GitHub behind the scenes – parte 1)
Esta entrada es un poco atípica, realmente no es más que una excusa para presentaros el nuevo repositorio en GitHub de esta web.
Poco a poco quiero ir ofreciendo los scripts que me hacen la vida más sencilla y que pueden ayudaros en ciertas tareas. Para estrenar el repo, he pensado en contar cómo hago la entrada de los Viernes en las que os listo las noticias que me han parecido más interesantes de la semana.
Tras unas cuantas entradas en las que iba recopilando enlaces a mano, decidí que así no podía continuar. Como dice un gran amigo, soy muy vago, pero vago de los buenos. Eso me hace pensar en cómo automatizar absolutamente todo lo que hago para que las tareas repetitivas las haga una CPU y yo pueda centrarme en ideas felices o a imaginar qué isla me compraré cuando me toque la lotería.
Gracias a lo de internet, tiro de Twitter para estar al tanto de las noticias de última hora y suelo hacer retweet de lo que me llama la atención. Noticias, herramientas, análisis, humor… pero todo relacionado con lo que me apasiona, la seguridad de la información.
Como últimamente le he cogido cariño a Python (al pitón como le llamo alegremente por la oficina de Dive), decidí tirar de un poco de crawling vía BeautifulSoup para buscar en twitter ciertos elementos.
Básicamente lo que hago es abrir la página de Twitter de SecurityInside y busco todos los retweets. De cada uno, me quedo con los elementos interesantes (título, autor, imágen y texto) y los pongo en forma de tabla para que se vea de forma decente como una entrada del blog. Básicamente esto:
# Get retweet info # --------------------------------------------------------------------------------------- req = requests.get(url) statusCode = req.status_code if statusCode == 200: html = BeautifulSoup(req.text, "html.parser") for timeline in html.find_all('div', {'data-test-selector':'ProfileTimeline'}): for oltag in timeline.find_all('ol', {'id':'stream-items-id'}): for litag in oltag.find_all('li'): for div in litag.find_all('div', {"class" : "tweet"}): try: if div['data-retweet-id']: for small in litag.find_all('small', {"class" : "time"}): for a in small.find_all('a', {"class" : "tweet-timestamp"}): try: date = a['title'].encode("ascii", "ignore") except Exception as e: None title = div.find('p', {'class':'TweetTextSize'}).getText().split('http')[0].encode("ascii", "ignore") link = div.find('a', {'class':'twitter-timeline-link'}).getText().encode("ascii", "ignore") name = div.find('span', {'class':'username'}).getText().split('@')[1].encode("ascii", "ignore") for img in div.find_all('img'): if 'avatar' in img: image = 'http://securityinside.info/wp-content/uploads/logo.png' else: image = img['src'].encode("ascii", "ignore") print '<tr><td style="vertical-align:middle;border:0px;margin: 0px 0px"><img class="aligncenter" src="' + image + '" alt="' + name + '" width="150"/></td>\n<td style="vertical-align:middle;border:0px;margin: 0px 0px"><strong><a href="https://twitter.com/' + name + '" target="_blank">' + date + ' @' + name + ':<br></a></strong> <a href="' + link + '" target="_blank">' + title + '</a></td></tr>' except Exception as e: None else: print "Status Code %d" %statusCode
Como podéis ver, sólo tengo que copiar la línea que me genera el script e insertarla en la entrada. La tarea se completa añadiendo el texto habitual y configurando las categorías, la imágen y los valores SEO.
Vale, me vais a decir que eso también se puede automatizar. La respuesta es que si, por eso os dejo pendiente la segunda parte del artículo en la que dedicaré otro rato a generar la entrada completa (insertando en base de datos y demás).
Pero poco a poco, que estoy un poco liado gestionando los backups anti malware de la junta directiva… pero eso es otra historia que os voy a contar en breve.
¿Os lo vais a perder?
- HIPAA: Protegiendo la Privacidad y Seguridad de la información médica con AWS - 13 septiembre, 2024
- 8 Recomendaciones básicas para mejorar la seguridad de tu cuenta AWS - 16 junio, 2024
- Una introducción a los contenedores: ECS y EKS en AWS - 16 abril, 2024