mirror of
https://github.com/OMGeeky/google-apis-rs.git
synced 2026-01-02 09:31:13 +01:00
2846 lines
146 KiB
Rust
2846 lines
146 KiB
Rust
// DO NOT EDIT !
|
||
// This file was generated automatically from 'src/generator/templates/cli/main.rs.mako'
|
||
// DO NOT EDIT !
|
||
#![allow(unused_variables, unused_imports, dead_code, unused_mut)]
|
||
|
||
#[macro_use]
|
||
extern crate clap;
|
||
|
||
use std::env;
|
||
use std::io::{self, Write};
|
||
use clap::{App, SubCommand, Arg};
|
||
|
||
use google_androiddeviceprovisioning1::{api, Error, oauth2, client::chrono, FieldMask};
|
||
|
||
|
||
use google_clis_common as client;
|
||
|
||
use client::{InvalidOptionsError, CLIError, arg_from_str, writer_from_opts, parse_kv_arg,
|
||
input_file_from_opts, input_mime_from_opts, FieldCursor, FieldError, CallType, UploadProtocol,
|
||
calltype_from_str, remove_json_null_values, ComplexType, JsonType, JsonTypeInfo};
|
||
|
||
use std::default::Default;
|
||
use std::error::Error as StdError;
|
||
use std::str::FromStr;
|
||
|
||
use serde_json as json;
|
||
use clap::ArgMatches;
|
||
use http::Uri;
|
||
use hyper::client::connect;
|
||
use tokio::io::{AsyncRead, AsyncWrite};
|
||
use tower_service;
|
||
|
||
enum DoitError {
|
||
IoError(String, io::Error),
|
||
ApiError(Error),
|
||
}
|
||
|
||
struct Engine<'n, S> {
|
||
opt: ArgMatches<'n>,
|
||
hub: api::AndroidProvisioningPartner<S>,
|
||
gp: Vec<&'static str>,
|
||
gpm: Vec<(&'static str, &'static str)>,
|
||
}
|
||
|
||
|
||
impl<'n, S> Engine<'n, S>
|
||
where
|
||
S: tower_service::Service<Uri> + Clone + Send + Sync + 'static,
|
||
S::Response: hyper::client::connect::Connection + AsyncRead + AsyncWrite + Send + Unpin + 'static,
|
||
S::Future: Send + Unpin + 'static,
|
||
S::Error: Into<Box<dyn StdError + Send + Sync>>,
|
||
{
|
||
async fn _customers_configurations_create(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"company-name" => Some(("companyName", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"configuration-id" => Some(("configurationId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"configuration-name" => Some(("configurationName", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"contact-email" => Some(("contactEmail", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"contact-phone" => Some(("contactPhone", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"custom-message" => Some(("customMessage", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"dpc-extras" => Some(("dpcExtras", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"dpc-resource-path" => Some(("dpcResourcePath", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"is-default" => Some(("isDefault", JsonTypeInfo { jtype: JsonType::Boolean, ctype: ComplexType::Pod })),
|
||
"name" => Some(("name", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["company-name", "configuration-id", "configuration-name", "contact-email", "contact-phone", "custom-message", "dpc-extras", "dpc-resource-path", "is-default", "name"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::Configuration = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.customers().configurations_create(request, opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_configurations_delete(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().configurations_delete(opt.value_of("name").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_configurations_get(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().configurations_get(opt.value_of("name").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_configurations_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().configurations_list(opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_configurations_patch(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"company-name" => Some(("companyName", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"configuration-id" => Some(("configurationId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"configuration-name" => Some(("configurationName", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"contact-email" => Some(("contactEmail", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"contact-phone" => Some(("contactPhone", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"custom-message" => Some(("customMessage", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"dpc-extras" => Some(("dpcExtras", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"dpc-resource-path" => Some(("dpcResourcePath", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"is-default" => Some(("isDefault", JsonTypeInfo { jtype: JsonType::Boolean, ctype: ComplexType::Pod })),
|
||
"name" => Some(("name", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["company-name", "configuration-id", "configuration-name", "contact-email", "contact-phone", "custom-message", "dpc-extras", "dpc-resource-path", "is-default", "name"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::Configuration = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.customers().configurations_patch(request, opt.value_of("name").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
"update-mask" => {
|
||
call = call.update_mask( value.map(|v| arg_from_str(v, err, "update-mask", "google-fieldmask")).unwrap_or(FieldMask::default()));
|
||
},
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v.extend(["update-mask"].iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_devices_apply_configuration(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"configuration" => Some(("configuration", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-id" => Some(("device.deviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.chrome-os-attested-device-id" => Some(("device.deviceIdentifier.chromeOsAttestedDeviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.device-type" => Some(("device.deviceIdentifier.deviceType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.imei" => Some(("device.deviceIdentifier.imei", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.manufacturer" => Some(("device.deviceIdentifier.manufacturer", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.meid" => Some(("device.deviceIdentifier.meid", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.model" => Some(("device.deviceIdentifier.model", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.serial-number" => Some(("device.deviceIdentifier.serialNumber", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["chrome-os-attested-device-id", "configuration", "device", "device-id", "device-identifier", "device-type", "imei", "manufacturer", "meid", "model", "serial-number"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::CustomerApplyConfigurationRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.customers().devices_apply_configuration(request, opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_devices_get(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().devices_get(opt.value_of("name").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_devices_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().devices_list(opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
"page-token" => {
|
||
call = call.page_token(value.unwrap_or(""));
|
||
},
|
||
"page-size" => {
|
||
call = call.page_size( value.map(|v| arg_from_str(v, err, "page-size", "int64")).unwrap_or(-0));
|
||
},
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v.extend(["page-size", "page-token"].iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_devices_remove_configuration(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"device.device-id" => Some(("device.deviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.chrome-os-attested-device-id" => Some(("device.deviceIdentifier.chromeOsAttestedDeviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.device-type" => Some(("device.deviceIdentifier.deviceType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.imei" => Some(("device.deviceIdentifier.imei", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.manufacturer" => Some(("device.deviceIdentifier.manufacturer", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.meid" => Some(("device.deviceIdentifier.meid", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.model" => Some(("device.deviceIdentifier.model", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.serial-number" => Some(("device.deviceIdentifier.serialNumber", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["chrome-os-attested-device-id", "device", "device-id", "device-identifier", "device-type", "imei", "manufacturer", "meid", "model", "serial-number"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::CustomerRemoveConfigurationRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.customers().devices_remove_configuration(request, opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_devices_unclaim(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"device.device-id" => Some(("device.deviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.chrome-os-attested-device-id" => Some(("device.deviceIdentifier.chromeOsAttestedDeviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.device-type" => Some(("device.deviceIdentifier.deviceType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.imei" => Some(("device.deviceIdentifier.imei", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.manufacturer" => Some(("device.deviceIdentifier.manufacturer", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.meid" => Some(("device.deviceIdentifier.meid", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.model" => Some(("device.deviceIdentifier.model", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device.device-identifier.serial-number" => Some(("device.deviceIdentifier.serialNumber", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["chrome-os-attested-device-id", "device", "device-id", "device-identifier", "device-type", "imei", "manufacturer", "meid", "model", "serial-number"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::CustomerUnclaimDeviceRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.customers().devices_unclaim(request, opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_dpcs_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().dpcs_list(opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _customers_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.customers().list();
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
"page-token" => {
|
||
call = call.page_token(value.unwrap_or(""));
|
||
},
|
||
"page-size" => {
|
||
call = call.page_size( value.map(|v| arg_from_str(v, err, "page-size", "int32")).unwrap_or(-0));
|
||
},
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v.extend(["page-size", "page-token"].iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _operations_get(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.operations().get(opt.value_of("name").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_customers_create(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"customer.admin-emails" => Some(("customer.adminEmails", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Vec })),
|
||
"customer.company-id" => Some(("customer.companyId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"customer.company-name" => Some(("customer.companyName", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"customer.google-workspace-account.customer-id" => Some(("customer.googleWorkspaceAccount.customerId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"customer.google-workspace-account.pre-provisioning-tokens" => Some(("customer.googleWorkspaceAccount.preProvisioningTokens", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Vec })),
|
||
"customer.language-code" => Some(("customer.languageCode", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"customer.name" => Some(("customer.name", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"customer.owner-emails" => Some(("customer.ownerEmails", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Vec })),
|
||
"customer.skip-welcome-email" => Some(("customer.skipWelcomeEmail", JsonTypeInfo { jtype: JsonType::Boolean, ctype: ComplexType::Pod })),
|
||
"customer.terms-status" => Some(("customer.termsStatus", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["admin-emails", "company-id", "company-name", "customer", "customer-id", "google-workspace-account", "language-code", "name", "owner-emails", "pre-provisioning-tokens", "skip-welcome-email", "terms-status"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::CreateCustomerRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().customers_create(request, opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_customers_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.partners().customers_list(opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
"page-token" => {
|
||
call = call.page_token(value.unwrap_or(""));
|
||
},
|
||
"page-size" => {
|
||
call = call.page_size( value.map(|v| arg_from_str(v, err, "page-size", "int32")).unwrap_or(-0));
|
||
},
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v.extend(["page-size", "page-token"].iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_claim(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"customer-id" => Some(("customerId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.chrome-os-attested-device-id" => Some(("deviceIdentifier.chromeOsAttestedDeviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.device-type" => Some(("deviceIdentifier.deviceType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.imei" => Some(("deviceIdentifier.imei", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.manufacturer" => Some(("deviceIdentifier.manufacturer", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.meid" => Some(("deviceIdentifier.meid", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.model" => Some(("deviceIdentifier.model", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.serial-number" => Some(("deviceIdentifier.serialNumber", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-metadata.entries" => Some(("deviceMetadata.entries", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Map })),
|
||
"google-workspace-customer-id" => Some(("googleWorkspaceCustomerId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"pre-provisioning-token" => Some(("preProvisioningToken", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"section-type" => Some(("sectionType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"simlock-profile-id" => Some(("simlockProfileId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["chrome-os-attested-device-id", "customer-id", "device-identifier", "device-metadata", "device-type", "entries", "google-workspace-customer-id", "imei", "manufacturer", "meid", "model", "pre-provisioning-token", "section-type", "serial-number", "simlock-profile-id"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::ClaimDeviceRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_claim(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_claim_async(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec![]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::ClaimDevicesRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_claim_async(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_find_by_identifier(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"device-identifier.chrome-os-attested-device-id" => Some(("deviceIdentifier.chromeOsAttestedDeviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.device-type" => Some(("deviceIdentifier.deviceType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.imei" => Some(("deviceIdentifier.imei", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.manufacturer" => Some(("deviceIdentifier.manufacturer", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.meid" => Some(("deviceIdentifier.meid", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.model" => Some(("deviceIdentifier.model", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.serial-number" => Some(("deviceIdentifier.serialNumber", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"limit" => Some(("limit", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"page-token" => Some(("pageToken", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["chrome-os-attested-device-id", "device-identifier", "device-type", "imei", "limit", "manufacturer", "meid", "model", "page-token", "serial-number"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::FindDevicesByDeviceIdentifierRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_find_by_identifier(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_find_by_owner(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"customer-id" => Some(("customerId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Vec })),
|
||
"google-workspace-customer-id" => Some(("googleWorkspaceCustomerId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Vec })),
|
||
"limit" => Some(("limit", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"page-token" => Some(("pageToken", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"section-type" => Some(("sectionType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["customer-id", "google-workspace-customer-id", "limit", "page-token", "section-type"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::FindDevicesByOwnerRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_find_by_owner(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_get(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.partners().devices_get(opt.value_of("name").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_metadata(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"device-metadata.entries" => Some(("deviceMetadata.entries", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Map })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["device-metadata", "entries"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::UpdateDeviceMetadataRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_metadata(request, opt.value_of("metadata-owner-id").unwrap_or(""), opt.value_of("device-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_unclaim(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
"device-id" => Some(("deviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.chrome-os-attested-device-id" => Some(("deviceIdentifier.chromeOsAttestedDeviceId", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.device-type" => Some(("deviceIdentifier.deviceType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.imei" => Some(("deviceIdentifier.imei", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.manufacturer" => Some(("deviceIdentifier.manufacturer", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.meid" => Some(("deviceIdentifier.meid", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.model" => Some(("deviceIdentifier.model", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"device-identifier.serial-number" => Some(("deviceIdentifier.serialNumber", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"section-type" => Some(("sectionType", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
"vacation-mode-days" => Some(("vacationModeDays", JsonTypeInfo { jtype: JsonType::Int, ctype: ComplexType::Pod })),
|
||
"vacation-mode-expire-time" => Some(("vacationModeExpireTime", JsonTypeInfo { jtype: JsonType::String, ctype: ComplexType::Pod })),
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec!["chrome-os-attested-device-id", "device-id", "device-identifier", "device-type", "imei", "manufacturer", "meid", "model", "section-type", "serial-number", "vacation-mode-days", "vacation-mode-expire-time"]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::UnclaimDeviceRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_unclaim(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_unclaim_async(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec![]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::UnclaimDevicesRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_unclaim_async(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_devices_update_metadata_async(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
|
||
let mut field_cursor = FieldCursor::default();
|
||
let mut object = json::value::Value::Object(Default::default());
|
||
|
||
for kvarg in opt.values_of("kv").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let last_errc = err.issues.len();
|
||
let (key, value) = parse_kv_arg(&*kvarg, err, false);
|
||
let mut temp_cursor = field_cursor.clone();
|
||
if let Err(field_err) = temp_cursor.set(&*key) {
|
||
err.issues.push(field_err);
|
||
}
|
||
if value.is_none() {
|
||
field_cursor = temp_cursor.clone();
|
||
if err.issues.len() > last_errc {
|
||
err.issues.remove(last_errc);
|
||
}
|
||
continue;
|
||
}
|
||
|
||
let type_info: Option<(&'static str, JsonTypeInfo)> =
|
||
match &temp_cursor.to_string()[..] {
|
||
_ => {
|
||
let suggestion = FieldCursor::did_you_mean(key, &vec![]);
|
||
err.issues.push(CLIError::Field(FieldError::Unknown(temp_cursor.to_string(), suggestion, value.map(|v| v.to_string()))));
|
||
None
|
||
}
|
||
};
|
||
if let Some((field_cursor_str, type_info)) = type_info {
|
||
FieldCursor::from(field_cursor_str).set_json_value(&mut object, value.unwrap(), type_info, err, &temp_cursor);
|
||
}
|
||
}
|
||
let mut request: api::UpdateDeviceMetadataInBatchRequest = json::value::from_value(object).unwrap();
|
||
let mut call = self.hub.partners().devices_update_metadata_async(request, opt.value_of("partner-id").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_vendors_customers_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.partners().vendors_customers_list(opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
"page-token" => {
|
||
call = call.page_token(value.unwrap_or(""));
|
||
},
|
||
"page-size" => {
|
||
call = call.page_size( value.map(|v| arg_from_str(v, err, "page-size", "int32")).unwrap_or(-0));
|
||
},
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v.extend(["page-size", "page-token"].iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _partners_vendors_list(&self, opt: &ArgMatches<'n>, dry_run: bool, err: &mut InvalidOptionsError)
|
||
-> Result<(), DoitError> {
|
||
let mut call = self.hub.partners().vendors_list(opt.value_of("parent").unwrap_or(""));
|
||
for parg in opt.values_of("v").map(|i|i.collect()).unwrap_or(Vec::new()).iter() {
|
||
let (key, value) = parse_kv_arg(&*parg, err, false);
|
||
match key {
|
||
"page-token" => {
|
||
call = call.page_token(value.unwrap_or(""));
|
||
},
|
||
"page-size" => {
|
||
call = call.page_size( value.map(|v| arg_from_str(v, err, "page-size", "int32")).unwrap_or(-0));
|
||
},
|
||
_ => {
|
||
let mut found = false;
|
||
for param in &self.gp {
|
||
if key == *param {
|
||
found = true;
|
||
call = call.param(self.gpm.iter().find(|t| t.0 == key).unwrap_or(&("", key)).1, value.unwrap_or("unset"));
|
||
break;
|
||
}
|
||
}
|
||
if !found {
|
||
err.issues.push(CLIError::UnknownParameter(key.to_string(),
|
||
{let mut v = Vec::new();
|
||
v.extend(self.gp.iter().map(|v|*v));
|
||
v.extend(["page-size", "page-token"].iter().map(|v|*v));
|
||
v } ));
|
||
}
|
||
}
|
||
}
|
||
}
|
||
let protocol = CallType::Standard;
|
||
if dry_run {
|
||
Ok(())
|
||
} else {
|
||
assert!(err.issues.len() == 0);
|
||
let mut ostream = match writer_from_opts(opt.value_of("out")) {
|
||
Ok(mut f) => f,
|
||
Err(io_err) => return Err(DoitError::IoError(opt.value_of("out").unwrap_or("-").to_string(), io_err)),
|
||
};
|
||
match match protocol {
|
||
CallType::Standard => call.doit().await,
|
||
_ => unreachable!()
|
||
} {
|
||
Err(api_err) => Err(DoitError::ApiError(api_err)),
|
||
Ok((mut response, output_schema)) => {
|
||
let mut value = json::value::to_value(&output_schema).expect("serde to work");
|
||
remove_json_null_values(&mut value);
|
||
json::to_writer_pretty(&mut ostream, &value).unwrap();
|
||
ostream.flush().unwrap();
|
||
Ok(())
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
async fn _doit(&self, dry_run: bool) -> Result<Result<(), DoitError>, Option<InvalidOptionsError>> {
|
||
let mut err = InvalidOptionsError::new();
|
||
let mut call_result: Result<(), DoitError> = Ok(());
|
||
let mut err_opt: Option<InvalidOptionsError> = None;
|
||
match self.opt.subcommand() {
|
||
("customers", Some(opt)) => {
|
||
match opt.subcommand() {
|
||
("configurations-create", Some(opt)) => {
|
||
call_result = self._customers_configurations_create(opt, dry_run, &mut err).await;
|
||
},
|
||
("configurations-delete", Some(opt)) => {
|
||
call_result = self._customers_configurations_delete(opt, dry_run, &mut err).await;
|
||
},
|
||
("configurations-get", Some(opt)) => {
|
||
call_result = self._customers_configurations_get(opt, dry_run, &mut err).await;
|
||
},
|
||
("configurations-list", Some(opt)) => {
|
||
call_result = self._customers_configurations_list(opt, dry_run, &mut err).await;
|
||
},
|
||
("configurations-patch", Some(opt)) => {
|
||
call_result = self._customers_configurations_patch(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-apply-configuration", Some(opt)) => {
|
||
call_result = self._customers_devices_apply_configuration(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-get", Some(opt)) => {
|
||
call_result = self._customers_devices_get(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-list", Some(opt)) => {
|
||
call_result = self._customers_devices_list(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-remove-configuration", Some(opt)) => {
|
||
call_result = self._customers_devices_remove_configuration(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-unclaim", Some(opt)) => {
|
||
call_result = self._customers_devices_unclaim(opt, dry_run, &mut err).await;
|
||
},
|
||
("dpcs-list", Some(opt)) => {
|
||
call_result = self._customers_dpcs_list(opt, dry_run, &mut err).await;
|
||
},
|
||
("list", Some(opt)) => {
|
||
call_result = self._customers_list(opt, dry_run, &mut err).await;
|
||
},
|
||
_ => {
|
||
err.issues.push(CLIError::MissingMethodError("customers".to_string()));
|
||
writeln!(io::stderr(), "{}\n", opt.usage()).ok();
|
||
}
|
||
}
|
||
},
|
||
("operations", Some(opt)) => {
|
||
match opt.subcommand() {
|
||
("get", Some(opt)) => {
|
||
call_result = self._operations_get(opt, dry_run, &mut err).await;
|
||
},
|
||
_ => {
|
||
err.issues.push(CLIError::MissingMethodError("operations".to_string()));
|
||
writeln!(io::stderr(), "{}\n", opt.usage()).ok();
|
||
}
|
||
}
|
||
},
|
||
("partners", Some(opt)) => {
|
||
match opt.subcommand() {
|
||
("customers-create", Some(opt)) => {
|
||
call_result = self._partners_customers_create(opt, dry_run, &mut err).await;
|
||
},
|
||
("customers-list", Some(opt)) => {
|
||
call_result = self._partners_customers_list(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-claim", Some(opt)) => {
|
||
call_result = self._partners_devices_claim(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-claim-async", Some(opt)) => {
|
||
call_result = self._partners_devices_claim_async(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-find-by-identifier", Some(opt)) => {
|
||
call_result = self._partners_devices_find_by_identifier(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-find-by-owner", Some(opt)) => {
|
||
call_result = self._partners_devices_find_by_owner(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-get", Some(opt)) => {
|
||
call_result = self._partners_devices_get(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-metadata", Some(opt)) => {
|
||
call_result = self._partners_devices_metadata(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-unclaim", Some(opt)) => {
|
||
call_result = self._partners_devices_unclaim(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-unclaim-async", Some(opt)) => {
|
||
call_result = self._partners_devices_unclaim_async(opt, dry_run, &mut err).await;
|
||
},
|
||
("devices-update-metadata-async", Some(opt)) => {
|
||
call_result = self._partners_devices_update_metadata_async(opt, dry_run, &mut err).await;
|
||
},
|
||
("vendors-customers-list", Some(opt)) => {
|
||
call_result = self._partners_vendors_customers_list(opt, dry_run, &mut err).await;
|
||
},
|
||
("vendors-list", Some(opt)) => {
|
||
call_result = self._partners_vendors_list(opt, dry_run, &mut err).await;
|
||
},
|
||
_ => {
|
||
err.issues.push(CLIError::MissingMethodError("partners".to_string()));
|
||
writeln!(io::stderr(), "{}\n", opt.usage()).ok();
|
||
}
|
||
}
|
||
},
|
||
_ => {
|
||
err.issues.push(CLIError::MissingCommandError);
|
||
writeln!(io::stderr(), "{}\n", self.opt.usage()).ok();
|
||
}
|
||
}
|
||
|
||
if dry_run {
|
||
if err.issues.len() > 0 {
|
||
err_opt = Some(err);
|
||
}
|
||
Err(err_opt)
|
||
} else {
|
||
Ok(call_result)
|
||
}
|
||
}
|
||
|
||
// Please note that this call will fail if any part of the opt can't be handled
|
||
async fn new(opt: ArgMatches<'n>, connector: S) -> Result<Engine<'n, S>, InvalidOptionsError> {
|
||
let (config_dir, secret) = {
|
||
let config_dir = match client::assure_config_dir_exists(opt.value_of("folder").unwrap_or("~/.google-service-cli")) {
|
||
Err(e) => return Err(InvalidOptionsError::single(e, 3)),
|
||
Ok(p) => p,
|
||
};
|
||
|
||
match client::application_secret_from_directory(&config_dir, "androiddeviceprovisioning1-secret.json",
|
||
"{\"installed\":{\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"client_secret\":\"hCsslbCUyfehWMmbkG8vTYxG\",\"token_uri\":\"https://accounts.google.com/o/oauth2/token\",\"client_email\":\"\",\"redirect_uris\":[\"urn:ietf:wg:oauth:2.0:oob\",\"oob\"],\"client_x509_cert_url\":\"\",\"client_id\":\"620010449518-9ngf7o4dhs0dka470npqvor6dc5lqb9b.apps.googleusercontent.com\",\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\"}}") {
|
||
Ok(secret) => (config_dir, secret),
|
||
Err(e) => return Err(InvalidOptionsError::single(e, 4))
|
||
}
|
||
};
|
||
|
||
let client = hyper::Client::builder().build(connector);
|
||
|
||
let auth = oauth2::InstalledFlowAuthenticator::with_client(
|
||
secret,
|
||
oauth2::InstalledFlowReturnMethod::HTTPRedirect,
|
||
client.clone(),
|
||
).persist_tokens_to_disk(format!("{}/androiddeviceprovisioning1", config_dir)).build().await.unwrap();
|
||
|
||
let engine = Engine {
|
||
opt: opt,
|
||
hub: api::AndroidProvisioningPartner::new(client, auth),
|
||
gp: vec!["$-xgafv", "access-token", "alt", "callback", "fields", "key", "oauth-token", "pretty-print", "quota-user", "upload-type", "upload-protocol"],
|
||
gpm: vec![
|
||
("$-xgafv", "$.xgafv"),
|
||
("access-token", "access_token"),
|
||
("oauth-token", "oauth_token"),
|
||
("pretty-print", "prettyPrint"),
|
||
("quota-user", "quotaUser"),
|
||
("upload-type", "uploadType"),
|
||
("upload-protocol", "upload_protocol"),
|
||
]
|
||
};
|
||
|
||
match engine._doit(true).await {
|
||
Err(Some(err)) => Err(err),
|
||
Err(None) => Ok(engine),
|
||
Ok(_) => unreachable!(),
|
||
}
|
||
}
|
||
|
||
async fn doit(&self) -> Result<(), DoitError> {
|
||
match self._doit(false).await {
|
||
Ok(res) => res,
|
||
Err(_) => unreachable!(),
|
||
}
|
||
}
|
||
}
|
||
|
||
#[tokio::main]
|
||
async fn main() {
|
||
let mut exit_status = 0i32;
|
||
let arg_data = [
|
||
("customers", "methods: 'configurations-create', 'configurations-delete', 'configurations-get', 'configurations-list', 'configurations-patch', 'devices-apply-configuration', 'devices-get', 'devices-list', 'devices-remove-configuration', 'devices-unclaim', 'dpcs-list' and 'list'", vec![
|
||
("configurations-create",
|
||
Some(r##"Creates a new configuration. Once created, a customer can apply the configuration to devices."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_configurations-create",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer that manages the configuration. An API resource name in the format `customers/[CUSTOMER_ID]`. This field has custom validation in CreateConfigurationRequestValidator"##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("configurations-delete",
|
||
Some(r##"Deletes an unused configuration. The API call fails if the customer has devices with the configuration applied."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_configurations-delete",
|
||
vec![
|
||
(Some(r##"name"##),
|
||
None,
|
||
Some(r##"Required. The configuration to delete. An API resource name in the format `customers/[CUSTOMER_ID]/configurations/[CONFIGURATION_ID]`. If the configuration is applied to any devices, the API call fails."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("configurations-get",
|
||
Some(r##"Gets the details of a configuration."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_configurations-get",
|
||
vec![
|
||
(Some(r##"name"##),
|
||
None,
|
||
Some(r##"Required. The configuration to get. An API resource name in the format `customers/[CUSTOMER_ID]/configurations/[CONFIGURATION_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("configurations-list",
|
||
Some(r##"Lists a customer's configurations."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_configurations-list",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer that manages the listed configurations. An API resource name in the format `customers/[CUSTOMER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("configurations-patch",
|
||
Some(r##"Updates a configuration's field values."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_configurations-patch",
|
||
vec![
|
||
(Some(r##"name"##),
|
||
None,
|
||
Some(r##"Output only. The API resource name in the format `customers/[CUSTOMER_ID]/configurations/[CONFIGURATION_ID]`. Assigned by the server."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-apply-configuration",
|
||
Some(r##"Applies a Configuration to the device to register the device for zero-touch enrollment. After applying a configuration to a device, the device automatically provisions itself on first boot, or next factory reset."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_devices-apply-configuration",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer managing the device. An API resource name in the format `customers/[CUSTOMER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-get",
|
||
Some(r##"Gets the details of a device."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_devices-get",
|
||
vec![
|
||
(Some(r##"name"##),
|
||
None,
|
||
Some(r##"Required. The device to get. An API resource name in the format `customers/[CUSTOMER_ID]/devices/[DEVICE_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-list",
|
||
Some(r##"Lists a customer's devices."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_devices-list",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer managing the devices. An API resource name in the format `customers/[CUSTOMER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-remove-configuration",
|
||
Some(r##"Removes a configuration from device."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_devices-remove-configuration",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer managing the device in the format `customers/[CUSTOMER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-unclaim",
|
||
Some(r##"Unclaims a device from a customer and removes it from zero-touch enrollment. After removing a device, a customer must contact their reseller to register the device into zero-touch enrollment again."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_devices-unclaim",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer managing the device. An API resource name in the format `customers/[CUSTOMER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("dpcs-list",
|
||
Some(r##"Lists the DPCs (device policy controllers) that support zero-touch enrollment."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_dpcs-list",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The customer that can use the DPCs in configurations. An API resource name in the format `customers/[CUSTOMER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("list",
|
||
Some(r##"Lists the user's customer accounts."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/customers_list",
|
||
vec![
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
]),
|
||
|
||
("operations", "methods: 'get'", vec![
|
||
("get",
|
||
Some(r##"Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/operations_get",
|
||
vec![
|
||
(Some(r##"name"##),
|
||
None,
|
||
Some(r##"The name of the operation resource."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
]),
|
||
|
||
("partners", "methods: 'customers-create', 'customers-list', 'devices-claim', 'devices-claim-async', 'devices-find-by-identifier', 'devices-find-by-owner', 'devices-get', 'devices-metadata', 'devices-unclaim', 'devices-unclaim-async', 'devices-update-metadata-async', 'vendors-customers-list' and 'vendors-list'", vec![
|
||
("customers-create",
|
||
Some(r##"Creates a customer for zero-touch enrollment. After the method returns successfully, admin and owner roles can manage devices and EMM configs by calling API methods or using their zero-touch enrollment portal. The customer receives an email that welcomes them to zero-touch enrollment and explains how to sign into the portal."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_customers-create",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The parent resource ID in the format `partners/[PARTNER_ID]` that identifies the reseller."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("customers-list",
|
||
Some(r##"Lists the customers that are enrolled to the reseller identified by the `partnerId` argument. This list includes customers that the reseller created and customers that enrolled themselves using the portal."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_customers-list",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the reseller partner."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-claim",
|
||
Some(r##"Claims a device for a customer and adds it to zero-touch enrollment. If the device is already claimed by another customer, the call returns an error."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-claim",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the reseller partner."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-claim-async",
|
||
Some(r##"Claims a batch of devices for a customer asynchronously. Adds the devices to zero-touch enrollment. To learn more, read [Long‑running batch operations](/zero-touch/guides/how-it-works#operations)."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-claim-async",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the reseller partner."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-find-by-identifier",
|
||
Some(r##"Finds devices by hardware identifiers, such as IMEI."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-find-by-identifier",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the reseller partner."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-find-by-owner",
|
||
Some(r##"Finds devices claimed for customers. The results only contain devices registered to the reseller that's identified by the `partnerId` argument. The customer's devices purchased from other resellers don't appear in the results."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-find-by-owner",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the reseller partner."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-get",
|
||
Some(r##"Gets a device."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-get",
|
||
vec![
|
||
(Some(r##"name"##),
|
||
None,
|
||
Some(r##"Required. The device API resource name in the format `partners/[PARTNER_ID]/devices/[DEVICE_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-metadata",
|
||
Some(r##"Updates reseller metadata associated with the device. Android devices only."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-metadata",
|
||
vec![
|
||
(Some(r##"metadata-owner-id"##),
|
||
None,
|
||
Some(r##"Required. The owner of the newly set metadata. Set this to the partner ID."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"device-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the device."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-unclaim",
|
||
Some(r##"Unclaims a device from a customer and removes it from zero-touch enrollment."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-unclaim",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The ID of the reseller partner."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-unclaim-async",
|
||
Some(r##"Unclaims a batch of devices for a customer asynchronously. Removes the devices from zero-touch enrollment. To learn more, read [Long‑running batch operations](/zero-touch/guides/how-it-works#operations)."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-unclaim-async",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The reseller partner ID."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("devices-update-metadata-async",
|
||
Some(r##"Updates the reseller metadata attached to a batch of devices. This method updates devices asynchronously and returns an `Operation` that can be used to track progress. Read [Long‑running batch operations](/zero-touch/guides/how-it-works#operations). Android Devices only."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_devices-update-metadata-async",
|
||
vec![
|
||
(Some(r##"partner-id"##),
|
||
None,
|
||
Some(r##"Required. The reseller partner ID."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"kv"##),
|
||
Some(r##"r"##),
|
||
Some(r##"Set various fields of the request structure, matching the key=value form"##),
|
||
Some(true),
|
||
Some(true)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("vendors-customers-list",
|
||
Some(r##"Lists the customers of the vendor."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_vendors-customers-list",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The resource name in the format `partners/[PARTNER_ID]/vendors/[VENDOR_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
("vendors-list",
|
||
Some(r##"Lists the vendors of the partner."##),
|
||
"Details at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli/partners_vendors-list",
|
||
vec![
|
||
(Some(r##"parent"##),
|
||
None,
|
||
Some(r##"Required. The resource name in the format `partners/[PARTNER_ID]`."##),
|
||
Some(true),
|
||
Some(false)),
|
||
|
||
(Some(r##"v"##),
|
||
Some(r##"p"##),
|
||
Some(r##"Set various optional parameters, matching the key=value form"##),
|
||
Some(false),
|
||
Some(true)),
|
||
|
||
(Some(r##"out"##),
|
||
Some(r##"o"##),
|
||
Some(r##"Specify the file into which to write the program's output"##),
|
||
Some(false),
|
||
Some(false)),
|
||
]),
|
||
]),
|
||
|
||
];
|
||
|
||
let mut app = App::new("androiddeviceprovisioning1")
|
||
.author("Sebastian Thiel <byronimo@gmail.com>")
|
||
.version("5.0.3+20230115")
|
||
.about("Automates Android zero-touch enrollment for device resellers, customers, and EMMs.")
|
||
.after_help("All documentation details can be found at http://byron.github.io/google-apis-rs/google_androiddeviceprovisioning1_cli")
|
||
.arg(Arg::with_name("folder")
|
||
.long("config-dir")
|
||
.help("A directory into which we will store our persistent data. Defaults to a user-writable directory that we will create during the first invocation.[default: ~/.google-service-cli")
|
||
.multiple(false)
|
||
.takes_value(true))
|
||
.arg(Arg::with_name("debug")
|
||
.long("debug")
|
||
.help("Debug print all errors")
|
||
.multiple(false)
|
||
.takes_value(false));
|
||
|
||
for &(main_command_name, about, ref subcommands) in arg_data.iter() {
|
||
let mut mcmd = SubCommand::with_name(main_command_name).about(about);
|
||
|
||
for &(sub_command_name, ref desc, url_info, ref args) in subcommands {
|
||
let mut scmd = SubCommand::with_name(sub_command_name);
|
||
if let &Some(desc) = desc {
|
||
scmd = scmd.about(desc);
|
||
}
|
||
scmd = scmd.after_help(url_info);
|
||
|
||
for &(ref arg_name, ref flag, ref desc, ref required, ref multi) in args {
|
||
let arg_name_str =
|
||
match (arg_name, flag) {
|
||
(&Some(an), _ ) => an,
|
||
(_ , &Some(f)) => f,
|
||
_ => unreachable!(),
|
||
};
|
||
let mut arg = Arg::with_name(arg_name_str)
|
||
.empty_values(false);
|
||
if let &Some(short_flag) = flag {
|
||
arg = arg.short(short_flag);
|
||
}
|
||
if let &Some(desc) = desc {
|
||
arg = arg.help(desc);
|
||
}
|
||
if arg_name.is_some() && flag.is_some() {
|
||
arg = arg.takes_value(true);
|
||
}
|
||
if let &Some(required) = required {
|
||
arg = arg.required(required);
|
||
}
|
||
if let &Some(multi) = multi {
|
||
arg = arg.multiple(multi);
|
||
}
|
||
scmd = scmd.arg(arg);
|
||
}
|
||
mcmd = mcmd.subcommand(scmd);
|
||
}
|
||
app = app.subcommand(mcmd);
|
||
}
|
||
|
||
let matches = app.get_matches();
|
||
|
||
let debug = matches.is_present("adebug");
|
||
let connector = hyper_rustls::HttpsConnectorBuilder::new().with_native_roots()
|
||
.https_or_http()
|
||
.enable_http1()
|
||
.build();
|
||
|
||
match Engine::new(matches, connector).await {
|
||
Err(err) => {
|
||
exit_status = err.exit_code;
|
||
writeln!(io::stderr(), "{}", err).ok();
|
||
},
|
||
Ok(engine) => {
|
||
if let Err(doit_err) = engine.doit().await {
|
||
exit_status = 1;
|
||
match doit_err {
|
||
DoitError::IoError(path, err) => {
|
||
writeln!(io::stderr(), "Failed to open output file '{}': {}", path, err).ok();
|
||
},
|
||
DoitError::ApiError(err) => {
|
||
if debug {
|
||
writeln!(io::stderr(), "{:#?}", err).ok();
|
||
} else {
|
||
writeln!(io::stderr(), "{}", err).ok();
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
std::process::exit(exit_status);
|
||
}
|