1 # Copyright 2012 GRNET S.A. All rights reserved.
3 # Redistribution and use in source and binary forms, with or
4 # without modification, are permitted provided that the following
7 # 1. Redistributions of source code must retain the above
8 # copyright notice, this list of conditions and the following
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.
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.
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.
34 from django.core.management.base import BaseCommand, CommandError
36 from astakos.im.models import AstakosUser, get_latest_terms
38 from ._common import format_bool, format_date
41 class Command(BaseCommand):
42 args = "<user ID or email>"
43 help = "Show user info"
45 def handle(self, *args, **options):
47 raise CommandError("Please provide a user ID or email")
50 if email_or_id.isdigit():
51 users = AstakosUser.objects.filter(id=int(email_or_id))
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)
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)
85 if get_latest_terms():
86 has_signed_terms = user.signed_terms()
87 kv['has_signed_terms'] = format_bool(has_signed_terms)
89 kv['date_signed_terms'] = format_date(user.date_signed_terms)
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')