Struct SpansAPI

Source
pub struct SpansAPI { /* private fields */ }
Expand description

Search and aggregate your spans from your Datadog platform over HTTP.

Implementations§

Source§

impl SpansAPI

Source

pub fn new() -> Self

Source

pub fn with_config(config: Configuration) -> Self

Examples found in repository?
examples/v2_spans_ListSpansGet.rs (line 9)
7async fn main() {
8    let configuration = datadog::Configuration::new();
9    let api = SpansAPI::with_config(configuration);
10    let resp = api
11        .list_spans_get(ListSpansGetOptionalParams::default())
12        .await;
13    if let Ok(value) = resp {
14        println!("{:#?}", value);
15    } else {
16        println!("{:#?}", resp.unwrap_err());
17    }
18}
More examples
Hide additional examples
examples/v2_spans_ListSpansGet_1130763422.rs (line 11)
9async fn main() {
10    let configuration = datadog::Configuration::new();
11    let api = SpansAPI::with_config(configuration);
12    let response =
13        api.list_spans_get_with_pagination(ListSpansGetOptionalParams::default().page_limit(2));
14    pin_mut!(response);
15    while let Some(resp) = response.next().await {
16        if let Ok(value) = resp {
17            println!("{:#?}", value);
18        } else {
19            println!("{:#?}", resp.unwrap_err());
20        }
21    }
22}
examples/v2_spans_ListSpans.rs (line 32)
14async fn main() {
15    let body = SpansListRequest::new().data(
16        SpansListRequestData::new()
17            .attributes(
18                SpansListRequestAttributes::new()
19                    .filter(
20                        SpansQueryFilter::new()
21                            .from("now-15m".to_string())
22                            .query("*".to_string())
23                            .to("now".to_string()),
24                    )
25                    .options(SpansQueryOptions::new().timezone("GMT".to_string()))
26                    .page(SpansListRequestPage::new().limit(25))
27                    .sort(SpansSort::TIMESTAMP_ASCENDING),
28            )
29            .type_(SpansListRequestType::SEARCH_REQUEST),
30    );
31    let configuration = datadog::Configuration::new();
32    let api = SpansAPI::with_config(configuration);
33    let resp = api.list_spans(body).await;
34    if let Ok(value) = resp {
35        println!("{:#?}", value);
36    } else {
37        println!("{:#?}", resp.unwrap_err());
38    }
39}
examples/v2_spans_AggregateSpans.rs (line 32)
14async fn main() {
15    let body = SpansAggregateRequest::new().data(
16        SpansAggregateData::new()
17            .attributes(
18                SpansAggregateRequestAttributes::new()
19                    .compute(vec![SpansCompute::new(SpansAggregationFunction::COUNT)
20                        .interval("5m".to_string())
21                        .type_(SpansComputeType::TIMESERIES)])
22                    .filter(
23                        SpansQueryFilter::new()
24                            .from("now-15m".to_string())
25                            .query("*".to_string())
26                            .to("now".to_string()),
27                    ),
28            )
29            .type_(SpansAggregateRequestType::AGGREGATE_REQUEST),
30    );
31    let configuration = datadog::Configuration::new();
32    let api = SpansAPI::with_config(configuration);
33    let resp = api.aggregate_spans(body).await;
34    if let Ok(value) = resp {
35        println!("{:#?}", value);
36    } else {
37        println!("{:#?}", resp.unwrap_err());
38    }
39}
examples/v2_spans_ListSpans_3495563906.rs (line 34)
16async fn main() {
17    let body = SpansListRequest::new().data(
18        SpansListRequestData::new()
19            .attributes(
20                SpansListRequestAttributes::new()
21                    .filter(
22                        SpansQueryFilter::new()
23                            .from("now-15m".to_string())
24                            .query("service:python*".to_string())
25                            .to("now".to_string()),
26                    )
27                    .options(SpansQueryOptions::new().timezone("GMT".to_string()))
28                    .page(SpansListRequestPage::new().limit(2))
29                    .sort(SpansSort::TIMESTAMP_ASCENDING),
30            )
31            .type_(SpansListRequestType::SEARCH_REQUEST),
32    );
33    let configuration = datadog::Configuration::new();
34    let api = SpansAPI::with_config(configuration);
35    let response = api.list_spans_with_pagination(body);
36    pin_mut!(response);
37    while let Some(resp) = response.next().await {
38        if let Ok(value) = resp {
39            println!("{:#?}", value);
40        } else {
41            println!("{:#?}", resp.unwrap_err());
42        }
43    }
44}
Source

pub fn with_client_and_config( config: Configuration, client: ClientWithMiddleware, ) -> Self

Source

pub async fn aggregate_spans( &self, body: SpansAggregateRequest, ) -> Result<SpansAggregateResponse, Error<AggregateSpansError>>

The API endpoint to aggregate spans into buckets and compute metrics and timeseries. This endpoint is rate limited to 300 requests per hour.

Examples found in repository?
examples/v2_spans_AggregateSpans.rs (line 33)
14async fn main() {
15    let body = SpansAggregateRequest::new().data(
16        SpansAggregateData::new()
17            .attributes(
18                SpansAggregateRequestAttributes::new()
19                    .compute(vec![SpansCompute::new(SpansAggregationFunction::COUNT)
20                        .interval("5m".to_string())
21                        .type_(SpansComputeType::TIMESERIES)])
22                    .filter(
23                        SpansQueryFilter::new()
24                            .from("now-15m".to_string())
25                            .query("*".to_string())
26                            .to("now".to_string()),
27                    ),
28            )
29            .type_(SpansAggregateRequestType::AGGREGATE_REQUEST),
30    );
31    let configuration = datadog::Configuration::new();
32    let api = SpansAPI::with_config(configuration);
33    let resp = api.aggregate_spans(body).await;
34    if let Ok(value) = resp {
35        println!("{:#?}", value);
36    } else {
37        println!("{:#?}", resp.unwrap_err());
38    }
39}
Source

pub async fn aggregate_spans_with_http_info( &self, body: SpansAggregateRequest, ) -> Result<ResponseContent<SpansAggregateResponse>, Error<AggregateSpansError>>

The API endpoint to aggregate spans into buckets and compute metrics and timeseries. This endpoint is rate limited to 300 requests per hour.

Source

pub async fn list_spans( &self, body: SpansListRequest, ) -> Result<SpansListResponse, Error<ListSpansError>>

List endpoint returns spans that match a span search query. Results are paginated.

Use this endpoint to build complex spans filtering and search. This endpoint is rate limited to 300 requests per hour.

Examples found in repository?
examples/v2_spans_ListSpans.rs (line 33)
14async fn main() {
15    let body = SpansListRequest::new().data(
16        SpansListRequestData::new()
17            .attributes(
18                SpansListRequestAttributes::new()
19                    .filter(
20                        SpansQueryFilter::new()
21                            .from("now-15m".to_string())
22                            .query("*".to_string())
23                            .to("now".to_string()),
24                    )
25                    .options(SpansQueryOptions::new().timezone("GMT".to_string()))
26                    .page(SpansListRequestPage::new().limit(25))
27                    .sort(SpansSort::TIMESTAMP_ASCENDING),
28            )
29            .type_(SpansListRequestType::SEARCH_REQUEST),
30    );
31    let configuration = datadog::Configuration::new();
32    let api = SpansAPI::with_config(configuration);
33    let resp = api.list_spans(body).await;
34    if let Ok(value) = resp {
35        println!("{:#?}", value);
36    } else {
37        println!("{:#?}", resp.unwrap_err());
38    }
39}
Source

pub fn list_spans_with_pagination( &self, body: SpansListRequest, ) -> impl Stream<Item = Result<Span, Error<ListSpansError>>> + '_

Examples found in repository?
examples/v2_spans_ListSpans_3495563906.rs (line 35)
16async fn main() {
17    let body = SpansListRequest::new().data(
18        SpansListRequestData::new()
19            .attributes(
20                SpansListRequestAttributes::new()
21                    .filter(
22                        SpansQueryFilter::new()
23                            .from("now-15m".to_string())
24                            .query("service:python*".to_string())
25                            .to("now".to_string()),
26                    )
27                    .options(SpansQueryOptions::new().timezone("GMT".to_string()))
28                    .page(SpansListRequestPage::new().limit(2))
29                    .sort(SpansSort::TIMESTAMP_ASCENDING),
30            )
31            .type_(SpansListRequestType::SEARCH_REQUEST),
32    );
33    let configuration = datadog::Configuration::new();
34    let api = SpansAPI::with_config(configuration);
35    let response = api.list_spans_with_pagination(body);
36    pin_mut!(response);
37    while let Some(resp) = response.next().await {
38        if let Ok(value) = resp {
39            println!("{:#?}", value);
40        } else {
41            println!("{:#?}", resp.unwrap_err());
42        }
43    }
44}
Source

pub async fn list_spans_with_http_info( &self, body: SpansListRequest, ) -> Result<ResponseContent<SpansListResponse>, Error<ListSpansError>>

List endpoint returns spans that match a span search query. Results are paginated.

Use this endpoint to build complex spans filtering and search. This endpoint is rate limited to 300 requests per hour.

Source

pub async fn list_spans_get( &self, params: ListSpansGetOptionalParams, ) -> Result<SpansListResponse, Error<ListSpansGetError>>

List endpoint returns spans that match a span search query. Results are paginated.

Use this endpoint to see your latest spans. This endpoint is rate limited to 300 requests per hour.

Examples found in repository?
examples/v2_spans_ListSpansGet.rs (line 11)
7async fn main() {
8    let configuration = datadog::Configuration::new();
9    let api = SpansAPI::with_config(configuration);
10    let resp = api
11        .list_spans_get(ListSpansGetOptionalParams::default())
12        .await;
13    if let Ok(value) = resp {
14        println!("{:#?}", value);
15    } else {
16        println!("{:#?}", resp.unwrap_err());
17    }
18}
Source

pub fn list_spans_get_with_pagination( &self, params: ListSpansGetOptionalParams, ) -> impl Stream<Item = Result<Span, Error<ListSpansGetError>>> + '_

Examples found in repository?
examples/v2_spans_ListSpansGet_1130763422.rs (line 13)
9async fn main() {
10    let configuration = datadog::Configuration::new();
11    let api = SpansAPI::with_config(configuration);
12    let response =
13        api.list_spans_get_with_pagination(ListSpansGetOptionalParams::default().page_limit(2));
14    pin_mut!(response);
15    while let Some(resp) = response.next().await {
16        if let Ok(value) = resp {
17            println!("{:#?}", value);
18        } else {
19            println!("{:#?}", resp.unwrap_err());
20        }
21    }
22}
Source

pub async fn list_spans_get_with_http_info( &self, params: ListSpansGetOptionalParams, ) -> Result<ResponseContent<SpansListResponse>, Error<ListSpansGetError>>

List endpoint returns spans that match a span search query. Results are paginated.

Use this endpoint to see your latest spans. This endpoint is rate limited to 300 requests per hour.

Trait Implementations§

Source§

impl Clone for SpansAPI

Source§

fn clone(&self) -> SpansAPI

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SpansAPI

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for SpansAPI

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,