From c2dcc3dde9d4f569b5b4e7a278c781701670a629 Mon Sep 17 00:00:00 2001 From: talyz Date: Thu, 21 Oct 2021 13:43:48 +0200 Subject: [PATCH] Make --network accept a file argument and add a --flake flag To make it possible to keep multiple network definitions in the same directory, make the `--network` flag accept a file in addition to a directory. Also, add a corresponding `--flake` flag and create short flags for both (`-n` and `-f` respectively). --- doc/manual/nixops.rst | 21 ++++++++++---- nixops/args.py | 5 ++-- nixops/script_defs.py | 64 +++++++++++++++++++++++++++++-------------- 3 files changed, 61 insertions(+), 29 deletions(-) diff --git a/doc/manual/nixops.rst b/doc/manual/nixops.rst index 5f1ae397f..a51905c5a 100644 --- a/doc/manual/nixops.rst +++ b/doc/manual/nixops.rst @@ -6,6 +6,19 @@ NixOps is a tool for deploying NixOS machines in a network or cloud. Common options ============== +``--network``; ``-n`` + Path to file that contains the NixOps network specification, or the + path to a directory containing it. By default, a file called + ``nixops.nix`` in the current working directory is used; if a + directory is specified, it is searched instead. + +``--flake``; ``-f`` + Path to the flake file that contains the NixOps network + specification in ``outputs.nixopsConfigurations.default``, or the + path to a directory containing it. By default, a file called + ``flake.nix`` in the current working directory is used; if a + directory is specified, it is searched instead. + ``--state``; ``-s`` Path to the state file that contains the deployments. It defaults to the value of the NIXOPS_STATE environment variable, or @@ -222,7 +235,6 @@ Synopsis nixops modify nixexprs --name --n name -I path @@ -241,9 +253,9 @@ from ``foo`` to ``bar``: :: - $ nixops modify -d foo -n bar expr3.nix expr4.nix + $ nixops modify -d foo --name bar expr3.nix expr4.nix -Note that ``-d`` identifies the existing deployment, while ``-n`` +Note that ``-d`` identifies the existing deployment, while ``--name`` specifies its new name. Command ``nixops clone`` @@ -254,7 +266,6 @@ Synopsis nixops clone --name --n name Description ----------- @@ -273,7 +284,7 @@ To create a new deployment ``bar`` by cloning the deployment ``foo``: :: - $ nixops clone -d foo -n bar + $ nixops clone -d foo --name bar Command ``nixops delete`` ========================= diff --git a/nixops/args.py b/nixops/args.py index 74b5dafea..b81400d28 100644 --- a/nixops/args.py +++ b/nixops/args.py @@ -61,20 +61,19 @@ subparser = add_subparser(subparsers, "create", help="create a new deployment") subparser.set_defaults(op=op_create) subparser.add_argument( - "--name", "-n", dest="name", metavar="NAME", help=SUPPRESS + "--name", dest="name", metavar="NAME", help=SUPPRESS ) # obsolete, use -d instead subparser = add_subparser(subparsers, "modify", help="modify an existing deployment") subparser.set_defaults(op=op_modify) subparser.add_argument( - "--name", "-n", dest="name", metavar="NAME", help="new symbolic name of deployment" + "--name", dest="name", metavar="NAME", help="new symbolic name of deployment" ) subparser = add_subparser(subparsers, "clone", help="clone an existing deployment") subparser.set_defaults(op=op_clone) subparser.add_argument( "--name", - "-n", dest="name", metavar="NAME", help="symbolic name of the cloned deployment", diff --git a/nixops/script_defs.py b/nixops/script_defs.py index 709c433b6..2e11502c2 100644 --- a/nixops/script_defs.py +++ b/nixops/script_defs.py @@ -37,27 +37,41 @@ def get_network_file(args: Namespace) -> NetworkFile: - network_dir: str = os.path.abspath(args.network_dir) - - if not os.path.exists(network_dir): - raise ValueError(f"{network_dir} does not exist") - - classic_path = os.path.join(network_dir, "nixops.nix") - flake_path = os.path.join(network_dir, "flake.nix") - - classic_exists: bool = os.path.exists(classic_path) + network_path: str = "" + flake_path: str = "" + + if args.network_path is not None: + network_path = os.path.abspath(args.network_path) + if os.path.isdir(network_path): + network_path = os.path.join(network_path, "nixops.nix") + if not os.path.exists(network_path): + raise ValueError(f"{network_path} does not exist") + return NetworkFile(network=network_path, is_flake=False) + + if args.flake_path is not None: + flake_path = os.path.abspath(args.flake_path) + if os.path.isdir(flake_path): + flake_path = os.path.join(flake_path, "flake.nix") + if not os.path.exists(flake_path): + raise ValueError(f"{flake_path} does not exist") + return NetworkFile(network=flake_path, is_flake=True) + + network_path = os.path.join(os.getcwd(), "nixops.nix") + flake_path = os.path.join(os.getcwd(), "flake.nix") + + network_exists: bool = os.path.exists(network_path) flake_exists: bool = os.path.exists(flake_path) - if all((flake_exists, classic_exists)): - raise ValueError("Both flake.nix and nixops.nix cannot coexist") - - if classic_exists: - return NetworkFile(network=classic_path, is_flake=False) + if all((flake_exists, network_exists)): + raise ValueError("Both flake.nix and nixops.nix found in current directory") - if flake_exists: - return NetworkFile(network=network_dir, is_flake=True) + if not network_exists and not flake_exists: + raise ValueError("Neither flake.nix nor nixops.nix exists in current directory") - raise ValueError(f"Neither flake.nix nor nixops.nix exists in {network_dir}") + if network_exists: + return NetworkFile(network=network_path, is_flake=False) + else: + return NetworkFile(network=network_path, is_flake=True) def set_common_depl(depl: nixops.deployment.Deployment, args: Namespace) -> None: @@ -1154,12 +1168,20 @@ def add_subparser( subparsers: _SubParsersAction, name: str, help: str ) -> ArgumentParser: subparser = subparsers.add_parser(name, help=help) - subparser.add_argument( + network = subparser.add_mutually_exclusive_group() + network.add_argument( "--network", - dest="network_dir", + "-n", + dest="network_path", + metavar="FILE", + help="path to network file or a directory containing nixops.nix", + ) + network.add_argument( + "--flake", + "-f", + dest="flake_path", metavar="FILE", - default=os.getcwd(), - help="path to a directory containing either nixops.nix or flake.nix", + help="path to flake or a directory containing flake.nix", ) subparser.add_argument( "--deployment",