Merge remote-tracking branch 'origin/newstyles' into newstyles
[astakos] / snf-astakos-app / astakos / im / management / commands / showuser.py
1 # Copyright 2012 GRNET S.A. All rights reserved.
2 #
3 # Redistribution and use in source and binary forms, with or
4 # without modification, are permitted provided that the following
5 # conditions are met:
6 #
7 #   1. Redistributions of source code must retain the above
8 #      copyright notice, this list of conditions and the following
9 #      disclaimer.
10 #
11 #   2. Redistributions in binary form must reproduce the above
12 #      copyright notice, this list of conditions and the following
13 #      disclaimer in the documentation and/or other materials
14 #      provided with the distribution.
15 #
16 # THIS SOFTWARE IS PROVIDED BY GRNET S.A. ``AS IS'' AND ANY EXPRESS
17 # OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18 # WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
19 # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL GRNET S.A OR
20 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
23 # USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
24 # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 # LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 # ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 # POSSIBILITY OF SUCH DAMAGE.
28 #
29 # The views and conclusions contained in the software and
30 # documentation are those of the authors and should not be
31 # interpreted as representing official policies, either expressed
32 # or implied, of GRNET S.A.
33
34 from django.core.management.base import BaseCommand, CommandError
35
36 from astakos.im.models import AstakosUser, get_latest_terms
37
38 from ._common import format_bool, format_date
39
40
41 class Command(BaseCommand):
42     args = "<user ID or email>"
43     help = "Show user info"
44     
45     def handle(self, *args, **options):
46         if len(args) != 1:
47             raise CommandError("Please provide a user ID or email")
48         
49         email_or_id = args[0]
50         if email_or_id.isdigit():
51             users = AstakosUser.objects.filter(id=int(email_or_id))
52         else:
53             users = AstakosUser.objects.filter(email=email_or_id)
54         if users.count() == 0:
55             field = 'id' if email_or_id.isdigit() else 'email'
56             msg = "Unknown user with %s '%s'" % (field, email_or_id)
57             raise CommandError(msg)
58         
59         for user in users:
60             kv = {
61                 'id': user.id,
62                 'email': user.email,
63                 'first name': user.first_name,
64                 'last name': user.last_name,
65                 'active': format_bool(user.is_active),
66                 'admin': format_bool(user.is_superuser),
67                 'last login': format_date(user.last_login),
68                 'date joined': format_date(user.date_joined),
69                 'last update': format_date(user.updated),
70                 #'token': user.auth_token,
71                 'token expiration': format_date(user.auth_token_expires),
72                 'invitations': user.invitations,
73                 'invitation level': user.level,
74                 'provider': user.provider,
75                 'verified': format_bool(user.is_verified),
76                 'has_credits': format_bool(user.has_credits),
77                 'groups': [elem.name for elem in user.groups.all()],
78                 'permissions': [elem.codename for elem in user.user_permissions.all()],
79                 'group_permissions': user.get_group_permissions(),
80                 'third_party_identifier': user.third_party_identifier,
81                 'email_verified': format_bool(user.email_verified),
82                 'username': user.username,
83                 'activation_sent_date': format_date(user.activation_sent)
84             }
85             if get_latest_terms():
86                 has_signed_terms = user.signed_terms()
87                 kv['has_signed_terms'] = format_bool(has_signed_terms)
88                 if has_signed_terms:
89                     kv['date_signed_terms'] = format_date(user.date_signed_terms)
90             
91             for key, val in sorted(kv.items()):
92                 line = '%s: %s\n' % (key.rjust(22), val)
93                 self.stdout.write(line.encode('utf8'))
94             self.stdout.write('\n')