Beispiel #1
0
    def delete(self, user_id):
        self.request_parser.add_argument('password',
                                         type=str,
                                         required=True,
                                         help='No password is provided')
        args = self.request_parser.parse_args()
        password = args['password']

        if not password:
            return make_response('Password is mandatory!', 400)

        user = service.get_user_by_id(user_id)

        if user is None:
            return make_response('User ' + str(user_id) + ' does not exist!',
                                 404)
        else:
            existing_password_entry = \
                service.find_user_password_by_email(user.email)
            if not existing_password_entry.verify_password(password):
                logger.warn(
                    'Cannot delete user %s (%s): '
                    'wrong password provided', user_id, user.email)
                return make_response('Wrong password', 400)
            service.delete_user(user.email)
            logger.info('Deleted user %s (%s)', user_id, user.email)
            return redirect('/')
Beispiel #2
0
    def delete(self, user_id):
        self.request_parser.add_argument('password',
                                         type=str,
                                         required=True,
                                         help='No password is provided')
        args = self.request_parser.parse_args()
        password = args['password']

        if not password:
            return make_response('Password is mandatory!', 400)

        user = service.get_user_by_id(user_id)

        if user is None:
            return make_response('User ' + str(user_id) + ' does not exist!',
                                 404)
        else:
            existing_password_entry = \
                service.find_user_password_by_email(user.email)
            if not existing_password_entry.verify_password(password):
                logger.warn('Cannot delete user %s (%s): '
                            'wrong password provided',
                            user_id, user.email)
                return make_response('Wrong password', 400)
            service.delete_user(user.email)
            logger.info('Deleted user %s (%s)', user_id, user.email)
            return redirect('/')
Beispiel #3
0
    def post(self, user_id):
        """
        Updates user information.
        :param user_id
        :return: Flask response
        """
        self.request_parser.add_argument('confirm',
                                         type=str,
                                         required=False)
        self.request_parser.add_argument('source',
                                         type=str,
                                         required=False)
        self.request_parser.add_argument('name',
                                         type=unicode,
                                         required=False)
        self.request_parser.add_argument('last_name',
                                         type=unicode,
                                         required=False)
        self.request_parser.add_argument('profession',
                                         type=unicode,
                                         required=False)
        self.request_parser.add_argument('birthday',
                                         type=str,
                                         required=False)
        args = self.request_parser.parse_args()
        user = service.get_user_by_id(user_id)
        if not user:
            return make_response('User with id ' + str(user_id) +
                                 ' does not exist.', 404)

        confirm_hash = args['confirm']
        if confirm_hash:
            if service.confirm_email(user, confirm_hash):
                logger.info('User %s confirmed their email %s', user.id,
                            user.email)
                login_user(user)
                if args['source']:
                    return redirect(args['source'])
                else:
                    return redirect('/')
            else:
                logger.warn('User with email %s tried to confirm their '
                            'email with wrong hash (expected %s - got %s)',
                            user.email, user.confirmation_hash,
                            confirm_hash)
                return make_response('The confirmation email link is wrong! '
                                     'The email cannot be confirmed.', 400)

        user_updated = service.update_user(args, user)

        if user_updated:
            return make_response('User has been updated', 201)
        else:
            return make_response('No request parameters specified!', 400)
Beispiel #4
0
    def post(self, user_id):
        """
        Updates user information.
        :param user_id
        :return: Flask response
        """
        self.request_parser.add_argument('confirm', type=str, required=False)
        self.request_parser.add_argument('source', type=str, required=False)
        self.request_parser.add_argument('name', type=unicode, required=False)
        self.request_parser.add_argument('last_name',
                                         type=unicode,
                                         required=False)
        self.request_parser.add_argument('profession',
                                         type=unicode,
                                         required=False)
        self.request_parser.add_argument('birthday', type=str, required=False)
        args = self.request_parser.parse_args()
        user = service.get_user_by_id(user_id)
        if not user:
            return make_response(
                'User with id ' + str(user_id) + ' does not exist.', 404)

        confirm_hash = args['confirm']
        if confirm_hash:
            if service.confirm_email(user, confirm_hash):
                logger.info('User %s confirmed their email %s', user.id,
                            user.email)
                login_user(user)
                if args['source']:
                    return redirect(args['source'])
                else:
                    return redirect('/')
            else:
                logger.warn(
                    'User with email %s tried to confirm their '
                    'email with wrong hash (expected %s - got %s)', user.email,
                    user.confirmation_hash, confirm_hash)
                return make_response(
                    'The confirmation email link is wrong! '
                    'The email cannot be confirmed.', 400)

        user_updated = service.update_user(args, user)

        if user_updated:
            return make_response('User has been updated', 201)
        else:
            return make_response('No request parameters specified!', 400)
Beispiel #5
0
    def get(self, user_id):
        """
        Render the user page.
        :param user_id
        :return: Flask response
        """
        user = service.get_user_by_id(user_id)
        if not user:
            return make_response(
                'User with id ' + str(user_id) + ' does not exist.', 404)

        user_data, user_locations = service.get_user_data_to_display(user)

        headers = {'Content-Type': 'text/html'}
        return make_response(
            render_template('user_page.html',
                            user=user_data,
                            locations=user_locations), 200, headers)
Beispiel #6
0
    def get(self, user_id):
        """
        Render the user page.
        :param user_id
        :return: Flask response
        """
        user = service.get_user_by_id(user_id)
        if not user:
            return make_response('User with id ' + str(user_id) +
                                 ' does not exist.', 404)

        user_data, user_locations = service.get_user_data_to_display(user)

        headers = {'Content-Type': 'text/html'}
        return make_response(
            render_template('user_page.html', user=user_data,
                            locations=user_locations),
            200,
            headers
        )