pub struct UsageBuilder { /* private fields */ }Expand description
Builder for querying usage data from the OpenAI API.
§Examples
use openai_ergonomic::builders::usage::{UsageBuilder, BucketWidth};
let builder = UsageBuilder::new(1704067200, None) // Start time (Unix timestamp)
.bucket_width(BucketWidth::Day)
.limit(100);Implementations§
Source§impl UsageBuilder
impl UsageBuilder
Sourcepub fn new(start_time: i32, end_time: Option<i32>) -> Self
pub fn new(start_time: i32, end_time: Option<i32>) -> Self
Create a new usage builder with the specified start time.
§Arguments
start_time- Unix timestamp (in seconds) for the start of the query rangeend_time- Optional Unix timestamp (in seconds) for the end of the query range
Examples found in repository?
72async fn basic_usage_query(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
73 let builder = UsageBuilder::new(start_time, Some(end_time));
74
75 let usage = client.usage().completions(builder).await?;
76
77 println!("Completions usage:");
78 println!(" Data points: {}", usage.data.len());
79
80 if usage.has_more {
81 println!(" Has more: yes");
82 }
83
84 Ok(())
85}
86
87async fn usage_with_aggregation(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
88 let builder = UsageBuilder::new(start_time, Some(end_time))
89 .bucket_width(BucketWidth::Day)
90 .limit(10);
91
92 let usage = client.usage().completions(builder).await?;
93
94 println!("Daily aggregated completions usage:");
95 println!(" Bucket width: 1 day");
96 println!(" Data points: {}", usage.data.len());
97
98 Ok(())
99}
100
101async fn usage_by_model(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
102 let builder = UsageBuilder::new(start_time, Some(end_time))
103 .model("gpt-4")
104 .limit(100);
105
106 let usage = client.usage().completions(builder).await?;
107
108 println!("Completions usage for gpt-4:");
109 println!(" Data points: {}", usage.data.len());
110
111 Ok(())
112}
113
114async fn usage_grouped_by_project(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
115 let builder = UsageBuilder::new(start_time, Some(end_time))
116 .group_by(GroupBy::ProjectId)
117 .group_by(GroupBy::Model)
118 .limit(50);
119
120 let usage = client.usage().completions(builder).await?;
121
122 println!("Completions usage grouped by project and model:");
123 println!(" Data points: {}", usage.data.len());
124
125 Ok(())
126}
127
128async fn cost_data(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
129 let builder = UsageBuilder::new(start_time, Some(end_time))
130 .bucket_width(BucketWidth::Day)
131 .limit(10);
132
133 let costs = client.usage().costs(builder).await?;
134
135 println!("Cost data:");
136 println!(" Data points: {}", costs.data.len());
137
138 Ok(())
139}
140
141async fn audio_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
142 let builder = UsageBuilder::new(start_time, Some(end_time)).limit(10);
143
144 // Audio speeches (text-to-speech)
145 let speeches = client.usage().audio_speeches(builder.clone()).await?;
146 println!("Audio speeches usage: {} data points", speeches.data.len());
147
148 // Audio transcriptions
149 let transcriptions = client.usage().audio_transcriptions(builder).await?;
150 println!(
151 "Audio transcriptions usage: {} data points",
152 transcriptions.data.len()
153 );
154
155 Ok(())
156}
157
158async fn image_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
159 let builder = UsageBuilder::new(start_time, Some(end_time))
160 .bucket_width(BucketWidth::Day)
161 .limit(10);
162
163 let usage = client.usage().images(builder).await?;
164
165 println!("Image generation usage:");
166 println!(" Data points: {}", usage.data.len());
167
168 Ok(())
169}
170
171async fn embeddings_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
172 let builder = UsageBuilder::new(start_time, Some(end_time))
173 .model("text-embedding-3-small")
174 .limit(100);
175
176 let usage = client.usage().embeddings(builder).await?;
177
178 println!("Embeddings usage for text-embedding-3-small:");
179 println!(" Data points: {}", usage.data.len());
180
181 Ok(())
182}Sourcepub fn bucket_width(self, width: BucketWidth) -> Self
pub fn bucket_width(self, width: BucketWidth) -> Self
Set the bucket width for aggregation.
Examples found in repository?
87async fn usage_with_aggregation(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
88 let builder = UsageBuilder::new(start_time, Some(end_time))
89 .bucket_width(BucketWidth::Day)
90 .limit(10);
91
92 let usage = client.usage().completions(builder).await?;
93
94 println!("Daily aggregated completions usage:");
95 println!(" Bucket width: 1 day");
96 println!(" Data points: {}", usage.data.len());
97
98 Ok(())
99}
100
101async fn usage_by_model(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
102 let builder = UsageBuilder::new(start_time, Some(end_time))
103 .model("gpt-4")
104 .limit(100);
105
106 let usage = client.usage().completions(builder).await?;
107
108 println!("Completions usage for gpt-4:");
109 println!(" Data points: {}", usage.data.len());
110
111 Ok(())
112}
113
114async fn usage_grouped_by_project(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
115 let builder = UsageBuilder::new(start_time, Some(end_time))
116 .group_by(GroupBy::ProjectId)
117 .group_by(GroupBy::Model)
118 .limit(50);
119
120 let usage = client.usage().completions(builder).await?;
121
122 println!("Completions usage grouped by project and model:");
123 println!(" Data points: {}", usage.data.len());
124
125 Ok(())
126}
127
128async fn cost_data(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
129 let builder = UsageBuilder::new(start_time, Some(end_time))
130 .bucket_width(BucketWidth::Day)
131 .limit(10);
132
133 let costs = client.usage().costs(builder).await?;
134
135 println!("Cost data:");
136 println!(" Data points: {}", costs.data.len());
137
138 Ok(())
139}
140
141async fn audio_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
142 let builder = UsageBuilder::new(start_time, Some(end_time)).limit(10);
143
144 // Audio speeches (text-to-speech)
145 let speeches = client.usage().audio_speeches(builder.clone()).await?;
146 println!("Audio speeches usage: {} data points", speeches.data.len());
147
148 // Audio transcriptions
149 let transcriptions = client.usage().audio_transcriptions(builder).await?;
150 println!(
151 "Audio transcriptions usage: {} data points",
152 transcriptions.data.len()
153 );
154
155 Ok(())
156}
157
158async fn image_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
159 let builder = UsageBuilder::new(start_time, Some(end_time))
160 .bucket_width(BucketWidth::Day)
161 .limit(10);
162
163 let usage = client.usage().images(builder).await?;
164
165 println!("Image generation usage:");
166 println!(" Data points: {}", usage.data.len());
167
168 Ok(())
169}Sourcepub fn project_id(self, id: impl Into<String>) -> Self
pub fn project_id(self, id: impl Into<String>) -> Self
Filter by a single project ID.
Sourcepub fn project_ids<I, S>(self, ids: I) -> Self
pub fn project_ids<I, S>(self, ids: I) -> Self
Filter by multiple project IDs.
Sourcepub fn api_key_id(self, id: impl Into<String>) -> Self
pub fn api_key_id(self, id: impl Into<String>) -> Self
Filter by a single API key ID.
Sourcepub fn api_key_ids<I, S>(self, ids: I) -> Self
pub fn api_key_ids<I, S>(self, ids: I) -> Self
Filter by multiple API key IDs.
Sourcepub fn model(self, model: impl Into<String>) -> Self
pub fn model(self, model: impl Into<String>) -> Self
Filter by a single model.
Examples found in repository?
101async fn usage_by_model(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
102 let builder = UsageBuilder::new(start_time, Some(end_time))
103 .model("gpt-4")
104 .limit(100);
105
106 let usage = client.usage().completions(builder).await?;
107
108 println!("Completions usage for gpt-4:");
109 println!(" Data points: {}", usage.data.len());
110
111 Ok(())
112}
113
114async fn usage_grouped_by_project(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
115 let builder = UsageBuilder::new(start_time, Some(end_time))
116 .group_by(GroupBy::ProjectId)
117 .group_by(GroupBy::Model)
118 .limit(50);
119
120 let usage = client.usage().completions(builder).await?;
121
122 println!("Completions usage grouped by project and model:");
123 println!(" Data points: {}", usage.data.len());
124
125 Ok(())
126}
127
128async fn cost_data(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
129 let builder = UsageBuilder::new(start_time, Some(end_time))
130 .bucket_width(BucketWidth::Day)
131 .limit(10);
132
133 let costs = client.usage().costs(builder).await?;
134
135 println!("Cost data:");
136 println!(" Data points: {}", costs.data.len());
137
138 Ok(())
139}
140
141async fn audio_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
142 let builder = UsageBuilder::new(start_time, Some(end_time)).limit(10);
143
144 // Audio speeches (text-to-speech)
145 let speeches = client.usage().audio_speeches(builder.clone()).await?;
146 println!("Audio speeches usage: {} data points", speeches.data.len());
147
148 // Audio transcriptions
149 let transcriptions = client.usage().audio_transcriptions(builder).await?;
150 println!(
151 "Audio transcriptions usage: {} data points",
152 transcriptions.data.len()
153 );
154
155 Ok(())
156}
157
158async fn image_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
159 let builder = UsageBuilder::new(start_time, Some(end_time))
160 .bucket_width(BucketWidth::Day)
161 .limit(10);
162
163 let usage = client.usage().images(builder).await?;
164
165 println!("Image generation usage:");
166 println!(" Data points: {}", usage.data.len());
167
168 Ok(())
169}
170
171async fn embeddings_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
172 let builder = UsageBuilder::new(start_time, Some(end_time))
173 .model("text-embedding-3-small")
174 .limit(100);
175
176 let usage = client.usage().embeddings(builder).await?;
177
178 println!("Embeddings usage for text-embedding-3-small:");
179 println!(" Data points: {}", usage.data.len());
180
181 Ok(())
182}Sourcepub fn group_by(self, field: GroupBy) -> Self
pub fn group_by(self, field: GroupBy) -> Self
Add a group by field.
Examples found in repository?
114async fn usage_grouped_by_project(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
115 let builder = UsageBuilder::new(start_time, Some(end_time))
116 .group_by(GroupBy::ProjectId)
117 .group_by(GroupBy::Model)
118 .limit(50);
119
120 let usage = client.usage().completions(builder).await?;
121
122 println!("Completions usage grouped by project and model:");
123 println!(" Data points: {}", usage.data.len());
124
125 Ok(())
126}Sourcepub fn group_by_fields<I>(self, fields: I) -> Selfwhere
I: IntoIterator<Item = GroupBy>,
pub fn group_by_fields<I>(self, fields: I) -> Selfwhere
I: IntoIterator<Item = GroupBy>,
Add multiple group by fields.
Sourcepub fn limit(self, limit: i32) -> Self
pub fn limit(self, limit: i32) -> Self
Set the maximum number of results to return.
Examples found in repository?
87async fn usage_with_aggregation(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
88 let builder = UsageBuilder::new(start_time, Some(end_time))
89 .bucket_width(BucketWidth::Day)
90 .limit(10);
91
92 let usage = client.usage().completions(builder).await?;
93
94 println!("Daily aggregated completions usage:");
95 println!(" Bucket width: 1 day");
96 println!(" Data points: {}", usage.data.len());
97
98 Ok(())
99}
100
101async fn usage_by_model(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
102 let builder = UsageBuilder::new(start_time, Some(end_time))
103 .model("gpt-4")
104 .limit(100);
105
106 let usage = client.usage().completions(builder).await?;
107
108 println!("Completions usage for gpt-4:");
109 println!(" Data points: {}", usage.data.len());
110
111 Ok(())
112}
113
114async fn usage_grouped_by_project(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
115 let builder = UsageBuilder::new(start_time, Some(end_time))
116 .group_by(GroupBy::ProjectId)
117 .group_by(GroupBy::Model)
118 .limit(50);
119
120 let usage = client.usage().completions(builder).await?;
121
122 println!("Completions usage grouped by project and model:");
123 println!(" Data points: {}", usage.data.len());
124
125 Ok(())
126}
127
128async fn cost_data(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
129 let builder = UsageBuilder::new(start_time, Some(end_time))
130 .bucket_width(BucketWidth::Day)
131 .limit(10);
132
133 let costs = client.usage().costs(builder).await?;
134
135 println!("Cost data:");
136 println!(" Data points: {}", costs.data.len());
137
138 Ok(())
139}
140
141async fn audio_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
142 let builder = UsageBuilder::new(start_time, Some(end_time)).limit(10);
143
144 // Audio speeches (text-to-speech)
145 let speeches = client.usage().audio_speeches(builder.clone()).await?;
146 println!("Audio speeches usage: {} data points", speeches.data.len());
147
148 // Audio transcriptions
149 let transcriptions = client.usage().audio_transcriptions(builder).await?;
150 println!(
151 "Audio transcriptions usage: {} data points",
152 transcriptions.data.len()
153 );
154
155 Ok(())
156}
157
158async fn image_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
159 let builder = UsageBuilder::new(start_time, Some(end_time))
160 .bucket_width(BucketWidth::Day)
161 .limit(10);
162
163 let usage = client.usage().images(builder).await?;
164
165 println!("Image generation usage:");
166 println!(" Data points: {}", usage.data.len());
167
168 Ok(())
169}
170
171async fn embeddings_usage(client: &Client, start_time: i32, end_time: i32) -> Result<()> {
172 let builder = UsageBuilder::new(start_time, Some(end_time))
173 .model("text-embedding-3-small")
174 .limit(100);
175
176 let usage = client.usage().embeddings(builder).await?;
177
178 println!("Embeddings usage for text-embedding-3-small:");
179 println!(" Data points: {}", usage.data.len());
180
181 Ok(())
182}Sourcepub fn start_time(&self) -> i32
pub fn start_time(&self) -> i32
Get the start time.
Sourcepub fn bucket_width_ref(&self) -> Option<BucketWidth>
pub fn bucket_width_ref(&self) -> Option<BucketWidth>
Get the bucket width.
Sourcepub fn project_ids_ref(&self) -> &[String]
pub fn project_ids_ref(&self) -> &[String]
Get the project IDs.
Sourcepub fn user_ids_ref(&self) -> &[String]
pub fn user_ids_ref(&self) -> &[String]
Get the user IDs.
Sourcepub fn api_key_ids_ref(&self) -> &[String]
pub fn api_key_ids_ref(&self) -> &[String]
Get the API key IDs.
Sourcepub fn models_ref(&self) -> &[String]
pub fn models_ref(&self) -> &[String]
Get the models.
Sourcepub fn group_by_ref(&self) -> &[GroupBy]
pub fn group_by_ref(&self) -> &[GroupBy]
Get the group by fields.
Sourcepub fn project_ids_option(&self) -> Option<Vec<String>>
pub fn project_ids_option(&self) -> Option<Vec<String>>
Convert project IDs to Option<Vec<String>>.
Sourcepub fn user_ids_option(&self) -> Option<Vec<String>>
pub fn user_ids_option(&self) -> Option<Vec<String>>
Convert user IDs to Option<Vec<String>>.
Sourcepub fn api_key_ids_option(&self) -> Option<Vec<String>>
pub fn api_key_ids_option(&self) -> Option<Vec<String>>
Convert API key IDs to Option<Vec<String>>.
Sourcepub fn models_option(&self) -> Option<Vec<String>>
pub fn models_option(&self) -> Option<Vec<String>>
Convert models to Option<Vec<String>>.
Sourcepub fn group_by_option(&self) -> Option<Vec<String>>
pub fn group_by_option(&self) -> Option<Vec<String>>
Convert group by fields to Option<Vec<String>>.
Sourcepub fn bucket_width_str(&self) -> Option<&str>
pub fn bucket_width_str(&self) -> Option<&str>
Get bucket width as Option<&str>.
Trait Implementations§
Source§impl Clone for UsageBuilder
impl Clone for UsageBuilder
Source§fn clone(&self) -> UsageBuilder
fn clone(&self) -> UsageBuilder
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more