1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
/*
* 3DS OUTSCALE API
*
* Welcome to the OUTSCALE API documentation.<br /> The OUTSCALE API enables you to manage your resources in the OUTSCALE Cloud. This documentation describes the different actions available along with code examples.<br /><br /> Throttling: To protect against overloads, the number of identical requests allowed in a given time period is limited.<br /> Brute force: To protect against brute force attacks, the number of failed authentication attempts in a given time period is limited.<br /><br /> Note that the OUTSCALE Cloud is compatible with Amazon Web Services (AWS) APIs, but there are [differences in resource names](https://docs.outscale.com/en/userguide/About-the-APIs.html) between AWS and the OUTSCALE API.<br /> You can also manage your resources using the [Cockpit](https://docs.outscale.com/en/userguide/About-Cockpit.html) web interface.<br /><br /> An OpenAPI description of the OUTSCALE API is also available in this [GitHub repository](https://github.com/outscale/osc-api).<br /> # Authentication Schemes ### Access Key/Secret Key The main way to authenticate your requests to the OUTSCALE API is to use an access key and a secret key.<br /> The mechanism behind this is based on AWS Signature Version 4, whose technical implementation details are described in [Signature of API Requests](https://docs.outscale.com/en/userguide/Signature-of-API-Requests.html).<br /><br /> In practice, the way to specify your access key and secret key depends on the tool or SDK you want to use to interact with the API.<br /> > For example, if you use OSC CLI: > 1. You need to create an **~/.osc/config.json** file to specify your access key, secret key, and the Region of your account. > 2. You then specify the `--profile` option when executing OSC CLI commands. > > For more information, see [Installing and Configuring OSC CLI](https://docs.outscale.com/en/userguide/Installing-and-Configuring-OSC-CLI.html). See the code samples in each section of this documentation for specific examples in different programming languages.<br /> For more information about access keys, see [About Access Keys](https://docs.outscale.com/en/userguide/About-Access-Keys.html). > If you try to sign requests with an invalid access key four times in a row, further authentication attempts will be prevented for 1 minute. This lockout time increases 1 minute every four failed attempts, for up to 10 minutes. ### Login/Password For certain API actions, you can also use basic authentication with the login (email address) and password of your TINA account.<br /> This is useful only in special circumstances, for example if you do not know your access key/secret key and want to retrieve them programmatically.<br /> In most cases, however, you can use the Cockpit web interface to retrieve them.<br /> > For example, if you use OSC CLI: > 1. You need to create an **~/.osc/config.json** file to specify the Region of your account, but you leave the access key value and secret key value empty (`""`). > 2. You then specify the `--profile`, `--authentication-method`, `--login`, and `--password` options when executing OSC CLI commands. See the code samples in each section of this documentation for specific examples in different programming languages. > If you try to sign requests with an invalid password four times in a row, further authentication attempts will be prevented for 1 minute. This lockout time increases 1 minute every four failed attempts, for up to 10 minutes. ### No Authentication A few API actions do not require any authentication. They are indicated as such in this documentation.<br /> ### Other Security Mechanisms In parallel with the authentication schemes, you can add other security mechanisms to your OUTSCALE account, for example to restrict API requests by IP or other criteria.<br /> For more information, see [Managing Your API Accesses](https://docs.outscale.com/en/userguide/Managing-Your-API-Accesses.html).<br /> # Error Codes Reference You can learn more about errors returned by the API in the dedicated [errors page](api-errors.html).
*
* The version of the OpenAPI document: 1.30.0
* Contact: support@outscale.com
* Generated by: https://openapi-generator.tech
*/
/// ConsumptionEntry : Information about the resources consumed during the specified time period.
#[derive(Clone, Debug, PartialEq, Default, Serialize, Deserialize)]
pub struct ConsumptionEntry {
/// The ID of your TINA account.
#[serde(rename = "AccountId", skip_serializing_if = "Option::is_none")]
pub account_id: Option<String>,
/// The category of the resource (for example, `network`).
#[serde(rename = "Category", skip_serializing_if = "Option::is_none")]
pub category: Option<String>,
/// The beginning of the time period (UTC).
#[serde(rename = "FromDate", skip_serializing_if = "Option::is_none")]
pub from_date: Option<String>,
/// The API call that triggered the resource consumption (for example, `RunInstances` or `CreateVolume`).
#[serde(rename = "Operation", skip_serializing_if = "Option::is_none")]
pub operation: Option<String>,
/// The ID of the TINA account which is billed for your consumption. It can be different from your account in the `AccountId` parameter.
#[serde(rename = "PayingAccountId", skip_serializing_if = "Option::is_none")]
pub paying_account_id: Option<String>,
/// The total price of the consumed resource during the specified time period, in the currency of the Region's catalog.
#[serde(rename = "Price", skip_serializing_if = "Option::is_none")]
pub price: Option<f64>,
/// The service of the API call (`TinaOS-FCU`, `TinaOS-LBU`, `TinaOS-DirectLink`, `TinaOS-OOS`, or `TinaOS-OSU`).
#[serde(rename = "Service", skip_serializing_if = "Option::is_none")]
pub service: Option<String>,
/// The name of the Subregion.
#[serde(rename = "SubregionName", skip_serializing_if = "Option::is_none")]
pub subregion_name: Option<String>,
/// A description of the consumed resource.
#[serde(rename = "Title", skip_serializing_if = "Option::is_none")]
pub title: Option<String>,
/// The end of the time period (UTC).
#[serde(rename = "ToDate", skip_serializing_if = "Option::is_none")]
pub to_date: Option<String>,
/// The type of resource, depending on the API call.
#[serde(rename = "Type", skip_serializing_if = "Option::is_none")]
pub _type: Option<String>,
/// The unit price of the consumed resource, in the currency of the Region's catalog.
#[serde(rename = "UnitPrice", skip_serializing_if = "Option::is_none")]
pub unit_price: Option<f64>,
/// The consumed amount for the resource. The unit depends on the resource type. For more information, see the `Title` element.
#[serde(rename = "Value", skip_serializing_if = "Option::is_none")]
pub value: Option<f64>,
}
impl ConsumptionEntry {
/// Information about the resources consumed during the specified time period.
pub fn new() -> ConsumptionEntry {
ConsumptionEntry {
account_id: None,
category: None,
from_date: None,
operation: None,
paying_account_id: None,
price: None,
service: None,
subregion_name: None,
title: None,
to_date: None,
_type: None,
unit_price: None,
value: None,
}
}
}