Statistics
| Branch: | Tag: | Revision:

root / snf-astakos-app / astakos / im / management / commands / user-list.py @ 2a6fc999

History | View | Annotate | Download (4.1 kB)

1
# Copyright 2012, 2013 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 optparse import make_option
35

    
36
from django.core.management.base import NoArgsCommand
37

    
38
from astakos.im.models import AstakosUser, AstakosUserAuthProvider
39

    
40
from ._common import format
41

    
42

    
43
class Command(NoArgsCommand):
44
    help = "List users"
45

    
46
    option_list = NoArgsCommand.option_list + (
47
        make_option('-c',
48
                    action='store_true',
49
                    dest='csv',
50
                    default=False,
51
                    help="Use pipes to separate values"),
52
        make_option('-p',
53
                    action='store_true',
54
                    dest='pending',
55
                    default=False,
56
                    help="List only users pending activation"),
57
        make_option('-n',
58
                    action='store_true',
59
                    dest='pending_send_mail',
60
                    default=False,
61
                    help="List only users who have not received activation"),
62
    )
63

    
64
    def handle_noargs(self, **options):
65
        users = AstakosUser.objects.all().order_by('id')
66
        if options['pending']:
67
            users = users.filter(is_active=False)
68
        elif options['pending_send_mail']:
69
            users = users.filter(is_active=False, activation_sent=None)
70

    
71
        ids = [user.id for user in users]
72
        auths = AstakosUserAuthProvider.objects.filter(
73
            user__in=ids, active=True)
74

    
75
        all_auth = partition_by(lambda a: a.user_id, auths)
76

    
77
        labels = ('id', 'email', 'real name', 'active', 'admin', 'uuid', 'providers')
78
        columns = (3, 24, 24, 6, 5, 12, 36, 24)
79

    
80
        if not options['csv']:
81
            line = ' '.join(l.rjust(w) for l, w in zip(labels, columns))
82
            self.stdout.write(line + '\n')
83
            sep = '-' * len(line)
84
            self.stdout.write(sep + '\n')
85

    
86
        for user in users:
87
            id = str(user.id)
88
            active = user.is_active
89
            admin = user.is_superuser
90
            uuid = user.uuid or ''
91
            auths = all_auth[user.id]
92
            auth_display = ",".join(unicode(auth) for auth in auths)
93
            fields = (format(elem) for elem in (
94
                            id,
95
                            user.email,
96
                            user.realname,
97
                            active, admin, uuid,
98
                            auth_display
99
            ))
100

    
101
            if options['csv']:
102
                line = '|'.join(fields)
103
            else:
104
                line = ' '.join(f.rjust(w) for f, w in zip(fields, columns))
105

    
106
            self.stdout.write(line + '\n')
107

    
108

    
109
def partition_by(f, l):
110
    d = {}
111
    for x in l:
112
        group = f(x)
113
        group_l = d.get(group, [])
114
        group_l.append(x)
115
        d[group] = group_l
116
    return d