Statistics
| Branch: | Tag: | Revision:

root / snf-pithos-app / pithos / api / management / commands / reconcile-commissions-pithos.py @ 603e0058

History | View | Annotate | Download (3.5 kB)

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 NoArgsCommand, CommandError
35
from optparse import make_option
36

    
37
from pithos.api.util import get_backend
38

    
39
import logging
40

    
41
logger = logging.getLogger(__name__)
42

    
43
CLIENTKEY = 'pithos'
44

    
45
class Command(NoArgsCommand):
46
    help = "Display unresolved commissions and trigger their recovery"
47

    
48
    option_list = NoArgsCommand.option_list + (
49
        make_option('--fix',
50
                    dest='fix',
51
                    action="store_true",
52
                    default=False,
53
                    help="Fix unresolved commissions"),
54
    )
55

    
56
    def handle_noargs(self, **options):
57
        b = get_backend()
58
        try:
59
            pending_commissions = b.astakosclient.get_pending_commissions(
60
                token=b.service_token)
61

    
62
            if pending_commissions:
63
                self.stdout.write(
64
                    "Unresolved commissions: %s\n" % pending_commissions
65
                )
66
            else:
67
                self.stdout.write( "No unresolved commissions were found\n")
68
                return
69

    
70
            if options['fix']:
71
                to_accept = b.commission_serials.lookup(pending_commissions)
72
                to_reject = list(set(pending_commissions) - set(to_accept))
73
                response = b.astakosclient.resolve_commissions(
74
                    token=b.service_token,
75
                    accept_serials=to_accept,
76
                    reject_serials=to_reject
77
                )
78
                accepted = response['accepted']
79
                rejected = response['rejected']
80
                failed = response['failed']
81
                self.stdout.write("Accepted commissions: %s\n" %  accepted)
82
                self.stdout.write("Rejected commissions: %s\n" %  rejected)
83
                self.stdout.write("Failed commissions:\n")
84
                for i in failed:
85
                    self.stdout.write('%s\n' % i)
86

    
87
                b.commission_serials.delete_many(accepted)
88
        except Exception, e:
89
            logger.exception(e)
90
            raise CommandError(e)
91
        finally:
92
            b.close()