Statistics
| Branch: | Tag: | Revision:

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

History | View | Annotate | Download (3.6 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 CommandError
35
from optparse import make_option
36

    
37
from pithos.api.util import get_backend
38
from snf_django.management.commands import SynnefoCommand
39

    
40
import logging
41

    
42
logger = logging.getLogger(__name__)
43

    
44
CLIENTKEY = 'pithos'
45

    
46

    
47
class Command(SynnefoCommand):
48
    help = "Display unresolved commissions and trigger their recovery"
49

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

    
58
    def handle_noargs(self, **options):
59
        b = get_backend()
60
        try:
61
            b.pre_exec()
62
            pending_commissions = b.astakosclient.get_pending_commissions()
63

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

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

    
88
                b.commission_serials.delete_many(accepted)
89
        except Exception, e:
90
            logger.exception(e)
91
            b.post_exec(False)
92
            raise CommandError(e)
93
        else:
94
            b.post_exec(True)
95
        finally:
96
            b.close()