Total Complexity | 5 |
Total Lines | 19 |
Duplicated Lines | 0 % |
1 | import _mssql |
||
10 | class MSSQLAction(Action): |
||
11 | |||
12 | def connect(self, database=None, server=None, user=None, password=None): |
||
13 | # pylint: disable=no-member |
||
14 | return _mssql.connect(**self._connect_params(database, server, user, password)) |
||
15 | |||
16 | def _connect_params(self, database=None, server=None, user=None, password=None): |
||
17 | database = database or self.config.get('default') |
||
18 | db_config = self.config.get(database, {}) |
||
19 | params = { |
||
20 | 'database': db_config.get('database') or database, |
||
21 | 'server': server or db_config.get('server'), |
||
22 | 'user': user or db_config.get('user'), |
||
23 | 'password': password or db_config.get('password') |
||
24 | } |
||
25 | unspecified = [param for param, value in params.iteritems() if value is None] |
||
26 | if unspecified: |
||
27 | raise Exception("Must specify or configure in config.yaml: %s" % ', '.join(unspecified)) |
||
28 | return params |
||
29 |