Skip to content

Latest commit

 

History

History
117 lines (90 loc) · 2.87 KB

README.md

File metadata and controls

117 lines (90 loc) · 2.87 KB

Azel

Or how to have fun with the internet

Azel is a python library equivalent to the Elza Perl macro-language (HTTP scripting)

It basically allows you to automatize sequences of HTTP requests and to script around it (without having to care about sessions / redirections / randomly generated input fields)...

Usage

Initialization

import azel
a = azel.Azel()

Query a website

a.get('http://www.lescigales.org') # promo never hurts !

Specify a proxy to use

a.proxyHost = '10.7.0.1'
a.proxyPort = 8118

Collect links from a web page:

getLink(re.pattern) will return the href of the first link match getLinks(re.pattern) will return a list of links

a.get('http://sk.php.net/')
dl = a.getLink('downloads')
a.get(dl)
links = a.getLinks('PHP 5.')
for link in links:
    print link.href, link.value, link.title

    # Download the first link                                                                    
    a.get(link.href)
    l = a.getLink('sk.php.net')
    a.get(l)

    tarball = a.read() # thats right babe, we just got php's tarball                              
    break

Pre-fill a form

a.get('https://gist.github.com/')
a.fillForm()
print a.data # this will return the prefilled form data

Post a form (and publish cool stuff on gist)

a.get('http://gist.github.com/')
a.fillForm()

a.data['file_ext[gistfile1]'] = '.py'
a.data['file_name[gistfile1]'] = __file__.strip('./')
a.data['description'] = 'This was published by awesome azel!'
a.data['file_contents[gistfile1]'] = content

a.post('') # will post the first form

will produce the following output:

-> GET http://gist.github.com/
<- 301 Moved Permanently
-> GET https://gist.github.com/
<- 200 OK
-> POST https://gist.github.com/gists
<- 302 Found
-> GET https://gist.github.com/2491246
<- 200 OK

Annoy the hell of an asshole by trashing his blog:

blog = azel.Azel()
final = []
blog.get('http://strepoetlo.legtux.org/')
links = blog.getLinks('/#respond')
for l in links: final.append(l.href)
links = blog.getLinks('/#comments')
for l in links: final.append(l.href)
previous = blog.getLink('Previous')
blog.get(previous)
links = blog.getLinks('/#respond')
for l in links: final.append(l.href)
links = blog.getLinks('/#comments')
for l in links: final.append(l.href)

for link in final:
    print link
    blog.get(link)
    blog.fillForm()
    post = 'http://strepoetlo.legtux.org/wp-comments-post.php'
    s = 'http://forum.lescigales.org/topic1638-site-de-phishing-httpstrepoetlolescigalesorg-par-strepoetlo.html'
    blog.data['author'] = 'Paul Gonsolin'
    blog.data['url'] = 'http://strepoetlo.lescigales.org/'
    blog.data['email'] = 'no-reply@lescigales.org'
    blog.data['comment'] = 'Createur de sites de phishing Facebook, priere de ne plus venir sur lesCigales.ORG. -> <a href="'+s+'">'+s+'</a>'
    blog.post(post)