Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Use environment variable for passing the private key password #2094

Merged
merged 8 commits into from
Oct 27, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
13 changes: 10 additions & 3 deletions autonomy/cli/deploy.py
Original file line number Diff line number Diff line change
Expand Up @@ -187,6 +187,11 @@ def build_deployment_command( # pylint: disable=too-many-arguments, too-many-lo
image_author: Optional[str] = None,
) -> None:
"""Build deployment setup for n agents."""
if password is not None: # pragma: nocover
click.echo(
"WARNING: `--password` flag has been deprecated, "
"use `OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD` to export the password value"
)

keys_file = Path(keys_file or DEFAULT_KEYS_FILE).absolute()
if not keys_file.exists():
Expand Down Expand Up @@ -222,7 +227,6 @@ def build_deployment_command( # pylint: disable=too-many-arguments, too-many-lo
deployment_type=deployment_type,
dev_mode=dev_mode,
number_of_agents=number_of_agents,
password=password,
packages_dir=packages_dir,
open_aea_dir=open_aea_dir,
open_autonomy_dir=open_autonomy_dir,
Expand Down Expand Up @@ -343,11 +347,15 @@ def run_deployment_from_token( # pylint: disable=too-many-arguments, too-many-l
password: Optional[str] = None,
) -> None:
"""Run service deployment."""
if password is not None: # pragma: nocover
click.echo(
"WARNING: `--password` flag has been deprecated, "
"use `OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD` to export the password value"
)

ctx = cast(Context, click_context.obj)
ctx.registry_type = REGISTRY_REMOTE
keys_file = Path(keys_file or DEFAULT_KEYS_FILE).absolute()

with reraise_as_click_exception(
NotValidKeysFile, FileNotFoundError, FileExistsError
):
Expand All @@ -359,7 +367,6 @@ def run_deployment_from_token( # pylint: disable=too-many-arguments, too-many-l
n=n,
deployment_type=deployment_type,
aev=aev,
password=password,
no_deploy=no_deploy,
detach=detach,
)
4 changes: 0 additions & 4 deletions autonomy/cli/helpers/deployment.py
Original file line number Diff line number Diff line change
Expand Up @@ -180,7 +180,6 @@ def build_deployment( # pylint: disable=too-many-arguments, too-many-locals
deployment_type: str,
dev_mode: bool,
number_of_agents: Optional[int] = None,
password: Optional[str] = None,
packages_dir: Optional[Path] = None,
open_aea_dir: Optional[Path] = None,
open_autonomy_dir: Optional[Path] = None,
Expand Down Expand Up @@ -213,7 +212,6 @@ def build_deployment( # pylint: disable=too-many-arguments, too-many-locals
service_path=Path.cwd(),
type_of_deployment=deployment_type,
keys_file=keys_file,
private_keys_password=password,
number_of_agents=number_of_agents,
build_dir=build_dir,
dev_mode=dev_mode,
Expand Down Expand Up @@ -280,7 +278,6 @@ def build_and_deploy_from_token( # pylint: disable=too-many-arguments, too-many
n: Optional[int],
deployment_type: str,
aev: bool = False,
password: Optional[str] = None,
no_deploy: bool = False,
detach: bool = False,
) -> None:
Expand Down Expand Up @@ -314,7 +311,6 @@ def build_and_deploy_from_token( # pylint: disable=too-many-arguments, too-many
multisig_address=multisig_address,
consensus_threshold=consensus_threshold,
apply_environment_variables=aev,
password=password,
)
if not skip_image:
click.echo("Building required images.")
Expand Down
26 changes: 6 additions & 20 deletions autonomy/deploy/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -110,7 +110,6 @@ def __init__( # pylint: disable=too-many-arguments
self,
service: Service,
keys: Optional[List[Dict[str, str]]] = None,
private_keys_password: Optional[str] = None,
agent_instances: Optional[List[str]] = None,
apply_environment_variables: bool = False,
) -> None:
Expand All @@ -128,7 +127,6 @@ def __init__( # pylint: disable=too-many-arguments
self._service_name_clean = self.service.name.replace("_", "")
self._keys = keys or []
self._agent_instances = agent_instances
self._private_keys_password = private_keys_password
self._all_participants = self.try_get_all_participants()

def get_abci_container_name(self, index: int) -> str:
Expand Down Expand Up @@ -169,18 +167,6 @@ def try_get_all_participants(self) -> Optional[List[str]]:

return None

@property
def private_keys_password(
self,
) -> Optional[str]:
"""Service password for agent keys."""

password = self._private_keys_password
if password is None:
password = os.environ.get("AUTONOLAS_SERVICE_PASSWORD")

return password

@property
def agent_instances(
self,
Expand Down Expand Up @@ -214,7 +200,6 @@ def from_dir( # pylint: disable=too-many-arguments
path: Path,
keys_file: Optional[Path] = None,
number_of_agents: Optional[int] = None,
private_keys_password: Optional[str] = None,
agent_instances: Optional[List[str]] = None,
apply_environment_variables: bool = False,
) -> "ServiceBuilder":
Expand All @@ -228,7 +213,6 @@ def from_dir( # pylint: disable=too-many-arguments
service_builder = cls(
service=service,
apply_environment_variables=apply_environment_variables,
private_keys_password=private_keys_password,
)

if keys_file is not None:
Expand Down Expand Up @@ -626,10 +610,12 @@ def generate_common_vars(self, agent_n: int) -> Dict:
ENV_VAR_AEA_AGENT: self.service.agent,
ENV_VAR_LOG_LEVEL: self.log_level,
}

if self.private_keys_password is not None:
agent_vars[ENV_VAR_AEA_PASSWORD] = self.private_keys_password

if self.deplopyment_type == DOCKER_COMPOSE_DEPLOYMENT:
agent_vars[ENV_VAR_AEA_PASSWORD] = "$OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD"
Comment on lines +613 to +614
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will store the value of AEA_PASSWORD as $OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD in the docker-compose.yaml so the user can pass the password as OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD when running the deployment

else:
agent_vars[ENV_VAR_AEA_PASSWORD] = os.environ.get(
"OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD", ""
)
Comment on lines +616 to +618
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Unfortunately the kubernetes does not provide such functionalities so we'll have to store them the old way

return agent_vars

def generate_agent(
Expand Down
2 changes: 0 additions & 2 deletions autonomy/deploy/build.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ def generate_deployment( # pylint: disable=too-many-arguments, too-many-locals
service_path: Path,
build_dir: Path,
number_of_agents: Optional[int] = None,
private_keys_password: Optional[str] = None,
dev_mode: bool = False,
packages_dir: Optional[Path] = None,
open_aea_dir: Optional[Path] = None,
Expand All @@ -60,7 +59,6 @@ def generate_deployment( # pylint: disable=too-many-arguments, too-many-locals
path=service_path,
keys_file=keys_file,
number_of_agents=number_of_agents,
private_keys_password=private_keys_password,
agent_instances=agent_instances,
apply_environment_variables=apply_environment_variables,
)
Expand Down
9 changes: 6 additions & 3 deletions docs/advanced_reference/commands/autonomy_deploy.md
Original file line number Diff line number Diff line change
Expand Up @@ -102,9 +102,6 @@ autonomy deploy build [OPTIONS] [KEYS_FILE]
`-p`
: Ask for password interactively.

`--password PASSWORD`
: Set password for key encryption/decryption.

`--help`
: Show the help message and exit.

Expand Down Expand Up @@ -148,12 +145,18 @@ autonomy deploy run [OPTIONS]
: Show the help message and exit.

### Examples

```bash
autonomy deploy run --build-dir ./abci_build
```

Runs the service deployment stored locally in the directory `./abci_build`.

To provide password for the private keys

```bash
OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD=PASSWORD autonomy deploy run --build-dir ./abci_build
```

## `autonomy deploy from-token`

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,8 @@ docker image push <tag>

Finally, build the deployment and run it:
```bash
autonomy deploy build ../generated_keys.json --password ${PASSWORD} --kubernetes --dev
export OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD=${PASSWORD}
autonomy deploy build ../generated_keys.json --kubernetes --dev
kubectl apply -f abci_build/
kubectl apply -f abci_build/agent_keys
```
Expand Down
2 changes: 0 additions & 2 deletions docs/api/cli/helpers/deployment.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,6 @@ def build_deployment(keys_file: Path,
deployment_type: str,
dev_mode: bool,
number_of_agents: Optional[int] = None,
password: Optional[str] = None,
packages_dir: Optional[Path] = None,
open_aea_dir: Optional[Path] = None,
open_autonomy_dir: Optional[Path] = None,
Expand Down Expand Up @@ -67,7 +66,6 @@ def build_and_deploy_from_token(token_id: int,
n: Optional[int],
deployment_type: str,
aev: bool = False,
password: Optional[str] = None,
no_deploy: bool = False,
detach: bool = False) -> None
```
Expand Down
13 changes: 0 additions & 13 deletions docs/api/deploy/base.md
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,6 @@ Class to assist with generating deployments.
```python
def __init__(service: Service,
keys: Optional[List[Dict[str, str]]] = None,
private_keys_password: Optional[str] = None,
agent_instances: Optional[List[str]] = None,
apply_environment_variables: bool = False) -> None
```
Expand Down Expand Up @@ -80,17 +79,6 @@ def try_get_all_participants() -> Optional[List[str]]

Try get all participants from the ABCI overrides

<a id="autonomy.deploy.base.ServiceBuilder.private_keys_password"></a>

#### private`_`keys`_`password

```python
@property
def private_keys_password() -> Optional[str]
```

Service password for agent keys.

<a id="autonomy.deploy.base.ServiceBuilder.agent_instances"></a>

#### agent`_`instances
Expand Down Expand Up @@ -134,7 +122,6 @@ def from_dir(cls,
path: Path,
keys_file: Optional[Path] = None,
number_of_agents: Optional[int] = None,
private_keys_password: Optional[str] = None,
agent_instances: Optional[List[str]] = None,
apply_environment_variables: bool = False) -> "ServiceBuilder"
```
Expand Down
1 change: 0 additions & 1 deletion docs/api/deploy/build.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,6 @@ def generate_deployment(type_of_deployment: str,
service_path: Path,
build_dir: Path,
number_of_agents: Optional[int] = None,
private_keys_password: Optional[str] = None,
dev_mode: bool = False,
packages_dir: Optional[Path] = None,
open_aea_dir: Optional[Path] = None,
Expand Down
1 change: 0 additions & 1 deletion docs/application_deployment.md
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@ Options:
--remote To use a remote registry.
--local To use a local registry.
-p Ask for password interactively
--password PASSWORD Set password for key encryption/decryption
--help Show this message and exit.

```
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -308,28 +308,29 @@ def test_docker_compose_password(
)

build_dir = self.t / DEFAULT_BUILD_FOLDER

assert result.exit_code == 0, result.output
assert result.exit_code == 0, result.stderr
assert (
"WARNING: `--password` flag has been deprecated, use `OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD` to export the password value"
in result.stdout
)
assert build_dir.exists()

build_dir = self.t / DEFAULT_BUILD_FOLDER

assert result.exit_code == 0, result.output
assert build_dir.exists()

docker_compose_file = build_dir / DockerComposeGenerator.output_name
with open(docker_compose_file, "r", encoding="utf-8") as fp:
docker_compose = yaml.safe_load(fp)

agents = int(len(docker_compose["services"]) / 2)

def _file_check(n: int) -> bool:
return (
build_dir
/ DEPLOYMENT_KEY_DIRECTORY
/ DEPLOYMENT_AGENT_KEY_DIRECTORY_SCHEMA.format(agent_n=n)
).exists()

agents = int(len(docker_compose["services"]) / 2)
assert all(_file_check(i) for i in range(agents))
for x in range(agents):
env = dict(
Expand All @@ -341,7 +342,7 @@ def _file_check(n: int) -> bool:
]
)
assert "AEA_PASSWORD" in env.keys()
assert env["AEA_PASSWORD"] == ETHEREUM_ENCRYPTION_PASSWORD
assert env["AEA_PASSWORD"] == "$OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD"

def test_include_acn_and_hardhat_nodes(
self,
Expand Down Expand Up @@ -601,6 +602,10 @@ def test_kubernetes_build_password(
)

assert result.exit_code == 0, result.output
assert (
"WARNING: `--password` flag has been deprecated, use `OPEN_AUTONOMY_PRIVATE_KEY_PASSWORD` to export the password value"
in result.stdout
)
assert build_dir.exists()

kubernetes_config = self.load_kubernetes_config(
Expand All @@ -613,7 +618,7 @@ def test_kubernetes_build_password(
except (KeyError, IndexError):
continue

assert agent_vars["AEA_PASSWORD"] == ETHEREUM_ENCRYPTION_PASSWORD
assert agent_vars["AEA_PASSWORD"] == ""

assert all(
(
Expand Down
29 changes: 21 additions & 8 deletions tests/test_autonomy/test_deploy/test_service_specification.py
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,6 @@ def test_initialize(
self.keys_path,
)

assert spec.private_keys_password is None
assert spec.agent_instances is None
assert len(spec.keys) == 1

Expand All @@ -144,11 +143,29 @@ def test_generate_agents(
assert len(agents) == 1, agents

agent = spec.generate_agent(0)
assert len(agent.keys()) == 10, agent
assert len(agent.keys()) == 11, agent

spec.service.overrides = []
agent = spec.generate_agent(0)
assert len(agent.keys()) == 3, agent
assert len(agent.keys()) == 4, agent

def test_get_maximum_participants(
self,
) -> None:
"""Test get_maximum_participants."""
self._write_service(get_dummy_service_config(file_number=0))
spec = ServiceBuilder.from_dir(
self.service_path,
self.keys_path,
)

spec._all_participants = list(map(str, range(2)))
assert spec.get_maximum_participants() == 2

with mock.patch.object(spec, attribute="verify_agent_instances"):
spec._all_participants = []
spec.agent_instances = list(map(str, range(3)))
assert spec.get_maximum_participants() == 3

def test_generate_common_vars(
self,
Expand All @@ -165,11 +182,7 @@ def test_generate_common_vars(
assert all(var in common_vars_without_password for var in COMMON_VARS[:-1])
assert common_vars_without_password[ENV_VAR_AEA_AGENT] == spec.service.agent

spec = ServiceBuilder.from_dir( # nosec
self.service_path,
self.keys_path,
private_keys_password="some_password",
)
spec = ServiceBuilder.from_dir(self.service_path, self.keys_path) # nosec
common_vars_without_password = spec.generate_common_vars(agent_n=0)
assert all(var in common_vars_without_password for var in COMMON_VARS)

Expand Down
1 change: 0 additions & 1 deletion tests/test_deployments/test_deployments.py
Original file line number Diff line number Diff line change
Expand Up @@ -281,7 +281,6 @@ def test_update_agent_number_based_on_keys_file(self) -> None:
builder = ServiceBuilder(
service=service,
keys=None,
private_keys_password=None,
agent_instances=list("abcdefg"),
)
assert builder.service.number_of_agents == 1_000_000
Expand Down
Loading