Ejemplo n.º 1
0
    def put(self, jid):
        # Grab the PUT request parameter (the Broadcasting User)
        param_target = self.request.get('target')

        # Create a Key for the User whose Broadcast is being affected
        key_user = db.Key.from_path('User', param_target)

        # Retrieve the User object for the Broadcasting User
        broadcasting_user = db.get(key_user)

        # Create a Key for the Confirmed User to be added
        key_confirmed = db.Key.from_path('User', jid)

        # Check if Confirmed User is already Confirmed
        if key_confirmed not in broadcasting_user.proposal_confirmed:
            # Add Key of Confirmed User to Broadcasting User
            broadcasting_user.proposal_confirmed.append(key_confirmed)

            # Add jid of Confirmed User to Broadcasting User
            broadcasting_user.proposal_confirmed_jids.append(jid)

            #################### Because Confirmed and Interested are mutually exclusive
            #################### We're removing you from Interested here as well, to prevent
            #################### having two requests with one client toggle switch
            if key_confirmed in broadcasting_user.proposal_interested:
                broadcasting_user.proposal_interested.remove(key_confirmed)
                self.response.write("key " + jid + " removed from interested")
            else:
                self.response.write("key " + jid + " was never interested")

            if jid in broadcasting_user.proposal_interested_jids:
                broadcasting_user.proposal_interested_jids.remove(jid)
                self.response.write(jid + " removed from interested jids")
            else:
                self.response.write(jid + " was never interested jids")

            # Save it back into the datastore.
            broadcasting_user.put()

            # Make list of Users to tickle
            users = []
            for broadcastee_key in broadcasting_user.outgoing_broadcasts:
                users.append(db.get(broadcastee_key))
            users.append(broadcasting_user)

            tickle_users(users, broadcasting_user)

            self.response.write("User " + jid + " is now Confirmed for " +
                                broadcasting_user.first_name +
                                "'s Proposal.\n")
        else:
            self.response.write("User " + jid + " was ALREADY Confirmed for " +
                                broadcasting_user.first_name +
                                "'s Proposal, idiot!!!\n")
        return
Ejemplo n.º 2
0
    def put(self, jid):
        try:
            #    self.response.write("test\n")
            # Grab the PUT request parameters and put them into variables.
            param_description = self.request.get('des')
            param_location = self.request.get('loc')
            param_time = self.request.get('time')

            # Create the Key for the User query we're about to perform
            key_user = db.Key.from_path('User', jid)

            # Retrieve the User object using the Key
            user = db.get(key_user)

            # Modify the User's fields
            user.proposal_description = param_description
            user.proposal_location = param_location
            user.proposal_time = param_time
            user.proposal_interested = []
            user.proposal_confirmed = []
            user.proposal_interested_jids = []
            user.proposal_confirmed_jids = []

            # Modify Broadcastees proposals_seen_jids fields
            for key in user.outgoing_broadcasts:
                broadcastee = db.get(key)
            if jid in broadcastee.proposals_seen_jids:
                broadcastee.proposals_seen_jids.remove(jid)
                broadcastee.put()
            else:
                self.response.write(key.name() + " not in " +
                                    broadcastee.first_name +
                                    "'s seen proposals\n")

            # Save it back into the datastore.
            user.put()

            # Make list of Users to tickle
            users = []

            for broadcastee_key in user.outgoing_broadcasts:
                users.append(db.get(broadcastee_key))
            users.append(user)

            tickle_users(users, user)

            # Tell the user.
            self.response.write("Updated %s's proposal to %s.\n" %
                                (user.first_name, user.proposal_description))

        except (TypeError, ValueError):
            # If we had an error, then show it
            self.response.write('Invalid inputs\n')
            return
Ejemplo n.º 3
0
    def put(self, jid):
        # Grab the PUT request parameter (the Broadcasting User)
        param_target = self.request.get('target')

        # Create a Key for the User whose Broadcast is being affected
        key_user = db.Key.from_path('User', param_target)

        # Retrieve the User object for the Broadcasting User
        broadcasting_user = db.get(key_user)

        # Create a Key for the Interested User to be added
        key_interested = db.Key.from_path('User', jid)

        # Check if Interested User is already Interested
        if key_interested not in broadcasting_user.proposal_interested:
            # Add Key of Interested User to Broadcasting User
            broadcasting_user.proposal_interested.append(key_interested)

            # Add jid of Interested User to Broadcasting User
            broadcasting_user.proposal_interested_jids.append(jid)

            # Save it back into the datastore.
            broadcasting_user.put()

            # Make list of Users to tickle
            users = []
            for broadcastee_key in broadcasting_user.outgoing_broadcasts:
                users.append(db.get(broadcastee_key))
            users.append(broadcasting_user)

            tickle_users(users, broadcasting_user)

            self.response.write("User " + jid + " is now Interested in " +
                                broadcasting_user.first_name +
                                "'s Proposal.\n")
        else:
            self.response.write("User " + jid + " was ALREADY Interested in " +
                                broadcasting_user.first_name +
                                "'s Proposal, idiot!!\n")
        self.response.write("[ ")
        for element in broadcasting_user.proposal_interested_jids:
            self.response.write(element + " ")
        self.response.write("]\n")
        return
Ejemplo n.º 4
0
    def delete(self, jid):

        key_user = db.Key.from_path('User', jid)

        user = db.get(key_user)

        user.status_color = None
        user.status_expiration_date = None

        user.put()

        # Make list of Users to tickle
        users = []
        for broadcastee_key in user.outgoing_broadcasts:
            users.append(db.get(broadcastee_key))

        tickle_users(users, user)

        self.response.write("Deleted %s's status.\n" % user.first_name)
Ejemplo n.º 5
0
    def delete(self, jid):
        # Grab the DELETE request parameter (the Broadcasting User)
        param_target = self.request.get('target')

        # Create a Key for the User whose Broadcast is being affected
        key_user = db.Key.from_path('User', param_target)

        # Retrieve the User object for the Broadcasting User
        broadcasting_user = db.get(key_user)

        # Create a Key for the Confirmed User to be removed
        key_confirmed = db.Key.from_path('User', jid)

        # Check if Confirmed User to be removed is Confirmed to begin with
        if key_confirmed in broadcasting_user.proposal_confirmed:
            # Remove Key of Confirmed User from Broadcasting User
            broadcasting_user.proposal_confirmed.remove(key_confirmed)

            # Add jid of Confirmed User from Broadcasting User
            broadcasting_user.proposal_confirmed_jids.remove(jid)

            # Save it back into the datastore.
            broadcasting_user.put()

            # Make list of Users to tickle
            users = []
            for broadcastee_key in broadcasting_user.outgoing_broadcasts:
                users.append(db.get(broadcastee_key))
            users.append(broadcasting_user)

            tickle_users(users, broadcasting_user)

            self.response.write("User " + jid +
                                " is no longer Confirmed for " +
                                broadcasting_user.first_name +
                                "'s Proposal.\n")
        else:
            self.response.write("User " + jid + " wasn't even Confirmed for " +
                                broadcasting_user.first_name +
                                "'s Proposal, idiot!!!\n")
        return
Ejemplo n.º 6
0
    def put(self, jid):
        try:
            # Grab the PUT request parameters and put them into variables.
            param_color = self.request.get('color')
            param_exp = self.request.get('exp')
            param_status_text = self.request.get('text')

            # Create the Key for the User query we're about to perform
            key_user = db.Key.from_path('User', jid)

            # Retrieve the User object using the Key
            user = db.get(key_user)

            # Modify the User's fields
            # TODO: Sanity check statuses to ensure that they're a valid color.
            user.status_color = param_color
            user.status_expiration_date = param_exp
            user.status_description = param_status_text

            # Save it back into the datastore.
            user.put()

            # Make list of Users to tickle
            users = []
            for broadcastee_key in user.outgoing_broadcasts:
                users.append(db.get(broadcastee_key))

            tickle_users(users, user)

            # Tell the user.
            self.response.write("Updated %s's status to %s.\n" %
                                (user.first_name, user.status_color))

        except (TypeError, ValueError):
            # If we had an error, then show it
            self.response.write('Invalid inputs')
            return
Ejemplo n.º 7
0
    def delete(self, jid):

        key_user = db.Key.from_path('User', jid)

        user = db.get(key_user)

        user.proposal_description = None
        user.proposal_location = None
        user.proposal_time = None
        user.proposal_interested = []
        user.proposal_confirmed = []
        user.proposal_interested_jids = []
        user.proposal_confirmed_jids = []

        user.put()

        # Modify Broadcastees proposals_seen_jids fields
        for key in user.outgoing_broadcasts:
            broadcastee = db.get(key)
            if jid in broadcastee.proposals_seen_jids:
                broadcastee.proposals_seen_jids.remove(jid)
                broadcastee.put()
            else:
                self.response.write(key.name() + " not in " +
                                    broadcastee.first_name +
                                    "'s seen proposals\n")

        # Make list of Users to tickle
        users = []
        for broadcastee_key in user.outgoing_broadcasts:
            users.append(db.get(broadcastee_key))
        users.append(user)

        tickle_users(users, user)

        self.response.write("Deleted %s's proposal.\n" % user.first_name)