use super::bundletool;
use crate::error::*;
use std::path::{Path, PathBuf};
#[derive(Debug, Default)]
pub struct BuildApks {
bundle: PathBuf,
output: PathBuf,
overwrite: bool,
aapt2: Option<PathBuf>,
ks: Option<PathBuf>,
ks_pass_pass: Option<String>,
ks_pass_file: Option<PathBuf>,
ks_key_alias: Option<String>,
key_pass_pass: Option<String>,
key_pass_file: Option<PathBuf>,
connected_device: bool,
device_id: Option<String>,
device_spec: Option<PathBuf>,
mode_universal: bool,
local_testing: bool,
}
#[derive(Debug)]
pub enum KsPass {
KsPassPass,
KsPassFile,
}
#[derive(Debug)]
pub enum KeyPass {
KeyPassPass,
KeyPassFile,
}
impl BuildApks {
pub fn new(bundle: &Path, output: &Path) -> Self {
Self {
bundle: bundle.to_owned(),
output: output.to_owned(),
..Default::default()
}
}
pub fn overwrite(&mut self, overwrite: bool) -> &mut Self {
self.overwrite = overwrite;
self
}
pub fn aapt2(&mut self, aapt2: &Path) -> &mut Self {
self.aapt2 = Some(aapt2.to_owned());
self
}
pub fn ks(&mut self, ks: &Path) -> &mut Self {
self.ks = Some(ks.to_owned());
self
}
pub fn ks_pass_pass(&mut self, ks_pass_pass: String) -> &mut Self {
self.ks_pass_pass = Some(ks_pass_pass);
self
}
pub fn ks_pass_file(&mut self, ks_pass_file: &Path) -> &mut Self {
self.ks_pass_file = Some(ks_pass_file.to_owned());
self
}
pub fn ks_key_alias(&mut self, ks_key_alias: String) -> &mut Self {
self.ks_key_alias = Some(ks_key_alias);
self
}
pub fn key_pass_pass(&mut self, key_pass_pass: String) -> &mut Self {
self.key_pass_pass = Some(key_pass_pass);
self
}
pub fn key_pass_file(&mut self, key_pass_file: &Path) -> &mut Self {
self.key_pass_file = Some(key_pass_file.to_owned());
self
}
pub fn connected_device(&mut self, connected_device: bool) -> &mut Self {
self.connected_device = connected_device;
self
}
pub fn device_id(&mut self, device_id: String) -> &mut Self {
self.device_id = Some(device_id);
self
}
pub fn device_spec(&mut self, device_spec: &Path) -> &mut Self {
self.device_spec = Some(device_spec.to_owned());
self
}
pub fn mode_universal(&mut self, mode_universal: bool) -> &mut Self {
self.mode_universal = mode_universal;
self
}
pub fn local_testing(&mut self, local_testing: bool) -> &mut Self {
self.local_testing = local_testing;
self
}
pub fn run(&self) -> Result<PathBuf> {
let mut build_apks = bundletool()?;
build_apks.arg("build-apks");
build_apks.arg("--bundle").arg(&self.bundle);
build_apks.arg("--output").arg(&self.output);
if self.overwrite {
build_apks.arg("--overwrite");
}
if let Some(aapt2) = &self.aapt2 {
build_apks.arg("--aapt2").arg(aapt2);
}
if let Some(ks) = &self.ks {
build_apks.arg("--ks").arg(ks);
}
if let Some(ks_pass_pass) = &self.ks_pass_pass {
build_apks
.arg("--ks-pass")
.arg(format!("pass:{}", ks_pass_pass));
}
if let Some(ks_pass_file) = &self.ks_pass_file {
build_apks.arg("--ks-pass").arg(format!(
"file:{}",
ks_pass_file.to_str().expect("Wrong ks_pass_file provided")
));
}
if let Some(ks_key_alias) = &self.ks_key_alias {
build_apks.arg("--ks-key-alias").arg(ks_key_alias);
}
if let Some(key_pass_pass) = &self.key_pass_pass {
build_apks
.arg("--key-pass")
.arg(format!("pass:{}", key_pass_pass));
}
if let Some(key_pass_file) = &self.key_pass_file {
build_apks.arg("--key-pass").arg(format!(
"file:{}",
key_pass_file
.to_str()
.expect("Wrong key_pass_file provided")
));
}
if self.connected_device {
build_apks.arg("--connected-device");
}
if let Some(device_id) = &self.device_id {
build_apks.arg("--device-id").arg(device_id);
}
if let Some(device_spec) = &self.device_spec {
build_apks.arg("--device-spec").arg(device_spec);
}
if self.mode_universal {
build_apks.arg("--mode").arg("universal");
}
if self.local_testing {
build_apks.arg("--local-testing");
}
build_apks.output_err(true)?;
Ok(self.output.clone())
}
}