use reqwest::Method;
use serde::{Deserialize, Serialize};
use super::AppRoleService;
use crate::{
core::{
api_req::ApiRequest,
api_resp::{ApiResponseTrait, BaseResponse, ResponseFormat},
config::Config,
constants::AccessTokenType,
endpoints::cloud_docs::*,
http::Transport,
req_option::RequestOption,
SDKResult,
},
impl_executable_builder_owned,
service::bitable::v1::app_role::{AppRole, BlockRole, TableRole},
};
#[derive(Debug, Serialize, Default)]
pub struct UpdateAppRoleRequest {
#[serde(skip)]
api_request: ApiRequest,
#[serde(skip)]
app_token: String,
#[serde(skip)]
role_id: String,
#[serde(skip_serializing_if = "Option::is_none")]
role_name: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
table_roles: Option<Vec<TableRole>>,
#[serde(skip_serializing_if = "Option::is_none")]
block_roles: Option<Vec<BlockRole>>,
}
impl UpdateAppRoleRequest {
pub fn builder() -> UpdateAppRoleRequestBuilder {
UpdateAppRoleRequestBuilder::default()
}
pub fn new(app_token: impl ToString, role_id: impl ToString) -> Self {
Self {
app_token: app_token.to_string(),
role_id: role_id.to_string(),
..Default::default()
}
}
}
#[derive(Default)]
pub struct UpdateAppRoleRequestBuilder {
request: UpdateAppRoleRequest,
}
impl UpdateAppRoleRequestBuilder {
pub fn app_token(mut self, app_token: impl ToString) -> Self {
self.request.app_token = app_token.to_string();
self
}
pub fn role_id(mut self, role_id: impl ToString) -> Self {
self.request.role_id = role_id.to_string();
self
}
pub fn role_name(mut self, role_name: impl ToString) -> Self {
self.request.role_name = Some(role_name.to_string());
self
}
pub fn table_roles(mut self, table_roles: Vec<TableRole>) -> Self {
self.request.table_roles = Some(table_roles);
self
}
pub fn block_roles(mut self, block_roles: Vec<BlockRole>) -> Self {
self.request.block_roles = Some(block_roles);
self
}
pub fn build(mut self) -> UpdateAppRoleRequest {
self.request.api_request.body = serde_json::to_vec(&self.request).unwrap();
self.request
}
}
impl_executable_builder_owned!(
UpdateAppRoleRequestBuilder,
AppRoleService,
UpdateAppRoleRequest,
BaseResponse<UpdateAppRoleResponse>,
update
);
#[derive(Debug, Deserialize)]
pub struct UpdateAppRoleResponse {
pub role: AppRole,
}
impl ApiResponseTrait for UpdateAppRoleResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
pub async fn update_app_role(
request: UpdateAppRoleRequest,
config: &Config,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<UpdateAppRoleResponse>> {
let mut api_req = request.api_request;
api_req.http_method = Method::PUT;
api_req.api_path = BITABLE_V1_ROLE_UPDATE
.replace("{app_token}", &request.app_token)
.replace("{role_id}", &request.role_id);
api_req.supported_access_token_types = vec![AccessTokenType::Tenant, AccessTokenType::User];
let api_resp = Transport::request(api_req, config, option).await?;
Ok(api_resp)
}
#[cfg(test)]
#[allow(unused_variables, unused_unsafe)]
mod tests {
use super::*;
use serde_json;
#[test]
fn test_update_app_role_request_builder() {
let request = UpdateAppRoleRequest::builder()
.app_token("bascnmBA*****yGehy8")
.role_id("rolxxxxxx")
.role_name("更新后的角色名称")
.build();
assert_eq!(request.app_token, "bascnmBA*****yGehy8");
assert_eq!(request.role_id, "rolxxxxxx");
assert_eq!(request.role_name, Some("更新后的角色名称".to_string()));
}
#[test]
fn test_update_app_role_request_new() {
let request = UpdateAppRoleRequest::new("bascnmBA*****yGehy8", "rolxxxxxx");
assert_eq!(request.app_token, "bascnmBA*****yGehy8");
assert_eq!(request.role_id, "rolxxxxxx");
assert_eq!(request.role_name, None);
assert!(request.table_roles.is_none());
assert!(request.block_roles.is_none());
}
#[test]
fn test_update_app_role_request_default() {
let request = UpdateAppRoleRequest::default();
assert_eq!(request.app_token, "");
assert_eq!(request.role_id, "");
assert_eq!(request.role_name, None);
assert!(request.table_roles.is_none());
assert!(request.block_roles.is_none());
}
#[test]
fn test_update_app_role_request_builder_default() {
let builder = UpdateAppRoleRequestBuilder::default();
let request = builder.build();
assert_eq!(request.app_token, "");
assert_eq!(request.role_id, "");
assert_eq!(request.role_name, None);
assert!(request.table_roles.is_none());
assert!(request.block_roles.is_none());
}
#[test]
fn test_update_app_role_request_builder_chaining() {
let request = UpdateAppRoleRequest::builder()
.app_token("app1")
.role_id("role1")
.role_name("name1")
.app_token("app2")
.role_id("role2")
.role_name("name2")
.build();
assert_eq!(request.app_token, "app2");
assert_eq!(request.role_id, "role2");
assert_eq!(request.role_name, Some("name2".to_string()));
}
#[test]
fn test_update_app_role_request_debug() {
let request = UpdateAppRoleRequest::new("test_app", "test_role");
let debug_str = format!("{:?}", request);
assert!(debug_str.contains("UpdateAppRoleRequest"));
assert!(debug_str.contains("test_app"));
assert!(debug_str.contains("test_role"));
}
#[test]
fn test_update_app_role_request_serialization() {
let request = UpdateAppRoleRequest::new("app_token_123", "role_456");
let serialized = serde_json::to_string(&request).unwrap();
assert!(!serialized.contains("app_token"));
assert!(!serialized.contains("role_id"));
assert!(!serialized.contains("api_request"));
assert_eq!(serialized, "{}");
}
#[test]
fn test_update_app_role_request_with_role_name() {
let request = UpdateAppRoleRequest::builder()
.app_token("test_app")
.role_id("test_role")
.role_name("新角色名称")
.build();
assert_eq!(request.app_token, "test_app");
assert_eq!(request.role_id, "test_role");
assert_eq!(request.role_name, Some("新角色名称".to_string()));
assert!(request.table_roles.is_none());
assert!(request.block_roles.is_none());
}
#[test]
fn test_update_app_role_request_with_table_roles() {
let table_roles = vec![]; let request = UpdateAppRoleRequest::builder()
.app_token("test_app")
.role_id("test_role")
.table_roles(table_roles.clone())
.build();
assert_eq!(request.app_token, "test_app");
assert_eq!(request.role_id, "test_role");
assert_eq!(request.role_name, None);
assert!(request.table_roles.is_some());
assert!(request.block_roles.is_none());
}
#[test]
fn test_update_app_role_request_with_block_roles() {
let block_roles = vec![]; let request = UpdateAppRoleRequest::builder()
.app_token("test_app")
.role_id("test_role")
.block_roles(block_roles.clone())
.build();
assert_eq!(request.app_token, "test_app");
assert_eq!(request.role_id, "test_role");
assert_eq!(request.role_name, None);
assert!(request.table_roles.is_none());
assert!(request.block_roles.is_some());
}
#[test]
fn test_update_app_role_request_with_all_fields() {
let table_roles = vec![];
let block_roles = vec![];
let request = UpdateAppRoleRequest::builder()
.app_token("full_app")
.role_id("full_role")
.role_name("完整角色")
.table_roles(table_roles.clone())
.block_roles(block_roles.clone())
.build();
assert_eq!(request.app_token, "full_app");
assert_eq!(request.role_id, "full_role");
assert_eq!(request.role_name, Some("完整角色".to_string()));
assert!(request.table_roles.is_some());
assert!(request.block_roles.is_some());
}
#[test]
fn test_update_app_role_request_with_empty_values() {
let request = UpdateAppRoleRequest::new("", "");
assert_eq!(request.app_token, "");
assert_eq!(request.role_id, "");
assert_eq!(request.role_name, None);
}
#[test]
fn test_update_app_role_request_with_unicode() {
let request = UpdateAppRoleRequest::new("应用令牌_123", "角色_456");
assert_eq!(request.app_token, "应用令牌_123");
assert_eq!(request.role_id, "角色_456");
}
#[test]
fn test_update_app_role_request_with_string_types() {
let owned_app_token = String::from("owned_app");
let owned_role_id = String::from("owned_role");
let request1 = UpdateAppRoleRequest::new(owned_app_token, owned_role_id);
assert_eq!(request1.app_token, "owned_app");
assert_eq!(request1.role_id, "owned_role");
let request2 = UpdateAppRoleRequest::builder()
.app_token(String::from("builder_app"))
.role_id(String::from("builder_role"))
.role_name(String::from("builder_name"))
.build();
assert_eq!(request2.app_token, "builder_app");
assert_eq!(request2.role_id, "builder_role");
assert_eq!(request2.role_name, Some("builder_name".to_string()));
}
#[test]
fn test_update_app_role_request_with_long_values() {
let long_token = "a".repeat(1000);
let long_role = "b".repeat(500);
let long_name = "c".repeat(200);
let request = UpdateAppRoleRequest::builder()
.app_token(&long_token)
.role_id(&long_role)
.role_name(&long_name)
.build();
assert_eq!(request.app_token, long_token);
assert_eq!(request.role_id, long_role);
assert_eq!(request.role_name, Some(long_name));
}
#[test]
fn test_update_app_role_request_with_special_characters() {
let special_app = "app-token_123.test";
let special_role = "role@domain#test";
let special_name = "角色名称!@#$%^&*()";
let request = UpdateAppRoleRequest::builder()
.app_token(special_app)
.role_id(special_role)
.role_name(special_name)
.build();
assert_eq!(request.app_token, special_app);
assert_eq!(request.role_id, special_role);
assert_eq!(request.role_name, Some(special_name.to_string()));
}
#[test]
fn test_update_app_role_request_builder_partial() {
let request1 = UpdateAppRoleRequest::builder()
.app_token("only_app")
.build();
assert_eq!(request1.app_token, "only_app");
assert_eq!(request1.role_id, "");
assert!(request1.role_name.is_none());
let request2 = UpdateAppRoleRequest::builder().role_id("only_role").build();
assert_eq!(request2.app_token, "");
assert_eq!(request2.role_id, "only_role");
assert!(request2.role_name.is_none());
let request3 = UpdateAppRoleRequest::builder()
.role_name("only_name")
.build();
assert_eq!(request3.app_token, "");
assert_eq!(request3.role_id, "");
assert_eq!(request3.role_name, Some("only_name".to_string()));
}
#[test]
fn test_update_app_role_request_serialization_with_role_name() {
let request = UpdateAppRoleRequest::builder()
.app_token("app123")
.role_id("role456")
.role_name("测试角色")
.build();
let serialized = serde_json::to_string(&request).unwrap();
assert!(serialized.contains("role_name"));
assert!(serialized.contains("测试角色"));
assert!(!serialized.contains("app_token"));
assert!(!serialized.contains("role_id"));
assert!(!serialized.contains("api_request"));
}
#[test]
fn test_update_app_role_request_serialization_with_optional_fields() {
let table_roles = vec![];
let block_roles = vec![];
let request = UpdateAppRoleRequest::builder()
.app_token("app123")
.role_id("role456")
.role_name("测试角色")
.table_roles(table_roles)
.block_roles(block_roles)
.build();
let serialized = serde_json::to_string(&request).unwrap();
assert!(serialized.contains("role_name"));
assert!(serialized.contains("table_roles"));
assert!(serialized.contains("block_roles"));
assert!(serialized.contains("测试角色"));
}
#[test]
fn test_update_app_role_response_data_format() {
let format = UpdateAppRoleResponse::data_format();
assert!(matches!(format, ResponseFormat::Data));
}
#[test]
fn test_memory_efficiency() {
let request = UpdateAppRoleRequest::new("test", "test");
let size = std::mem::size_of_val(&request);
assert!(size > 0);
assert!(size < 1024);
}
#[test]
fn test_update_app_role_request_builder_method_returns() {
let builder = UpdateAppRoleRequest::builder().app_token("测试链式");
let _chained = builder.role_id("role").role_name("name");
}
#[test]
fn test_update_app_role_request_build_with_body() {
let request = UpdateAppRoleRequest::builder()
.app_token("test_app")
.role_id("test_role")
.role_name("测试角色")
.build();
assert!(!request.api_request.body.is_empty());
}
}