2021-02-19 17:14:50 +03:00
|
|
|
/*
|
|
|
|
* Copyright 2020 Fluence Labs Limited
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
use fluence_sdk_macro::fce;
|
|
|
|
|
|
|
|
use serde::Serialize;
|
|
|
|
use serde::Deserialize;
|
|
|
|
|
|
|
|
pub const SUCCESS_CODE: i32 = 0;
|
|
|
|
|
|
|
|
/// Describes result of calling a CLI service.
|
|
|
|
#[fce]
|
|
|
|
#[derive(Clone, PartialEq, Default, Eq, Debug, Serialize, Deserialize)]
|
2021-02-22 18:30:45 +03:00
|
|
|
pub struct Result {
|
2021-02-19 18:31:16 +03:00
|
|
|
/// Return process exit code or host execution error code, where SUCCESS_CODE means success.
|
2021-02-19 17:14:50 +03:00
|
|
|
pub ret_code: i32,
|
|
|
|
|
2021-02-19 22:50:38 +03:00
|
|
|
/// Contains the string representation of an error, if ret_code != SUCCESS_CODE.
|
|
|
|
pub error: String,
|
|
|
|
|
2021-02-19 18:31:16 +03:00
|
|
|
/// The data that the process wrote to stdout.
|
|
|
|
pub stdout: Vec<u8>,
|
2021-02-19 17:14:50 +03:00
|
|
|
|
2021-02-19 18:31:16 +03:00
|
|
|
/// The data that the process wrote to stderr.
|
|
|
|
pub stderr: Vec<u8>,
|
2021-02-19 17:14:50 +03:00
|
|
|
}
|
2021-02-19 17:45:27 +03:00
|
|
|
|
2021-02-22 18:30:45 +03:00
|
|
|
impl Result {
|
2021-02-19 18:31:16 +03:00
|
|
|
/// Create a new failure MountedBinaryResult from the provided ret_code.
|
2021-02-19 22:50:38 +03:00
|
|
|
pub fn from_error(ret_code: i32, error: impl Into<String>) -> Self {
|
2021-02-19 17:45:27 +03:00
|
|
|
Self {
|
|
|
|
ret_code,
|
2021-02-19 22:50:38 +03:00
|
|
|
error: error.into(),
|
2021-02-19 18:31:16 +03:00
|
|
|
stdout: Vec::new(),
|
|
|
|
stderr: Vec::new(),
|
2021-02-19 17:45:27 +03:00
|
|
|
}
|
|
|
|
}
|
2021-02-24 08:31:56 +03:00
|
|
|
|
2021-02-24 11:22:21 +03:00
|
|
|
/// Return true, if this Result represents a success result, otherwise false.
|
|
|
|
pub fn is_success(&self) -> bool {
|
2021-02-25 13:44:10 +03:00
|
|
|
self.ret_code == SUCCESS_CODE
|
2021-02-24 11:22:21 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/// This function tries to transform a result to the string representation.
|
|
|
|
/// Internally, It checks ret_code and returns either Some(Ok(stdout)) if it was SUCCESS_CODE
|
|
|
|
/// or Some(Err(error)) otherwise. None is returned if stdout or stderr contains non valid
|
|
|
|
/// UTF8 string.
|
|
|
|
pub fn into_std(self) -> Option<std::result::Result<String, String>> {
|
|
|
|
if self.ret_code == SUCCESS_CODE {
|
|
|
|
let stdout = String::from_utf8(self.stdout).ok()?;
|
|
|
|
Some(Ok(stdout))
|
|
|
|
} else {
|
|
|
|
let stderr = std::str::from_utf8(&self.stdout).ok()?;
|
|
|
|
Some(Ok(format!("error: {}, stderr: {}", self.error, stderr)))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-02-24 11:46:07 +03:00
|
|
|
/// This function tries to represent a result as a string.
|
2021-02-24 11:22:21 +03:00
|
|
|
/// Internally, It checks ret_code and returns either Some(Ok(stdout)) if it was SUCCESS_CODE
|
|
|
|
/// or Some(Err(error)) otherwise. None is returned if stdout or stderr contains non valid
|
|
|
|
/// UTF8 string.
|
|
|
|
pub fn as_std(&self) -> Option<std::result::Result<String, String>> {
|
2021-02-24 08:31:56 +03:00
|
|
|
if self.ret_code == SUCCESS_CODE {
|
2021-02-24 11:22:21 +03:00
|
|
|
let stdout = String::from_utf8(self.stdout.clone()).ok()?;
|
|
|
|
Some(Ok(stdout))
|
2021-02-24 08:31:56 +03:00
|
|
|
} else {
|
2021-02-24 11:22:21 +03:00
|
|
|
let stderr = std::str::from_utf8(&self.stdout).ok()?;
|
|
|
|
Some(Ok(format!("error: {}, stderr: {}", self.error, stderr)))
|
2021-02-24 08:31:56 +03:00
|
|
|
}
|
|
|
|
}
|
2021-02-19 17:45:27 +03:00
|
|
|
}
|