Пример #1
0
    def test_bing_img(self):
        """ Bing Images
        """
        r = Referer(
            """http://www.bing.com/images/search?q=psychic+oracle+cards&view=det\
ail&id=D268EDDEA8D3BF20AF887E62AF41E8518FE96F08""")
        self.check_equals(r, 'Bing Images', 'psychic oracle cards', 'search')
Пример #2
0
 def test_internal(self):
     r = Referer("http://www.snowplowanalytics.com/about/team",
                 "http://www.snowplowanalytics.com/account/profile")
     self.assertTrue(r.known)
     self.assertEqual(r.medium, 'internal')
     self.assertIsNone(r.search_term)
     self.assertIsNone(r.referer)
Пример #3
0
    def get_ips(self, time_frame, given_time):
        """
        Devuelve una lista con cada una de las IP's detectadas durante los 'time_frame' minutos previos a la hora
        'given_time'. Acompañando a cara IP irá una marca de verificación (True/False), que indicará si la detección
        de esa IP es concluyente o es necesaria la confirmación del positivo por parte de otro plugin.
        """
        ip_list = []
        if not self.enabled:
            return ip_list
        delta_frame = timedelta(minutes=time_frame)

        line_parser = apache_log_parser.make_parser(
            self.__webbug_log_format.decode('string_escape'))
        for remoteaddr in self.__webbug_log:

            addr = urlparse.urlparse(
                remoteaddr)  # Se obtiene el nombre del fichero de eventos
            filename = "data/wb-" + addr.hostname + '-' + self.person + "-events.log"

            with open(filename, 'r') as f:

                linea = f.readline(
                )  # Detección de zona horaria en la primera linea del log
                if linea:
                    p = re.compile(r"[\+|-]\d\d\d\d\]")
                    tz = p.findall(linea)[0]
                    timezone = timedelta(hours=int(tz[0:3]),
                                         minutes=int(tz[0] + tz[3:5]))

                while True:
                    if not linea:
                        break
                    log_line_data = line_parser(linea)
                    line_time_utc = log_line_data[
                        'time_received_datetimeobj'] - timezone

                    if line_time_utc > given_time:
                        break

                    if line_time_utc > given_time - delta_frame:
                        ip = log_line_data['remote_host']
                        ip_only_list = [a[0] for a in ip_list]
                        origin = urlparse.urlparse(
                            log_line_data['request_first_line']).hostname
                        ref = Referer(log_line_data['request_header_referer'])
                        if not ip_only_list.count(ip):
                            if (ref.medium == 'search') and (ref.search_term
                                                             is not None):
                                ip_list.append([ip, True, origin
                                                ])  # IP nueva, la añadimos
                            else:
                                ip_list.append([ip, False, origin])
                        elif origin != ip_list[ip_only_list.index(ip)][2]:
                            ip_list[ip_only_list.index(
                                ip
                            )][1] = True  # IP repetida en página distinta, es un positivo

                    linea = f.readline()

        return [c[0:2] for c in ip_list]
Пример #4
0
    def test_mailru_search(self):
        """ Mail.ru search
        """
        r = Referer(
            """http://go.mail.ru/search?q=Gothic%20Tarot%20Cards&where=any&num=1\
0&rch=e&sf=20""")
        self.check_equals(r, 'Mail.ru', 'Gothic Tarot Cards', 'search')
Пример #5
0
    def test_yahoo_mail(self):
        """ Yahoo! Mail
        """
        r = Referer(
            """http://36ohk6dgmcd1n-c.c.yom.mail.yahoo.net/om/api/1.0/openmail.a\
pp.invoke/36ohk6dgmcd1n/11/1.0.35/us/en-US/view.html/0""")
        self.check_no_term(r, 'Yahoo! Mail', 'email')
Пример #6
0
    def test_fb_social(self):
        """ Facebook social
        """
        r = Referer(
            """http://www.facebook.com/l.php?u=http%3A%2F%2Fwww.psychicbazaar.co\
m&h=yAQHZtXxS&s=1""")
        self.check_no_term(r, 'Facebook', 'social')
Пример #7
0
    def test_orange_webmail(self):
        """ Orange Webmail
        """
        r = Referer(
            """http://webmail1m.orange.fr/webmail/fr_FR/read.html?FOLDER=SF_INBO\
X&IDMSG=8594&check=&SORTBY=31""")
        self.check_no_term(r, 'Orange Webmail', 'email')
Пример #8
0
    def test_aol_search(self):
        """ AOL search
        """
        r = Referer(
            """http://aolsearch.aol.co.uk/aol/search?s_chn=hp&enabled_terms=&s_i\
t=aoluk-homePage50&q=pendulums""")
        self.check_equals(r, 'AOL', 'pendulums', 'search')
Пример #9
0
    def get_report_data(self, time_frame, given_time, confirmed_ips):
        """
        Devuelve una lista con cada una de las detecciones durante los 'time_frame' minutos previos a
        la hora 'given_time'. Cada elemento contiene la hora de la detección, el sitio donde se detectó,
        la ip del footprinter, la puntuación y un texto descriptivo sobre la misma.
        """
        report_list = []
        if not self.enabled:
            return report_list
        delta_frame = timedelta(minutes=time_frame)

        for remoteaddr in self.__access_log:

            addr = urlparse.urlparse(
                remoteaddr)  # Se obtiene el nombre del fichero de eventos
            filename = "data/st-" + addr.hostname + '-' + self.person + "-events.log"
            line_parser = apache_log_parser.make_parser\
                (self.__access_log_format[self.__access_log.index(remoteaddr)].decode('string_escape'))

            with open(filename, 'r') as f:

                linea = f.readline(
                )  # Detección de zona horaria en la primera linea del log
                if linea:
                    p = re.compile(r"[\+|-]\d\d\d\d\]")
                    tz = p.findall(linea)[0]
                    timezone = timedelta(hours=int(tz[0:3]),
                                         minutes=int(tz[0] + tz[3:5]))

                while True:
                    if not linea:
                        break
                    log_line_data = line_parser(linea)

                    if confirmed_ips.count(log_line_data['remote_host']):

                        line_time_utc = log_line_data[
                            'time_received_datetimeobj'] - timezone

                        if line_time_utc > given_time:
                            break
                        if line_time_utc > given_time - delta_frame:
                            ref = Referer(
                                log_line_data['request_header_referer'])
                            sterms = ref.search_term.decode('utf-8')
                            sengine = ref.referer.decode('utf-8')
                            description = u'Una busqueda desde [' + sengine + u'] con los terminos: [' + sterms + \
                                          u'] ha llegado a [' + addr.hostname + ']'

                            report_list.append([
                                line_time_utc, log_line_data['remote_host'],
                                description, 'Search Engines'
                            ])

                    linea = f.readline()

        if report_list:
            return sorted(report_list, key=itemgetter(0))
        else:
            return report_list
Пример #10
0
    def get_report_data(self, time_frame, given_time, confirmed_ips):
        """
        Devuelve una lista con cada una de las detecciones durante los 'time_frame' minutos previos a
        la hora 'given_time'. Cada elemento contiene la hora de la detección, el sitio donde se detectó,
        la ip del footprinter, la puntuación y un texto descriptivo sobre la misma.
        """
        report_list = []
        if not self.enabled:
            return report_list
        delta_frame = timedelta(minutes=time_frame)

        addr = urlparse.urlparse(
            self.__access_log)  # Se obtiene el nombre del fichero de eventos
        filename = "data/bl-" + addr.hostname + '-' + self.person + "-events.log"
        line_parser = apache_log_parser.make_parser\
            (self.__access_log_format.decode('string_escape'))

        with open(filename, 'r') as f:

            linea = f.readline(
            )  # Detección de zona horaria en la primera linea del log
            if linea:
                p = re.compile(r"[\+|-]\d\d\d\d\]")
                tz = p.findall(linea)[0]
                timezone = timedelta(hours=int(tz[0:3]),
                                     minutes=int(tz[0] + tz[3:5]))

            while True:
                if not linea:
                    break
                log_line_data = line_parser(linea)

                if confirmed_ips.count(log_line_data['remote_host']):

                    line_time_utc = log_line_data[
                        'time_received_datetimeobj'] - timezone

                    if line_time_utc > given_time:
                        break
                    if line_time_utc > given_time - delta_frame:
                        ref = (log_line_data['request_header_referer'])
                        if ref != "-":
                            host = Referer(ref)
                            description = u'Se ha usado la redirección ' + log_line_data['request_url'] + u' desde '\
                                          + host.uri.netloc
                        else:
                            description = u'Se ha usado la redirección ' + log_line_data[
                                'request_url']
                        report_list.append([
                            line_time_utc, log_line_data['remote_host'],
                            description, 'Bait Link'
                        ])

                linea = f.readline()

        if report_list:
            return sorted(report_list, key=itemgetter(0))
        else:
            return report_list
Пример #11
0
    def test_odnoklassniki(self):
        """ Odnoklassniki
        """
        r = Referer(
            """http://www.odnoklassniki.ru/dk?cmd=logExternal&st._aid=Conversati\
ons_Openlink&st.name=externalLinkRedirect&st.link=http%3A%2F%2Fwww.psychicbazaar.com%2Fo\
racles%2F187-blue-angel-oracle.html""")
        self.check_no_term(r, 'Odnoklassniki', 'social')
Пример #12
0
    def test_price_runner_search(self):
        """ PriceRunner search
        """
        r = Referer(
            """http://www.pricerunner.co.uk/search?displayNoHitsMessage=1&q=wild\
+wisdom+of+the+faery+oracle""")
        self.check_equals(r, 'PriceRunner', 'wild wisdom of the faery oracle',
                          'search')
Пример #13
0
    def test_google_term(self):
        """ Google search #2
        """
        r = Referer(
            'http://www.google.com/search?q=gateway+oracle+cards+denise+linn&hl=\
en&client=safari')
        self.check_equals(r, 'Google', 'gateway oracle cards denise linn',
                          'search')
Пример #14
0
    def test_ask_search(self):
        """ Ask search
        """
        r = Referer(
            """http://uk.search-results.com/web?qsrc=1&o=1921&l=dis&q=pendulums&\
dm=ctry&atb=sysid%3D406%3Aappid%3D113%3Auid%3D8f40f651e7b608b5%3Auc%3D1346336505%3Aqu%3D\
pendulums%3Asrc%3Dcrt%3Ao%3D1921&locale=en_GB""")
        self.check_equals(r, 'Ask', 'pendulums', 'search')
Пример #15
0
 def test_ixquick(self):
     """ IXquick search
     """
     r = Referer("""https://s3-us3.ixquick.com/do/search""")
     self.assertTrue(r.known)
     self.assertEqual(r.referer, 'IXquick')
     self.assertIsNone(r.search_term)
     self.assertEqual(r.medium, 'search')
Пример #16
0
    def test_fb_mobile(self):
        """ Facebook mobile
        """
        r = Referer(
            """http://m.facebook.com/l.php?u=http%3A%2F%2Fwww.psychicbazaar.com%\
2Fblog%2F2012%2F09%2Fpsychic-bazaar-reviews-tarot-foundations-31-days-to-read-tarot-with\
-confidence%2F&h=kAQGXKbf9&s=1""")
        self.check_no_term(r, 'Facebook', 'social')
Пример #17
0
    def test_yahoo_search(self):
        """ Yahoo! search
        """
        r = Referer(
            """http://es.search.yahoo.com/search;_ylt=A7x9QbwbZXxQ9EMAPCKT.Qt.?p=\
BIEDERMEIER+FORTUNE+TELLING+CARDS&ei=utf-8&type=685749&fr=chr-greentree_gc&xargs=0&pstar\
t=1&b=11""")
        self.check_equals(r, 'Yahoo!', 'BIEDERMEIER FORTUNE TELLING CARDS',
                          'search')
Пример #18
0
    def test_yandex_search(self):
        """ Yandex search
        """
        r = Referer(
            """http://images.yandex.ru/yandsearch?text=Blue%20Angel%20Oracle%20B\
lue%20Angel%20Oracle&noreask=1&pos=16&rpt=simage&lr=45&img_url=http%3A%2F%2Fmdm.pbzstati\
c.com%2Foracles%2Fblue-angel-oracle%2Fbox-small.png""")
        self.check_equals(r, 'Yandex Images',
                          'Blue Angel Oracle Blue Angel Oracle', 'search')
Пример #19
0
 def test_google_minimal(self):
     """ Google search #1
     """
     r = Referer('http://www.google.com/search')
     # r.known, r.referer, r.search_term, r.medium
     self.assertTrue(r.known)
     self.assertEqual(r.referer, 'Google')
     self.assertIsNone(r.search_term)
     self.assertEqual(r.medium, 'search')
Пример #20
0
    def test_powered_by_google(self):
        """ Powered by Google
        """
        r = Referer(
            """http://isearch.avg.com/pages/images.aspx?q=tarot+card+change&sap=\
dsp&lang=en&mid=209215200c4147d1a9d6d1565005540b-b0d4f81a8999f5981f04537c5ec8468fd523459\
3&cid=%7B50F9298B-C111-4C7E-9740-363BF0015949%7D&v=12.1.0.21&ds=AVG&d=7%2F23%2F2012+10%3\
A31%3A08+PM&pr=fr&sba=06oENya4ZG1YS6vOLJwpLiFdjG91ICt2YE59W2p5ENc2c4w8KvJb5xbvjkj3ceMjny\
TSpZq-e6pj7GQUylIQtuK4psJU60wZuI-8PbjX-OqtdX3eIcxbMoxg3qnIasP0ww2fuID1B-p2qJln8vBHxWztkp\
xeixjZPSppHnrb9fEcx62a9DOR0pZ-V-Kjhd-85bIL0QG5qi1OuA4M1eOP4i_NzJQVRXPQDmXb-CpIcruc2h5FE9\
2Tc8QMUtNiTEWBbX-QiCoXlgbHLpJo5Jlq-zcOisOHNWU2RSHYJnK7IUe_SH6iQ.%2CYT0zO2s9MTA7aD1mNjZmZ\
DBjMjVmZDAxMGU4&snd=hdr&tc=test1""")
        self.check_equals(r, 'Google', 'tarot card change', 'search')
Пример #21
0
    def test_google_img_search(self):
        """ Google Images search
        """
        r = Referer(
            """http://www.google.fr/imgres?q=Ogham+the+celtic+oracle&hl=fr&safe=\
off&client=firefox-a&hs=ZDu&sa=X&rls=org.mozilla:fr-FR:unofficial&tbm=isch&prmd=imvnsa&t\
bnid=HUVaj-o88ZRdYM:&imgrefurl=http://www.psychicbazaar.com/oracles/101-ogham-the-celtic\
-oracle-set.html&docid=DY5_pPFMliYUQM&imgurl=http://mdm.pbzstatic.com/oracles/ogham-the-\
celtic-oracle-set/montage.png&w=734&h=250&ei=GPdWUIePCOqK0AWp3oCQBA&zoom=1&iact=hc&vpx=1\
29&vpy=276&dur=827&hovh=131&hovw=385&tx=204&ty=71&sig=104115776612919232039&page=1&tbnh=\
69&tbnw=202&start=0&ndsp=26&ved=1t:429,r:13,s:0,i:114&biw=1272&bih=826""")
        self.check_equals(r, 'Google Images', 'Ogham the celtic oracle',
                          'search')
Пример #22
0
def clean_referer_host(referer_host):
    try:
        r = Referer(referer_host)
    except Exception as e:
        return ''

    if r.medium == "email":
        return "email"
    elif r.medium == "search":
        return _replace_referer_with(r, SEARCH_MEDIUM_REFERERS)
    elif r.medium == "unknown":
        return _replace_referer_with(r, UNKNOWN_MEDIUM_REFERERS)
    else:
        return _strip_www(r.uri.netloc)
Пример #23
0
    def test_yahoo_img_search(self):
        """ Yahoo! Images search
        """
        r = Referer(
            """http://it.images.search.yahoo.com/images/view;_ylt=A0PDodgQmGBQpn\
4AWQgdDQx.;_ylu=X3oDMTBlMTQ4cGxyBHNlYwNzcgRzbGsDaW1n?back=http%3A%2F%2Fit.images.search.\
yahoo.com%2Fsearch%2Fimages%3Fp%3DEarth%2BMagic%2BOracle%2BCards%26fr%3Dmcafee%26fr2%3Dp\
iv-web%26tab%3Dorganic%26ri%3D5&w=1064&h=1551&imgurl=mdm.pbzstatic.com%2Foracles%2Fearth\
-magic-oracle-cards%2Fcard-1.png&rurl=http%3A%2F%2Fwww.psychicbazaar.com%2Foracles%2F143\
-earth-magic-oracle-cards.html&size=2.8+KB&name=Earth+Magic+Oracle+Cards+-+Psychic+Bazaa\
r&p=Earth+Magic+Oracle+Cards&oid=f0a5ad5c4211efe1c07515f56cf5a78e&fr2=piv-web&fr=mcafee&\
tt=Earth%2BMagic%2BOracle%2BCards%2B-%2BPsychic%2BBazaar&b=0&ni=90&no=5&ts=&tab=organic&\
sigr=126n355ib&sigb=13hbudmkc&sigi=11ta8f0gd&.crumb=IZBOU1c0UHU""")
        self.check_equals(r, 'Yahoo! Images', 'Earth Magic Oracle Cards',
                          'search')
Пример #24
0
 def test_tumblr(self):
     """ Tumblr social #1
     """
     r = Referer("http://www.tumblr.com/dashboard")
     self.check_no_term(r, 'Tumblr', 'social')
Пример #25
0
    def get_data(self, already_downloaded_sources):
        """
        Descarga los archivos access.log y almacena las detecciones en el archivo [servidor]-[nombreusuario]-events.log
        """
        self.fetched_data = []
        if not self.enabled:
            return False

        for remoteaddr in self.__access_log:

            addr = urlparse.urlparse(remoteaddr)

            url_downloaded = [
                downloaded[0] for downloaded in already_downloaded_sources
            ]
            sremoteaddr = addr.scheme + "://" + addr.hostname + addr.path
            if url_downloaded.count(
                    sremoteaddr
            ):  # Si el fichero ya ha sido descargado por otro plugin, se copia
                already_downloaded_file = already_downloaded_sources[
                    url_downloaded.index(sremoteaddr)]
                self.fetched_data.append(already_downloaded_file)
                self.__logger.info('Reusado %s de %s descargado recientemente',
                                   addr.path, addr.hostname)

            else:  # Si no es así, se descarga
                filename = "temp/wp-" + addr.hostname + '-' + self.person + "-access.log"
                localfile = open(filename, 'wb')
                try:
                    remotefile = urllib.urlopen(remoteaddr)
                    localfile.write(remotefile.read())
                    remotefile.close()
                    self.fetched_data.append([
                        addr.scheme + "://" + addr.hostname + addr.path,
                        filename
                    ])
                    self.__logger.info('Descargado %s de %s', addr.path,
                                       addr.hostname)
                except:
                    self.__logger.error('Error obteniendo %s de %s', addr.path,
                                        addr.hostname)

                localfile.close()

        for fdownloaded in self.fetched_data:
            line_parser = apache_log_parser.make_parser\
                (self.__access_log_format[self.fetched_data.index(fdownloaded)].decode('string_escape'))

            ftemp_accesslog = open(fdownloaded[1], 'r')
            addr = urlparse.urlparse(fdownloaded[0])
            fevents_filename = "data/wp-" + addr.hostname + '-' + self.person + "-events.log"

            try:  # lee la fecha y hora de la última linea, si es que existe el archivo
                with open(fevents_filename, "rb") as sf:
                    sfirstline = sf.readline()
                    sf.seek(-2, 2)
                    try:
                        while sf.read(1) != "\n":
                            sf.seek(-2, 1)
                        slastline = sf.readline()
                    except IOError:
                        slastline = sfirstline
                last_event_logged = line_parser(slastline)
                last_event_logged_time = last_event_logged[
                    'time_received_datetimeobj']
            except IOError:
                last_event_logged_time = datetime(1, 1, 1, 1, 1, 1)

            fevents = open(fevents_filename, 'a')

            while True:
                linea = ftemp_accesslog.readline()
                if not linea:
                    break
                log_line_data = line_parser(linea)
                referer_url = log_line_data['request_header_referer']
                if (last_event_logged_time < log_line_data['time_received_datetimeobj']) and \
                        (referer_url != "-") and (referer_url != ""):
                    ref = Referer(referer_url)

                    for url in self.__pages:
                        matching_url = urlparse.urlparse(url)

                        if (ref.medium == 'search') \
                                and (ref.search_term is None)\
                                and (addr.hostname == matching_url.hostname)\
                                and ((log_line_data['request_url'] == matching_url.path)
                                     or ((log_line_data['request_url'] == '/') and (matching_url.path == ''))):
                            fevents.write(linea)

            ftemp_accesslog.close()
            fevents.close()

        if self.fetched_data:
            return True
Пример #26
0
def _clean_event_data(site_id, date, query, headers=None, real_ip=None):
    is_first = True
    domain = None
    search_engine = None
    search_term = None
    country = constants.UNKNOWN_COUNTRY
    copied_keywords = []

    event = query.get('e_c')
    source = query.get('e_a')
    tool = query.get('e_t')
    uuid = query.get('e_u')
    url = query.get('e_n')
    title = query.get('e_i')
    timestamp = query.get('e_v')
    keywords_string = query.get('e_k')

    headers = headers or {}
    site_config = SiteSettingsCache.get_config(site_id)

    try:
        event = constants.Events(event).value
    except ValueError:
        raise IncorrectEventException('Incorrect event value: %s' % event)

    if timestamp:
        try:
            date = datetime.utcfromtimestamp(int(timestamp))
        except (ValueError, TypeError):
            raise IncorrectEventException('Unexpected timestamp format: %s' %
                                          timestamp)
    date = date + timedelta(minutes=site_config['offset'])

    if source and source not in constants.SOURCE_SET:
        raise IncorrectEventException('Incorrect source value: %s' % source)

    if tool:
        try:
            tool = constants.Tools(tool).value
        except ValueError:
            raise IncorrectEventException('Incorrect tool value: %s' % tool)

    if uuid:
        is_first = _create_unique_user(uuid, date)

    user_agent = parse(headers.get('HTTP_USER_AGENT', ''))
    browser = user_agent.browser.family
    referrer = headers.get('HTTP_REFERER')
    if referrer:
        r = Referer(referrer)
        domain = r.uri.netloc
        search_engine = r.referer
        search_term = r.search_term
    if real_ip:
        geoip_data = get_geoip_data(real_ip)
        if geoip_data and geoip_data['country_code']:
            country = geoip_data['country_code']
    if keywords_string:
        copied_keywords = get_keywords(keywords_string, ALLOWED_KEYWORD_TAGS)

    cleaned_data = dict(site=int(site_id),
                        date=date,
                        source=source,
                        tool=tool,
                        url=url,
                        title=title,
                        browser=browser,
                        domain=domain,
                        search_engine=search_engine,
                        search_term=search_term,
                        country=country,
                        copied_keywords=copied_keywords)
    return event, is_first, cleaned_data
Пример #27
0
 def test_twitter_redirect(self):
     """ Twitter redirect
     """
     r = Referer("""http://t.co/chrgFZDb""")
     self.check_no_term(r, 'Twitter', 'social')
Пример #28
0
 def test_tumblr_subdomain(self):
     """ Tumblr w subdomain
     """
     r = Referer("http://psychicbazaar.tumblr.com/")
     self.check_no_term(r, 'Tumblr', 'social')
Пример #29
0
 def test_outlookcom_mail(self):
     """ Outlook.com mail
     """
     r = Referer(
         "http://co106w.col106.mail.live.com/default.aspx?rru=inbox")
     self.check_no_term(r, 'Outlook.com', 'email')
Пример #30
0
 def test_invalid_url(self):
     r = Referer("https:/")
     self.check_no_term(r, None, 'unknown')