162870829a0355e3122ceddc82b304f93e373e4f
[myslice.git] / portal / lsapiclient.py
1 import sys
2 import urllib
3 import urllib2
4 import json
5 import socket
6 from urlparse import urlparse
7 from database import Database
8
9 class LaboraSchedulerClient:
10     """
11     A simple rest shell to a Labora Scheduler instance
12     This class can receive Labora API  calls to the underlying testbed
13     """
14                 
15     direct_calls = [ 'get_testbed_info', 'get_users', 'add_user', 'delete_user', 'update_user',
16                      'get_user_id_by_username' ]
17
18     def __init__ ( self, organization ):
19        # self.url, self.key = self.getOrganizationConfigs( organization )
20        self.url = "https://portal.ufrj.fibre.org.br:3002/LS-Sched/"
21        self.key = "9763dd03f2da8138fb22a63d78e5e9792b59a637"
22
23     def __getattr__(self, name):
24         
25         def func(*args, **kwds):
26             actual_name = None
27             
28             if name in LaboraSchedulerClient.direct_calls:
29                 actual_name = name
30             
31             if not actual_name:
32                 raise Exception, "Method %s not found in Labora Scheduler"%(name)
33                 return
34                 
35             if not self.url or not self.key:
36                 raise Exception, "Missing Labora Scheduler island url and/or key."
37                 return
38                 
39             address = self.url + "?method=" + actual_name + "&key=" + self.key
40             
41             # get the direct_call parameters
42             method_parameters = []
43             
44             if actual_name == "get_users":
45                 method_parameters.extend(['filter'])
46             elif actual_name == "update_user":
47                 method_parameters.extend(['user_id', 'new_user_data'])
48             elif actual_name == "delete_user":
49                 method_parameters.extend(['user_id'])
50             elif actual_name == "get_user_id_by_username":
51                 method_parameters.extend(['username'])
52             elif actual_name == "add_user":
53                 method_parameters.extend(['username', 'email', 'password', 'name', 'gidnumber',
54                                           'homedirectory'])
55             
56             for parameter in args:
57                 if isinstance(parameter, (frozenset, list, set, tuple, dict)):
58                     for key_name in parameter.keys():
59                         
60                         if key_name in method_parameters:
61                             param_value = parameter[key_name]
62                             
63                             if param_value == None:
64                                 continue
65                             
66                             if isinstance(param_value, (frozenset, list, set, tuple, dict)):
67                                 param_value = json.dumps(param_value)
68                             
69                             param_value = urllib.quote(param_value.encode('utf-8'))
70                             
71                             address += "&" + key_name + "=" + param_value
72             
73             api_call = urllib2.urlopen(address)
74             api_call = json.load(api_call)
75             
76             if not api_call['call_status']:
77                 result = api_call['method_result']
78             else:
79                 result = False
80
81
82             return result
83             
84         return func
85         
86         
87     def getOrganizationConfigs( self, organization ):
88         ls_url = None
89         ls_key = None
90         
91         databaseConfig = {
92             'dbHost'        : '10.128.11.200',
93             'dbUser'        : '',
94             'dbPassword'    : '',
95             'dbName'        : 'LaboraSchedulerNOC'
96         }
97         
98         databaseConnection = Database( databaseConfig )
99         
100         query = "SELECT * FROM islands WHERE domain ='" + organization + "'"
101         orgConfig = databaseConnection.fetchRows( query )
102
103         if orgConfig:
104             ls_url = orgConfig[0]["ls_url"]
105             ls_key = orgConfig[0]["ls_key"]
106         
107         return ls_url, ls_key