This file is indexed.

/usr/share/pyshared/archipelagentiphonenotification/notifications.py is in archipel-agent-iphone-notification 0.6.0-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
#!/usr/bin/env python

# Copyright (c) 2009, Thomas Jost <thomas.jost@gmail.com>
#
# Permission  to use,  copy, modify,  and/or  distribute this  software for  any
# purpose  with  or without  fee  is hereby  granted,  provided  that the  above
# copyright notice and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS"  AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
# REGARD TO  THIS SOFTWARE INCLUDING  ALL IMPLIED WARRANTIES  OF MERCHANTABILITY
# AND FITNESS. IN  NO EVENT SHALL THE AUTHOR BE LIABLE  FOR ANY SPECIAL, DIRECT,
# INDIRECT, OR  CONSEQUENTIAL DAMAGES OR  ANY DAMAGES WHATSOEVER  RESULTING FROM
# LOSS OF USE, DATA OR PROFITS,  WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
# OTHER  TORTIOUS ACTION,  ARISING  OUT OF  OR  IN CONNECTION  WITH  THE USE  OR
# PERFORMANCE OF THIS SOFTWARE.

"""Client for the iPhone/iPod Touch `Notifications' app.

This  module helps  scripts to  use  the HTTP  REST API  of the  `Notifications'
application, which is  available for the iPhone and the  iPod Touch. It supports
finding  the  user's credentials  token,  and  then  sending notification  in  a
synchronous or asynchronous way. This modules provides three functions:

get_credentials() -- Get the user's credentials token
send() -- Send a notification, waiting for it to be sent.
send_async() -- Send a  notification, returning immediately, without waiting for
the message to be sent.

"""

__author__ = "Thomas Jost <thomas.jost@gmail.com>"
__version__ = "0.1"


import thread
import urllib
import xml.dom.minidom

CREDENTIALS_URL = "https://www.appnotifications.com/user_session.xml"
SEND_URL = "https://www.appnotifications.com/account/notifications.xml"

def get_credentials(email, password):
    """Get the user's credentials token."""

    # Create data to POST
    data = {
        'user_session[email]': email,
        'user_session[password]': password
    }
    data = urllib.urlencode(data)

    # Send them
    u = urllib.urlopen(SEND_URL, data)
    success = (u.getcode() == 200)
    if not success: return False

    # Parse the XML response
    response = u.read()
    u.close()
    doc = xml.dom.minidom.parseString(response)
    token = doc.getElementsByTagName("single-access-token")
    if len(token) == 0: return False
    return token[0].firstChild.data


def send(credentials, message, title=None, long_message=None, subtitle=None,
         long_message_preview=None, message_level=0, silent=False,
         action_loc_key=None, run_command=None, sound=1, icon_url=None, debug=False):
    """Send a notification, waiting for the message to be sent.

    The first two arguments (credentials  and message) are mandatory, all of the
    others are optional. They are  the same as the various identifiers described
    in    the   documentation    of    the   Notifications    HTTP   REST    API
    (http://appnotifications.com/account/rest_api).

    When  `debug` is  set  to `True`,  the XML  result  of the  HTTP request  is
    displayed on `sys.stderr`.

    This  function  returns  a  boolean  indicating  if  the  message  was  sent
    successfuly.

    """
    try:
        # Create data to POST
        data = {}

        if credentials is None or credentials == "":
            raise ValueError("Invalid user credentials")
        if message is None or message == "":
            raise ValueError("Invalid message")

        data['user_credentials'] = credentials
        data['notification[message]'] = message

        for key in ("title", "long_message", "long_message_preview",
                    "message_level", "action_loc_key", "run_command", "icon_url", "subtitle"):
            value = locals()[key]
            if value is not None:
                data['notification[%s]' % key] = value

        if silent:
            data['notification[silent]'] = 1
        else:
            data['notification[silent]'] = 0
            if not 1 <= sound <= 7:
                raise ValueError("sound must be an integer between 1 and 7")
            data['notification[sound]'] = "%d.caf" % sound

        # Encode the data
        data = urllib.urlencode(data)

        # Send the notification
        u = urllib.urlopen(SEND_URL, data)
        success = (u.getcode() == 200)
        if debug:
            print >> sys.stderr, u.read()
        u.close()

        return success
    except:
        pass


def send_async(*args, **kwargs):
    """Send  a  notification, returning  immediately,  without  waiting for  the
    message to be sent.

    This function does return the ID of the thread that does the HTTP request.

    """
    return thread.start_new_thread(send, args, kwargs)


if __name__ == '__main__':
    import sys, time

    if len(sys.argv) != 3:
        print >> sys.stderr, "Syntax: %s credentials message" % sys.argv[0]
    else:
        send_async(sys.argv[1], sys.argv[2], title="MyTITLE", debug=True)
        time.sleep(5)