Skip to content

Commit

Permalink
review fixes
Browse files Browse the repository at this point in the history
  • Loading branch information
sfc-gh-pczajka committed Mar 8, 2024
1 parent fa6fb1c commit 161800a
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 25 deletions.
23 changes: 23 additions & 0 deletions src/snowflake/cli/api/sql_execution.py
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,29 @@ def use_role(self, new_role: str):
if is_different_role:
self._execute_query(f"use role {prev_role}")

def create_password_secret(
self, name: str, username: str, password: str
) -> SnowflakeCursor:
query = (
f"create secret {name}"
f" type = password"
f" username = '{username}'"
f" password = '{password}'"
)
return self._execute_query(query)

def create_api_integration(
self, name: str, api_provider: str, allowed_prefix: str, secret: Optional[str]
) -> SnowflakeCursor:
query = (
f"create api integration {name}"
f" api_provider = {api_provider}"
f" api_allowed_prefixes = ('{allowed_prefix}')"
f" allowed_authentication_secrets = ({secret if secret else ''})"
f" enabled = true"
)
return self._execute_query(query)

def _execute_schema_query(self, query: str, name: Optional[str] = None, **kwargs):
"""
Check that a database and schema are provided before executing the query. Useful for operating on schema level objects.
Expand Down
9 changes: 7 additions & 2 deletions src/snowflake/cli/plugins/git/commands.py
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,9 @@ def setup(
secret = f"{repository_name}_secret"
username = typer.prompt("username")
password = typer.prompt("password/token", hide_input=True)
manager.create_secret(username=username, password=password, name=secret)
manager.create_password_secret(
username=username, password=password, name=secret
)
cli_console.step(f"Secret '{secret}' successfully created")

use_existing_api = typer.confirm("Use existing api integration?")
Expand All @@ -96,7 +98,10 @@ def setup(
else:
api_integration = f"{repository_name}_api_integration"
manager.create_api_integration(
name=api_integration, allowed_prefix=url, secret=secret
name=api_integration,
api_provider="git_https_api",
allowed_prefix=url,
secret=secret,
)
cli_console.step(f"API integration '{api_integration}' successfully created.")

Expand Down
23 changes: 0 additions & 23 deletions src/snowflake/cli/plugins/git/manager.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,3 @@
from typing import Optional

from snowflake.cli.plugins.object.stage.manager import StageManager
from snowflake.connector.cursor import SnowflakeCursor

Expand Down Expand Up @@ -32,24 +30,3 @@ def create(
if secret is not None:
query += f" git_credentials = {secret}"
return self._execute_query(query)

def create_secret(self, name: str, username: str, password: str) -> SnowflakeCursor:
query = (
f"create secret {name}"
f" type = password"
f" username = '{username}'"
f" password = '{password}'"
)
return self._execute_query(query)

def create_api_integration(
self, name: str, allowed_prefix: str, secret: Optional[str]
) -> SnowflakeCursor:
query = (
f"create api integration {name}"
f" api_provider = git_https_api"
f" api_allowed_prefixes = ('{allowed_prefix}')"
f" allowed_authentication_secrets = ({secret if secret else ''})"
f" enabled = true"
)
return self._execute_query(query)

0 comments on commit 161800a

Please sign in to comment.