Files
adcs_api
cbor_protocol
channel_protocol
clyde_3g_eps_api
clyde_3g_eps_service
comms_service
db_test
eps_api
example_rust_c_service
example_rust_service
extern_lib
file_protocol
file_service
iobc_supervisor_service
isis_ants
isis_ants_api
isis_ants_service
isis_imtq_api
isis_iobc_supervisor
kubos_app
kubos_app_service
kubos_build_helper
kubos_file_client
kubos_service
kubos_shell_client
kubos_system
kubos_telemetry_db
large_download
large_upload
local_comms_service
mai400
mai400_api
mai400_service
monitor_service
novatel_oem6_api
novatel_oem6_service
nsl_duplex_d2
nsl_duplex_d2_comms_service
obc_hs
radio_api
rust_i2c
rust_mission_app
rust_uart
scheduler_service
serial_comms_service
shell_protocol
shell_service
telemetry_service
uart_comms_client
udp_client
utils
  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
/*
 * Copyright (C) 2018 Kubos Corporation
 *
 * 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 crate::error::*;
use serde_derive::{Deserialize, Serialize};
use std::fs;
use std::io::Write;
use std::path::PathBuf;
use toml;

/// The high level metadata of an application derived from the `manifest.toml` file during
/// registration
#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct AppMetadata {
    /// A unique name for the application
    pub name: String,
    /// Optional. The path of the file which should be called to kick off execution.
    /// If not specified, ``name`` will be used.
    pub executable: Option<String>,
    /// The version of this application
    pub version: String,
    /// The author of the application
    pub author: String,
    /// The custom configuration file which should be passed to the application when it is started
    pub config: Option<String>,
}
/// Kubos App struct
#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct App {
    /// The name of the application
    pub name: String,
    /// The absolute path to the application executable
    pub executable: String,
    /// The version of this instance of the application
    pub version: String,
    /// The author of the application
    pub author: String,
    /// Configuration file to be passed to the application
    pub config: String,
}
/// AppRegistryEntry
#[derive(Clone, Debug, Deserialize, Serialize)]
pub struct AppRegistryEntry {
    /// Whether or not this application is the active installation
    pub active_version: bool,
    /// The app itself
    pub app: App,
}

impl AppRegistryEntry {
    // Fetch a registered apps entry information
    pub fn from_dir(dir: &PathBuf) -> Result<AppRegistryEntry, AppError> {
        let mut app_toml = dir.clone();
        app_toml.push("app.toml");
        if !app_toml.exists() {
            return Err(AppError::FileError {
                err: "No app.toml file found".to_owned(),
            });
        }

        let app_entry = fs::read_to_string(app_toml)?;

        match toml::from_str::<AppRegistryEntry>(&app_entry) {
            Ok(entry) => Ok(entry),
            Err(error) => Err(AppError::ParseError {
                entity: "app.toml".to_owned(),
                err: error.to_string(),
            }),
        }
    }

    // Create or update a registered apps entry information
    pub fn save(&self) -> Result<(), AppError> {
        let mut app_toml = PathBuf::from(self.app.executable.clone());
        app_toml.set_file_name("app.toml");

        let mut file = fs::File::create(app_toml)?;
        let toml_str = match toml::to_string(&self) {
            Ok(toml) => toml,
            Err(error) => {
                return Err(AppError::ParseError {
                    entity: "app entry".to_owned(),
                    err: error.to_string(),
                });
            }
        };

        file.write_all(&toml_str.into_bytes())?;
        Ok(())
    }
}