use crate::error::*;
use std::path::{Path, PathBuf};
use std::process::Command;
#[derive(Debug, PartialEq)]
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, PartialEq)]
pub enum KsPass {
KsPassPass,
KsPassFile,
}
#[derive(Debug, PartialEq)]
pub enum KeyPass {
KeyPassPass,
KeyPassFile,
}
impl BuildApks {
pub fn new(bundle: &Path, output: &Path) -> Self {
Self {
bundle: bundle.to_owned(),
output: output.to_owned(),
overwrite: false,
aapt2: None,
ks: None,
ks_pass_pass: None,
ks_pass_file: None,
ks_key_alias: None,
key_pass_pass: None,
key_pass_file: None,
connected_device: false,
device_id: None,
device_spec: None,
mode_universal: false,
local_testing: false,
}
}
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<()> {
let mut build_apks = Command::new("java");
build_apks.arg("-jar");
if let Ok(bundletool_path) = std::env::var("BUNDLETOOL_PATH") {
build_apks.arg(bundletool_path);
} else {
return Err(Error::BundletoolNotFound);
}
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=pass:").arg(ks_pass_pass);
}
if let Some(ks_pass_file) = &self.ks_pass_file {
build_apks.arg("--ks-pass=file:").arg(ks_pass_file);
}
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=pass").arg(key_pass_pass);
}
if let Some(key_pass_file) = &self.key_pass_file {
build_apks.arg("--key-pass=file").arg(key_pass_file);
}
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=universal");
}
if self.local_testing {
build_apks.arg("--local-testing");
}
build_apks.output_err(true)?;
Ok(())
}
}