Statistics
| Branch: | Tag: | Revision:

root / snf-astakos-app / astakos / im / api / admin.py @ ec612228

History | View | Annotate | Download (7 kB)

1 aba1e498 Antony Chazapis
# Copyright 2011-2012 GRNET S.A. All rights reserved.
2 7a0c3713 Kostas Papadimitriou
#
3 64cd4730 Antony Chazapis
# Redistribution and use in source and binary forms, with or
4 64cd4730 Antony Chazapis
# without modification, are permitted provided that the following
5 64cd4730 Antony Chazapis
# conditions are met:
6 7a0c3713 Kostas Papadimitriou
#
7 64cd4730 Antony Chazapis
#   1. Redistributions of source code must retain the above
8 64cd4730 Antony Chazapis
#      copyright notice, this list of conditions and the following
9 64cd4730 Antony Chazapis
#      disclaimer.
10 7a0c3713 Kostas Papadimitriou
#
11 64cd4730 Antony Chazapis
#   2. Redistributions in binary form must reproduce the above
12 64cd4730 Antony Chazapis
#      copyright notice, this list of conditions and the following
13 64cd4730 Antony Chazapis
#      disclaimer in the documentation and/or other materials
14 64cd4730 Antony Chazapis
#      provided with the distribution.
15 7a0c3713 Kostas Papadimitriou
#
16 64cd4730 Antony Chazapis
# THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17 64cd4730 Antony Chazapis
# OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 64cd4730 Antony Chazapis
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 64cd4730 Antony Chazapis
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20 64cd4730 Antony Chazapis
# CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 64cd4730 Antony Chazapis
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 64cd4730 Antony Chazapis
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23 64cd4730 Antony Chazapis
# USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 64cd4730 Antony Chazapis
# AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 64cd4730 Antony Chazapis
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 64cd4730 Antony Chazapis
# ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 64cd4730 Antony Chazapis
# POSSIBILITY OF SUCH DAMAGE.
28 7a0c3713 Kostas Papadimitriou
#
29 64cd4730 Antony Chazapis
# The views and conclusions contained in the software and
30 64cd4730 Antony Chazapis
# documentation are those of the authors and should not be
31 64cd4730 Antony Chazapis
# interpreted as representing official policies, either expressed
32 64cd4730 Antony Chazapis
# or implied, of GRNET S.A.
33 64cd4730 Antony Chazapis
34 3a9f4931 Sofia Papagiannaki
import logging
35 3a9f4931 Sofia Papagiannaki
36 18ffbee1 Sofia Papagiannaki
from functools import wraps
37 64cd4730 Antony Chazapis
from time import time, mktime
38 1ae97c83 Sofia Papagiannaki
from urlparse import urlparse
39 6b03a847 Sofia Papagiannaki
from collections import defaultdict
40 1ae97c83 Sofia Papagiannaki
41 64cd4730 Antony Chazapis
from django.http import HttpResponse
42 64cd4730 Antony Chazapis
from django.utils import simplejson as json
43 64cd4730 Antony Chazapis
44 6b03a847 Sofia Papagiannaki
from astakos.im.api.faults import *
45 14c5be5a Sofia Papagiannaki
from astakos.im.api import render_fault
46 6b03a847 Sofia Papagiannaki
from astakos.im.models import AstakosUser, Service
47 09e7393c Sofia Papagiannaki
from astakos.im.util import epoch
48 6b03a847 Sofia Papagiannaki
from astakos.im.api import _get_user_by_email, _get_user_by_username
49 64cd4730 Antony Chazapis
50 3a9f4931 Sofia Papagiannaki
logger = logging.getLogger(__name__)
51 30dc8c1a Sofia Papagiannaki
format = ('%a, %d %b %Y %H:%M:%S GMT')
52 3a9f4931 Sofia Papagiannaki
53 30dc8c1a Sofia Papagiannaki
def api_method(http_method=None, token_required=False, perms=None):
54 18ffbee1 Sofia Papagiannaki
    """Decorator function for views that implement an API method."""
55 30dc8c1a Sofia Papagiannaki
    if not perms:
56 30dc8c1a Sofia Papagiannaki
        perms = []
57 d492d8ae Kostas Papadimitriou
58 18ffbee1 Sofia Papagiannaki
    def decorator(func):
59 18ffbee1 Sofia Papagiannaki
        @wraps(func)
60 18ffbee1 Sofia Papagiannaki
        def wrapper(request, *args, **kwargs):
61 18ffbee1 Sofia Papagiannaki
            try:
62 18ffbee1 Sofia Papagiannaki
                if http_method and request.method != http_method:
63 18ffbee1 Sofia Papagiannaki
                    raise BadRequest('Method not allowed.')
64 18ffbee1 Sofia Papagiannaki
                x_auth_token = request.META.get('HTTP_X_AUTH_TOKEN')
65 18ffbee1 Sofia Papagiannaki
                if token_required:
66 18ffbee1 Sofia Papagiannaki
                    if not x_auth_token:
67 18ffbee1 Sofia Papagiannaki
                        raise Unauthorized('Access denied')
68 18ffbee1 Sofia Papagiannaki
                    try:
69 18ffbee1 Sofia Papagiannaki
                        user = AstakosUser.objects.get(auth_token=x_auth_token)
70 18ffbee1 Sofia Papagiannaki
                        if not user.has_perms(perms):
71 30dc8c1a Sofia Papagiannaki
                            raise Forbidden('Unauthorized request')
72 18ffbee1 Sofia Papagiannaki
                    except AstakosUser.DoesNotExist, e:
73 18ffbee1 Sofia Papagiannaki
                        raise Unauthorized('Invalid X-Auth-Token')
74 18ffbee1 Sofia Papagiannaki
                    kwargs['user'] = user
75 18ffbee1 Sofia Papagiannaki
                response = func(request, *args, **kwargs)
76 18ffbee1 Sofia Papagiannaki
                return response
77 18ffbee1 Sofia Papagiannaki
            except Fault, fault:
78 18ffbee1 Sofia Papagiannaki
                return render_fault(request, fault)
79 18ffbee1 Sofia Papagiannaki
            except BaseException, e:
80 18ffbee1 Sofia Papagiannaki
                logger.exception('Unexpected error: %s' % e)
81 18ffbee1 Sofia Papagiannaki
                fault = InternalServerError('Unexpected error')
82 18ffbee1 Sofia Papagiannaki
                return render_fault(request, fault)
83 18ffbee1 Sofia Papagiannaki
        return wrapper
84 18ffbee1 Sofia Papagiannaki
    return decorator
85 18ffbee1 Sofia Papagiannaki
86 18ffbee1 Sofia Papagiannaki
@api_method(http_method='GET', token_required=True)
87 18ffbee1 Sofia Papagiannaki
def authenticate_old(request, user=None):
88 64cd4730 Antony Chazapis
    # Normal Response Codes: 204
89 863193cb Sofia Papagiannaki
    # Error Response Codes: internalServerError (500)
90 64cd4730 Antony Chazapis
    #                       badRequest (400)
91 64cd4730 Antony Chazapis
    #                       unauthorised (401)
92 18ffbee1 Sofia Papagiannaki
    if not user:
93 18ffbee1 Sofia Papagiannaki
        raise BadRequest('No user')
94 d492d8ae Kostas Papadimitriou
95 18ffbee1 Sofia Papagiannaki
    # Check if the is active.
96 18ffbee1 Sofia Papagiannaki
    if not user.is_active:
97 18ffbee1 Sofia Papagiannaki
        raise Unauthorized('User inactive')
98 1ae97c83 Sofia Papagiannaki
99 18ffbee1 Sofia Papagiannaki
    # Check if the token has expired.
100 18ffbee1 Sofia Papagiannaki
    if (time() - mktime(user.auth_token_expires.timetuple())) > 0:
101 18ffbee1 Sofia Papagiannaki
        raise Unauthorized('Authentication expired')
102 d492d8ae Kostas Papadimitriou
103 09e7393c Sofia Papagiannaki
    if not user.signed_terms():
104 18ffbee1 Sofia Papagiannaki
        raise Unauthorized('Pending approval terms')
105 d492d8ae Kostas Papadimitriou
106 18ffbee1 Sofia Papagiannaki
    response = HttpResponse()
107 18ffbee1 Sofia Papagiannaki
    response.status=204
108 18ffbee1 Sofia Papagiannaki
    user_info = {'username':user.username,
109 18ffbee1 Sofia Papagiannaki
                 'uniq':user.email,
110 18ffbee1 Sofia Papagiannaki
                 'auth_token':user.auth_token,
111 18ffbee1 Sofia Papagiannaki
                 'auth_token_created':user.auth_token_created.isoformat(),
112 18ffbee1 Sofia Papagiannaki
                 'auth_token_expires':user.auth_token_expires.isoformat(),
113 18ffbee1 Sofia Papagiannaki
                 'has_credits':user.has_credits,
114 8569eb53 Sofia Papagiannaki
                 'has_signed_terms':user.signed_terms(),
115 8569eb53 Sofia Papagiannaki
                 'groups':[g.name for g in user.groups.all()]}
116 18ffbee1 Sofia Papagiannaki
    response.content = json.dumps(user_info)
117 18ffbee1 Sofia Papagiannaki
    response['Content-Type'] = 'application/json; charset=UTF-8'
118 18ffbee1 Sofia Papagiannaki
    response['Content-Length'] = len(response.content)
119 18ffbee1 Sofia Papagiannaki
    return response
120 18ffbee1 Sofia Papagiannaki
121 18ffbee1 Sofia Papagiannaki
@api_method(http_method='GET', token_required=True)
122 18ffbee1 Sofia Papagiannaki
def authenticate(request, user=None):
123 18ffbee1 Sofia Papagiannaki
    # Normal Response Codes: 204
124 18ffbee1 Sofia Papagiannaki
    # Error Response Codes: internalServerError (500)
125 18ffbee1 Sofia Papagiannaki
    #                       badRequest (400)
126 18ffbee1 Sofia Papagiannaki
    #                       unauthorised (401)
127 18ffbee1 Sofia Papagiannaki
    if not user:
128 18ffbee1 Sofia Papagiannaki
        raise BadRequest('No user')
129 d492d8ae Kostas Papadimitriou
130 18ffbee1 Sofia Papagiannaki
    # Check if the is active.
131 18ffbee1 Sofia Papagiannaki
    if not user.is_active:
132 18ffbee1 Sofia Papagiannaki
        raise Unauthorized('User inactive')
133 18ffbee1 Sofia Papagiannaki
134 18ffbee1 Sofia Papagiannaki
    # Check if the token has expired.
135 18ffbee1 Sofia Papagiannaki
    if (time() - mktime(user.auth_token_expires.timetuple())) > 0:
136 18ffbee1 Sofia Papagiannaki
        raise Unauthorized('Authentication expired')
137 d492d8ae Kostas Papadimitriou
138 09e7393c Sofia Papagiannaki
    if not user.signed_terms():
139 18ffbee1 Sofia Papagiannaki
        raise Unauthorized('Pending approval terms')
140 d492d8ae Kostas Papadimitriou
141 18ffbee1 Sofia Papagiannaki
    response = HttpResponse()
142 18ffbee1 Sofia Papagiannaki
    response.status=204
143 18ffbee1 Sofia Papagiannaki
    user_info = {'userid':user.username,
144 18ffbee1 Sofia Papagiannaki
                 'email':[user.email],
145 18ffbee1 Sofia Papagiannaki
                 'name':user.realname,
146 18ffbee1 Sofia Papagiannaki
                 'auth_token':user.auth_token,
147 18ffbee1 Sofia Papagiannaki
                 'auth_token_created':epoch(user.auth_token_created),
148 18ffbee1 Sofia Papagiannaki
                 'auth_token_expires':epoch(user.auth_token_expires),
149 18ffbee1 Sofia Papagiannaki
                 'has_credits':user.has_credits,
150 18ffbee1 Sofia Papagiannaki
                 'is_active':user.is_active,
151 18ffbee1 Sofia Papagiannaki
                 'groups':[g.name for g in user.groups.all()]}
152 18ffbee1 Sofia Papagiannaki
    response.content = json.dumps(user_info)
153 18ffbee1 Sofia Papagiannaki
    response['Content-Type'] = 'application/json; charset=UTF-8'
154 18ffbee1 Sofia Papagiannaki
    response['Content-Length'] = len(response.content)
155 18ffbee1 Sofia Papagiannaki
    return response
156 7a0c3713 Kostas Papadimitriou
157 ce70ac01 Sofia Papagiannaki
@api_method(http_method='GET', token_required=True, perms=['im.can_access_userinfo'])
158 30dc8c1a Sofia Papagiannaki
def get_user_by_email(request, user=None):
159 30dc8c1a Sofia Papagiannaki
    # Normal Response Codes: 200
160 18ffbee1 Sofia Papagiannaki
    # Error Response Codes: internalServerError (500)
161 18ffbee1 Sofia Papagiannaki
    #                       badRequest (400)
162 18ffbee1 Sofia Papagiannaki
    #                       unauthorised (401)
163 30dc8c1a Sofia Papagiannaki
    #                       forbidden (403)
164 30dc8c1a Sofia Papagiannaki
    #                       itemNotFound (404)
165 30dc8c1a Sofia Papagiannaki
    email = request.GET.get('name')
166 6b03a847 Sofia Papagiannaki
    return _get_user_by_email(email)
167 18ffbee1 Sofia Papagiannaki
168 ce70ac01 Sofia Papagiannaki
@api_method(http_method='GET', token_required=True, perms=['im.can_access_userinfo'])
169 30dc8c1a Sofia Papagiannaki
def get_user_by_username(request, user_id, user=None):
170 30dc8c1a Sofia Papagiannaki
    # Normal Response Codes: 200
171 18ffbee1 Sofia Papagiannaki
    # Error Response Codes: internalServerError (500)
172 18ffbee1 Sofia Papagiannaki
    #                       badRequest (400)
173 18ffbee1 Sofia Papagiannaki
    #                       unauthorised (401)
174 30dc8c1a Sofia Papagiannaki
    #                       forbidden (403)
175 30dc8c1a Sofia Papagiannaki
    #                       itemNotFound (404)
176 35f8ccf1 Sofia Papagiannaki
    return _get_user_by_username(user_id)