mirror of
https://github.com/ProvableHQ/leo.git
synced 2024-11-23 07:07:07 +03:00
impl leo deploy
This commit is contained in:
parent
0d039bfa3f
commit
99d73a6010
@ -116,6 +116,13 @@ create_messages!(
|
|||||||
help: None,
|
help: None,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@backtraced
|
||||||
|
failed_to_execute_aleo_deploy {
|
||||||
|
args: (error: impl Display),
|
||||||
|
msg: format!("Failed to execute the `aleo deploy` command.\nSnarkVM Error: {}", error),
|
||||||
|
help: None,
|
||||||
|
}
|
||||||
|
|
||||||
@backtraced
|
@backtraced
|
||||||
failed_to_parse_aleo_new {
|
failed_to_parse_aleo_new {
|
||||||
args: (error: impl Display),
|
args: (error: impl Display),
|
||||||
@ -136,4 +143,11 @@ create_messages!(
|
|||||||
msg: format!("Failed to parse the `aleo node` command.\nSnarkVM Error: {}", error),
|
msg: format!("Failed to parse the `aleo node` command.\nSnarkVM Error: {}", error),
|
||||||
help: None,
|
help: None,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@backtraced
|
||||||
|
failed_to_parse_aleo_deploy {
|
||||||
|
args: (error: impl Display),
|
||||||
|
msg: format!("Failed to parse the `aleo deploy` command.\nSnarkVM Error: {}", error),
|
||||||
|
help: None,
|
||||||
|
}
|
||||||
);
|
);
|
||||||
|
61
leo/commands/deploy.rs
Normal file
61
leo/commands/deploy.rs
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
// Copyright (C) 2019-2022 Aleo Systems Inc.
|
||||||
|
// This file is part of the Leo library.
|
||||||
|
|
||||||
|
// The Leo library is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
|
||||||
|
// The Leo library is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with the Leo library. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use crate::commands::ALEO_CLI_COMMAND;
|
||||||
|
use crate::{commands::Command, context::Context};
|
||||||
|
use leo_errors::{CliError, PackageError, Result};
|
||||||
|
use leo_package::build::BuildDirectory;
|
||||||
|
|
||||||
|
use aleo::commands::Deploy as AleoDeploy;
|
||||||
|
|
||||||
|
use clap::StructOpt;
|
||||||
|
use tracing::span::Span;
|
||||||
|
|
||||||
|
/// Deploys an Aleo program.
|
||||||
|
#[derive(StructOpt, Debug)]
|
||||||
|
pub struct Deploy;
|
||||||
|
|
||||||
|
impl Command for Deploy {
|
||||||
|
type Input = ();
|
||||||
|
type Output = ();
|
||||||
|
|
||||||
|
fn log_span(&self) -> Span {
|
||||||
|
tracing::span!(tracing::Level::INFO, "Deploy")
|
||||||
|
}
|
||||||
|
|
||||||
|
fn prelude(&self, _: Context) -> Result<Self::Input> {
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
fn apply(self, context: Context, _: Self::Input) -> Result<Self::Output> {
|
||||||
|
// Open the Leo build/ directory
|
||||||
|
let path = context.dir()?;
|
||||||
|
let build_directory = BuildDirectory::open(&path).map_err(|_| CliError::needs_leo_build())?;
|
||||||
|
|
||||||
|
// Change the cwd to the Leo build/ directory to deploy aleo files.
|
||||||
|
std::env::set_current_dir(&build_directory)
|
||||||
|
.map_err(|err| PackageError::failed_to_set_cwd(build_directory.display(), err))?;
|
||||||
|
|
||||||
|
// Call the `aleo node` command from the Aleo SDK.
|
||||||
|
let command = AleoDeploy::try_parse_from(&[ALEO_CLI_COMMAND]).map_err(CliError::failed_to_parse_aleo_node)?;
|
||||||
|
let res = command.parse().map_err(CliError::failed_to_execute_aleo_node)?;
|
||||||
|
|
||||||
|
// Log the output of the `aleo node` command.
|
||||||
|
tracing::info!("{}", res);
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
}
|
@ -21,6 +21,9 @@ pub use build::Build;
|
|||||||
pub mod clean;
|
pub mod clean;
|
||||||
pub use clean::Clean;
|
pub use clean::Clean;
|
||||||
|
|
||||||
|
pub mod deploy;
|
||||||
|
pub use deploy::Deploy;
|
||||||
|
|
||||||
pub mod new;
|
pub mod new;
|
||||||
pub use new::New;
|
pub use new::New;
|
||||||
|
|
||||||
|
@ -43,11 +43,11 @@ impl Command for Node {
|
|||||||
tracing::span!(tracing::Level::INFO, "Node")
|
tracing::span!(tracing::Level::INFO, "Node")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn prelude(&self, _context: Context) -> Result<Self::Input> {
|
fn prelude(&self, _: Context) -> Result<Self::Input> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn apply(self, context: Context, _input: Self::Input) -> Result<Self::Output> {
|
fn apply(self, context: Context, _: Self::Input) -> Result<Self::Output> {
|
||||||
// Compose the `aleo node` command.
|
// Compose the `aleo node` command.
|
||||||
let mut arguments = vec![ALEO_CLI_COMMAND.to_string()];
|
let mut arguments = vec![ALEO_CLI_COMMAND.to_string()];
|
||||||
|
|
||||||
|
@ -84,6 +84,12 @@ enum Commands {
|
|||||||
},
|
},
|
||||||
#[structopt(subcommand)]
|
#[structopt(subcommand)]
|
||||||
Node(Node),
|
Node(Node),
|
||||||
|
|
||||||
|
#[structopt(about = "Deploy a program")]
|
||||||
|
Deploy {
|
||||||
|
#[structopt(flatten)]
|
||||||
|
command: Deploy,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
fn set_panic_hook() {
|
fn set_panic_hook() {
|
||||||
@ -143,12 +149,12 @@ pub fn run_with_args(cli: CLI) -> Result<()> {
|
|||||||
let context = handle_error(Context::new(cli.path));
|
let context = handle_error(Context::new(cli.path));
|
||||||
|
|
||||||
match cli.command {
|
match cli.command {
|
||||||
// CommandOpts::Init { command } => command.try_execute(context),
|
|
||||||
Commands::New { command } => command.try_execute(context),
|
Commands::New { command } => command.try_execute(context),
|
||||||
Commands::Build { command } => command.try_execute(context),
|
Commands::Build { command } => command.try_execute(context),
|
||||||
Commands::Clean { command } => command.try_execute(context),
|
Commands::Clean { command } => command.try_execute(context),
|
||||||
Commands::Run { command } => command.try_execute(context),
|
Commands::Run { command } => command.try_execute(context),
|
||||||
Commands::Node(command) => command.try_execute(context),
|
Commands::Node(command) => command.try_execute(context),
|
||||||
|
Commands::Deploy { command } => command.try_execute(context),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user