| Total Complexity | 5 |
| Total Lines | 19 |
| Duplicated Lines | 0 % |
| Changes | 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 |