use reqwest::Method;
use serde::{Deserialize, Serialize};
use crate::{
core::{
api_req::ApiRequest,
api_resp::{ApiResponseTrait, BaseResponse, ResponseFormat},
config::Config,
constants::AccessTokenType,
endpoints::{
EndpointBuilder, LINGO_ENTITY_CREATE, LINGO_ENTITY_GET, LINGO_ENTITY_HIGHLIGHT,
LINGO_ENTITY_MATCH, LINGO_ENTITY_SEARCH, LINGO_ENTITY_UPDATE,
},
http::Transport,
req_option::RequestOption,
SDKResult,
},
service::lingo::models::{
Entity, EntityMatchResult, EntitySearchResult, HighlightResult, OuterInfo, PageResponse,
RelatedMeta,
},
};
pub struct EntityService {
pub config: Config,
}
impl EntityService {
pub fn new(config: Config) -> Self {
Self { config }
}
pub async fn create_entity(
&self,
request: EntityCreateRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityCreateResponse>> {
let api_req = ApiRequest {
http_method: Method::POST,
api_path: LINGO_ENTITY_CREATE.to_string(),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: serde_json::to_vec(&request)?,
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
pub async fn update_entity(
&self,
entity_id: &str,
request: EntityUpdateRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityUpdateResponse>> {
let api_req = ApiRequest {
http_method: Method::PUT,
api_path: EndpointBuilder::replace_param(LINGO_ENTITY_UPDATE, "{entity_id}", entity_id),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: serde_json::to_vec(&request)?,
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
pub async fn delete_entity(
&self,
entity_id: &str,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityDeleteResponse>> {
let api_req = ApiRequest {
http_method: Method::DELETE,
api_path: EndpointBuilder::replace_param(LINGO_ENTITY_UPDATE, "{entity_id}", entity_id),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: vec![],
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
pub async fn get_entity(
&self,
entity_id: &str,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityGetResponse>> {
let api_req = ApiRequest {
http_method: Method::GET,
api_path: EndpointBuilder::replace_param(LINGO_ENTITY_GET, "{entity_id}", entity_id),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: vec![],
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
pub async fn list_entities(
&self,
request: EntityListRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityListResponse>> {
let mut api_req = ApiRequest {
http_method: Method::GET,
api_path: LINGO_ENTITY_CREATE.to_string(),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: vec![],
..Default::default()
};
if let Some(page_token) = request.page_token {
api_req.query_params.insert("page_token", page_token);
}
if let Some(page_size) = request.page_size {
api_req
.query_params
.insert("page_size", page_size.to_string());
}
if let Some(repo_id) = request.repo_id {
api_req.query_params.insert("repo_id", repo_id);
}
if let Some(classification_id) = request.classification_id {
api_req
.query_params
.insert("classification_id", classification_id);
}
if let Some(creator) = request.creator {
api_req.query_params.insert("creator", creator);
}
Transport::request(api_req, &self.config, option).await
}
pub async fn match_entities(
&self,
request: EntityMatchRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityMatchResponse>> {
let api_req = ApiRequest {
http_method: Method::POST,
api_path: LINGO_ENTITY_MATCH.to_string(),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: serde_json::to_vec(&request)?,
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
pub async fn search_entities(
&self,
request: EntitySearchRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntitySearchResponse>> {
let api_req = ApiRequest {
http_method: Method::POST,
api_path: LINGO_ENTITY_SEARCH.to_string(),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: serde_json::to_vec(&request)?,
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
pub async fn highlight_entities(
&self,
request: EntityHighlightRequest,
option: Option<RequestOption>,
) -> SDKResult<BaseResponse<EntityHighlightResponse>> {
let api_req = ApiRequest {
http_method: Method::POST,
api_path: LINGO_ENTITY_HIGHLIGHT.to_string(),
supported_access_token_types: vec![AccessTokenType::Tenant, AccessTokenType::User],
body: serde_json::to_vec(&request)?,
..Default::default()
};
Transport::request(api_req, &self.config, option).await
}
}
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct EntityCreateRequest {
pub main_keys: Vec<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub aliases: Option<Vec<String>>,
pub description: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub classification_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub outer_info: Option<OuterInfo>,
#[serde(skip_serializing_if = "Option::is_none")]
pub related_meta: Option<RelatedMeta>,
#[serde(skip_serializing_if = "Option::is_none")]
pub repo_id: Option<String>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityCreateResponse {
pub entity: Entity,
}
impl ApiResponseTrait for EntityCreateResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct EntityUpdateRequest {
#[serde(skip_serializing_if = "Option::is_none")]
pub main_keys: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
pub aliases: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
pub description: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub classification_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub outer_info: Option<OuterInfo>,
#[serde(skip_serializing_if = "Option::is_none")]
pub related_meta: Option<RelatedMeta>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityUpdateResponse {
pub entity: Entity,
}
impl ApiResponseTrait for EntityUpdateResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityDeleteResponse {
pub success: bool,
}
impl ApiResponseTrait for EntityDeleteResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityGetResponse {
pub entity: Entity,
}
impl ApiResponseTrait for EntityGetResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Clone, Serialize, Deserialize, Default)]
pub struct EntityListRequest {
#[serde(skip_serializing_if = "Option::is_none")]
pub page_token: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub page_size: Option<i32>,
#[serde(skip_serializing_if = "Option::is_none")]
pub repo_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub classification_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub creator: Option<String>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityListResponse {
#[serde(flatten)]
pub entities: PageResponse<Entity>,
}
impl ApiResponseTrait for EntityListResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct EntityMatchRequest {
pub word: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub repo_id: Option<String>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityMatchResponse {
pub results: Vec<EntityMatchResult>,
}
impl ApiResponseTrait for EntityMatchResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Clone, Serialize, Deserialize, Default)]
pub struct EntitySearchRequest {
pub query: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub classification_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub repo_id: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub sources: Option<Vec<String>>,
#[serde(skip_serializing_if = "Option::is_none")]
pub page_token: Option<String>,
#[serde(skip_serializing_if = "Option::is_none")]
pub page_size: Option<i32>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntitySearchResponse {
#[serde(flatten)]
pub results: PageResponse<EntitySearchResult>,
}
impl ApiResponseTrait for EntitySearchResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}
#[derive(Debug, Clone, Serialize, Deserialize)]
pub struct EntityHighlightRequest {
pub text: String,
#[serde(skip_serializing_if = "Option::is_none")]
pub repo_id: Option<String>,
}
#[derive(Debug, Serialize, Deserialize)]
pub struct EntityHighlightResponse {
pub result: HighlightResult,
}
impl ApiResponseTrait for EntityHighlightResponse {
fn data_format() -> ResponseFormat {
ResponseFormat::Data
}
}