from chalicelib.utils import pg_client, helper from chalicelib.core.integration_github_issue import GithubIntegrationIssue from chalicelib.core import integration_base PROVIDER = "GITHUB" class GitHubIntegration(integration_base.BaseIntegration): def __init__(self, tenant_id, user_id): self.__tenant_id = tenant_id super(GitHubIntegration, self).__init__(user_id=user_id, ISSUE_CLASS=GithubIntegrationIssue) @property def provider(self): return PROVIDER def get_obfuscated(self): integration = self.get() if integration is None: return None token = "*" * (len(integration["token"]) - 4) + integration["token"][-4:] return {"token": token, "provider": self.provider.lower()} def update(self, changes): with pg_client.PostgresClient() as cur: sub_query = [f"{helper.key_to_snake_case(k)} = %({k})s" for k in changes.keys()] cur.execute( cur.mogrify(f"""\ UPDATE public.oauth_authentication SET {','.join(sub_query)} WHERE user_id=%(user_id)s RETURNING token;""", {"user_id": self._user_id, **changes}) ) w = helper.dict_to_camel_case(cur.fetchone()) return w def _add(self, data): pass def add(self, token): with pg_client.PostgresClient() as cur: cur.execute( cur.mogrify("""\ INSERT INTO public.oauth_authentication(user_id, provider, provider_user_id, token) VALUES(%(user_id)s, 'github', '', %(token)s) RETURNING token;""", {"user_id": self._user_id, "token": token}) ) w = helper.dict_to_camel_case(cur.fetchone()) return w # TODO: make a revoke token call def delete(self): with pg_client.PostgresClient() as cur: cur.execute( cur.mogrify("""\ DELETE FROM public.oauth_authentication WHERE user_id=%(user_id)s AND provider=%(provider)s;""", {"user_id": self._user_id, "provider": self.provider.lower()}) ) return {"state": "success"} def add_edit(self, data): s = self.get() if s is not None: return self.update( changes={ "token": data["token"] } ) else: return self.add(token=data["token"])