langfuse_client/models/
model.rs

1/*
2 * langfuse
3 *
4 * ## Authentication  Authenticate with the API using [Basic Auth](https://en.wikipedia.org/wiki/Basic_access_authentication), get API keys in the project settings:  - username: Langfuse Public Key - password: Langfuse Secret Key  ## Exports  - OpenAPI spec: https://cloud.langfuse.com/generated/api/openapi.yml - Postman collection: https://cloud.langfuse.com/generated/postman/collection.json
5 *
6 * The version of the OpenAPI document: 
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14/// Model : Model definition used for transforming usage into USD cost and/or tokenization.
15#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
16#[cfg_attr(feature="bon", derive(bon::Builder))]
17pub struct Model {
18    #[serde(rename = "id")]
19    pub id: String,
20    /// Name of the model definition. If multiple with the same name exist, they are applied in the following order: (1) custom over built-in, (2) newest according to startTime where model.startTime<observation.startTime
21    #[serde(rename = "modelName")]
22    pub model_name: String,
23    /// Regex pattern which matches this model definition to generation.model. Useful in case of fine-tuned models. If you want to exact match, use `(?i)^modelname$`
24    #[serde(rename = "matchPattern")]
25    pub match_pattern: String,
26    /// Apply only to generations which are newer than this ISO date.
27    #[serde(rename = "startDate", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
28    pub start_date: Option<Option<String>>,
29    #[serde(rename = "unit", skip_serializing_if = "Option::is_none")]
30    pub unit: Option<models::ModelUsageUnit>,
31    /// Price (USD) per input unit
32    #[serde(rename = "inputPrice", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
33    pub input_price: Option<Option<f64>>,
34    /// Price (USD) per output unit
35    #[serde(rename = "outputPrice", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
36    pub output_price: Option<Option<f64>>,
37    /// Price (USD) per total unit. Cannot be set if input or output price is set.
38    #[serde(rename = "totalPrice", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
39    pub total_price: Option<Option<f64>>,
40    /// Optional. Tokenizer to be applied to observations which match to this model. See docs for more details.
41    #[serde(rename = "tokenizerId", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
42    pub tokenizer_id: Option<Option<String>>,
43    /// Optional. Configuration for the selected tokenizer. Needs to be JSON. See docs for more details.
44    #[serde(rename = "tokenizerConfig", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
45    pub tokenizer_config: Option<Option<serde_json::Value>>,
46    #[serde(rename = "isLangfuseManaged")]
47    pub is_langfuse_managed: bool,
48}
49
50impl Model {
51    /// Model definition used for transforming usage into USD cost and/or tokenization.
52    pub fn new(id: String, model_name: String, match_pattern: String, is_langfuse_managed: bool) -> Model {
53        Model {
54            id,
55            model_name,
56            match_pattern,
57            start_date: None,
58            unit: None,
59            input_price: None,
60            output_price: None,
61            total_price: None,
62            tokenizer_id: None,
63            tokenizer_config: None,
64            is_langfuse_managed,
65        }
66    }
67}
68