use std::error::Error;
use std::fmt;
#[allow(warnings)]
use futures::future;
use futures::Future;
use rusoto_core::credential::ProvideAwsCredentials;
use rusoto_core::region;
use rusoto_core::request::{BufferedHttpResponse, DispatchSignedRequest};
use rusoto_core::{Client, RusotoError, RusotoFuture};
use rusoto_core::proto;
use rusoto_core::signature::SignedRequest;
use serde_json;
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct CreateEnvironmentEC2Request {
#[serde(rename = "automaticStopTimeMinutes")]
#[serde(skip_serializing_if = "Option::is_none")]
pub automatic_stop_time_minutes: Option<i64>,
#[serde(rename = "clientRequestToken")]
#[serde(skip_serializing_if = "Option::is_none")]
pub client_request_token: Option<String>,
#[serde(rename = "description")]
#[serde(skip_serializing_if = "Option::is_none")]
pub description: Option<String>,
#[serde(rename = "instanceType")]
pub instance_type: String,
#[serde(rename = "name")]
pub name: String,
#[serde(rename = "ownerArn")]
#[serde(skip_serializing_if = "Option::is_none")]
pub owner_arn: Option<String>,
#[serde(rename = "subnetId")]
#[serde(skip_serializing_if = "Option::is_none")]
pub subnet_id: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct CreateEnvironmentEC2Result {
#[serde(rename = "environmentId")]
#[serde(skip_serializing_if = "Option::is_none")]
pub environment_id: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct CreateEnvironmentMembershipRequest {
#[serde(rename = "environmentId")]
pub environment_id: String,
#[serde(rename = "permissions")]
pub permissions: String,
#[serde(rename = "userArn")]
pub user_arn: String,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct CreateEnvironmentMembershipResult {
#[serde(rename = "membership")]
#[serde(skip_serializing_if = "Option::is_none")]
pub membership: Option<EnvironmentMember>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct DeleteEnvironmentMembershipRequest {
#[serde(rename = "environmentId")]
pub environment_id: String,
#[serde(rename = "userArn")]
pub user_arn: String,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct DeleteEnvironmentMembershipResult {}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct DeleteEnvironmentRequest {
#[serde(rename = "environmentId")]
pub environment_id: String,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct DeleteEnvironmentResult {}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct DescribeEnvironmentMembershipsRequest {
#[serde(rename = "environmentId")]
#[serde(skip_serializing_if = "Option::is_none")]
pub environment_id: Option<String>,
#[serde(rename = "maxResults")]
#[serde(skip_serializing_if = "Option::is_none")]
pub max_results: Option<i64>,
#[serde(rename = "nextToken")]
#[serde(skip_serializing_if = "Option::is_none")]
pub next_token: Option<String>,
#[serde(rename = "permissions")]
#[serde(skip_serializing_if = "Option::is_none")]
pub permissions: Option<Vec<String>>,
#[serde(rename = "userArn")]
#[serde(skip_serializing_if = "Option::is_none")]
pub user_arn: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct DescribeEnvironmentMembershipsResult {
#[serde(rename = "memberships")]
#[serde(skip_serializing_if = "Option::is_none")]
pub memberships: Option<Vec<EnvironmentMember>>,
#[serde(rename = "nextToken")]
#[serde(skip_serializing_if = "Option::is_none")]
pub next_token: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct DescribeEnvironmentStatusRequest {
#[serde(rename = "environmentId")]
pub environment_id: String,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct DescribeEnvironmentStatusResult {
#[serde(rename = "message")]
#[serde(skip_serializing_if = "Option::is_none")]
pub message: Option<String>,
#[serde(rename = "status")]
#[serde(skip_serializing_if = "Option::is_none")]
pub status: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct DescribeEnvironmentsRequest {
#[serde(rename = "environmentIds")]
pub environment_ids: Vec<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct DescribeEnvironmentsResult {
#[serde(rename = "environments")]
#[serde(skip_serializing_if = "Option::is_none")]
pub environments: Option<Vec<Environment>>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct Environment {
#[serde(rename = "arn")]
#[serde(skip_serializing_if = "Option::is_none")]
pub arn: Option<String>,
#[serde(rename = "description")]
#[serde(skip_serializing_if = "Option::is_none")]
pub description: Option<String>,
#[serde(rename = "id")]
#[serde(skip_serializing_if = "Option::is_none")]
pub id: Option<String>,
#[serde(rename = "lifecycle")]
#[serde(skip_serializing_if = "Option::is_none")]
pub lifecycle: Option<EnvironmentLifecycle>,
#[serde(rename = "name")]
#[serde(skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
#[serde(rename = "ownerArn")]
#[serde(skip_serializing_if = "Option::is_none")]
pub owner_arn: Option<String>,
#[serde(rename = "type")]
#[serde(skip_serializing_if = "Option::is_none")]
pub type_: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct EnvironmentLifecycle {
#[serde(rename = "failureResource")]
#[serde(skip_serializing_if = "Option::is_none")]
pub failure_resource: Option<String>,
#[serde(rename = "reason")]
#[serde(skip_serializing_if = "Option::is_none")]
pub reason: Option<String>,
#[serde(rename = "status")]
#[serde(skip_serializing_if = "Option::is_none")]
pub status: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct EnvironmentMember {
#[serde(rename = "environmentId")]
#[serde(skip_serializing_if = "Option::is_none")]
pub environment_id: Option<String>,
#[serde(rename = "lastAccess")]
#[serde(skip_serializing_if = "Option::is_none")]
pub last_access: Option<f64>,
#[serde(rename = "permissions")]
#[serde(skip_serializing_if = "Option::is_none")]
pub permissions: Option<String>,
#[serde(rename = "userArn")]
#[serde(skip_serializing_if = "Option::is_none")]
pub user_arn: Option<String>,
#[serde(rename = "userId")]
#[serde(skip_serializing_if = "Option::is_none")]
pub user_id: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct ListEnvironmentsRequest {
#[serde(rename = "maxResults")]
#[serde(skip_serializing_if = "Option::is_none")]
pub max_results: Option<i64>,
#[serde(rename = "nextToken")]
#[serde(skip_serializing_if = "Option::is_none")]
pub next_token: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct ListEnvironmentsResult {
#[serde(rename = "environmentIds")]
#[serde(skip_serializing_if = "Option::is_none")]
pub environment_ids: Option<Vec<String>>,
#[serde(rename = "nextToken")]
#[serde(skip_serializing_if = "Option::is_none")]
pub next_token: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct UpdateEnvironmentMembershipRequest {
#[serde(rename = "environmentId")]
pub environment_id: String,
#[serde(rename = "permissions")]
pub permissions: String,
#[serde(rename = "userArn")]
pub user_arn: String,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct UpdateEnvironmentMembershipResult {
#[serde(rename = "membership")]
#[serde(skip_serializing_if = "Option::is_none")]
pub membership: Option<EnvironmentMember>,
}
#[derive(Default, Debug, Clone, PartialEq, Serialize)]
pub struct UpdateEnvironmentRequest {
#[serde(rename = "description")]
#[serde(skip_serializing_if = "Option::is_none")]
pub description: Option<String>,
#[serde(rename = "environmentId")]
pub environment_id: String,
#[serde(rename = "name")]
#[serde(skip_serializing_if = "Option::is_none")]
pub name: Option<String>,
}
#[derive(Default, Debug, Clone, PartialEq, Deserialize)]
#[cfg_attr(test, derive(Serialize))]
pub struct UpdateEnvironmentResult {}
#[derive(Debug, PartialEq)]
pub enum CreateEnvironmentEC2Error {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl CreateEnvironmentEC2Error {
pub fn from_response(res: BufferedHttpResponse) -> RusotoError<CreateEnvironmentEC2Error> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::BadRequest(err.msg))
}
"ConflictException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::Conflict(err.msg))
}
"ForbiddenException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::Forbidden(err.msg))
}
"InternalServerErrorException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::InternalServerError(
err.msg,
))
}
"LimitExceededException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::LimitExceeded(err.msg))
}
"NotFoundException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::NotFound(err.msg))
}
"TooManyRequestsException" => {
return RusotoError::Service(CreateEnvironmentEC2Error::TooManyRequests(
err.msg,
))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for CreateEnvironmentEC2Error {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for CreateEnvironmentEC2Error {
fn description(&self) -> &str {
match *self {
CreateEnvironmentEC2Error::BadRequest(ref cause) => cause,
CreateEnvironmentEC2Error::Conflict(ref cause) => cause,
CreateEnvironmentEC2Error::Forbidden(ref cause) => cause,
CreateEnvironmentEC2Error::InternalServerError(ref cause) => cause,
CreateEnvironmentEC2Error::LimitExceeded(ref cause) => cause,
CreateEnvironmentEC2Error::NotFound(ref cause) => cause,
CreateEnvironmentEC2Error::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum CreateEnvironmentMembershipError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl CreateEnvironmentMembershipError {
pub fn from_response(
res: BufferedHttpResponse,
) -> RusotoError<CreateEnvironmentMembershipError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(CreateEnvironmentMembershipError::BadRequest(
err.msg,
))
}
"ConflictException" => {
return RusotoError::Service(CreateEnvironmentMembershipError::Conflict(
err.msg,
))
}
"ForbiddenException" => {
return RusotoError::Service(CreateEnvironmentMembershipError::Forbidden(
err.msg,
))
}
"InternalServerErrorException" => {
return RusotoError::Service(
CreateEnvironmentMembershipError::InternalServerError(err.msg),
)
}
"LimitExceededException" => {
return RusotoError::Service(CreateEnvironmentMembershipError::LimitExceeded(
err.msg,
))
}
"NotFoundException" => {
return RusotoError::Service(CreateEnvironmentMembershipError::NotFound(
err.msg,
))
}
"TooManyRequestsException" => {
return RusotoError::Service(CreateEnvironmentMembershipError::TooManyRequests(
err.msg,
))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for CreateEnvironmentMembershipError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for CreateEnvironmentMembershipError {
fn description(&self) -> &str {
match *self {
CreateEnvironmentMembershipError::BadRequest(ref cause) => cause,
CreateEnvironmentMembershipError::Conflict(ref cause) => cause,
CreateEnvironmentMembershipError::Forbidden(ref cause) => cause,
CreateEnvironmentMembershipError::InternalServerError(ref cause) => cause,
CreateEnvironmentMembershipError::LimitExceeded(ref cause) => cause,
CreateEnvironmentMembershipError::NotFound(ref cause) => cause,
CreateEnvironmentMembershipError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum DeleteEnvironmentError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl DeleteEnvironmentError {
pub fn from_response(res: BufferedHttpResponse) -> RusotoError<DeleteEnvironmentError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(DeleteEnvironmentError::BadRequest(err.msg))
}
"ConflictException" => {
return RusotoError::Service(DeleteEnvironmentError::Conflict(err.msg))
}
"ForbiddenException" => {
return RusotoError::Service(DeleteEnvironmentError::Forbidden(err.msg))
}
"InternalServerErrorException" => {
return RusotoError::Service(DeleteEnvironmentError::InternalServerError(
err.msg,
))
}
"LimitExceededException" => {
return RusotoError::Service(DeleteEnvironmentError::LimitExceeded(err.msg))
}
"NotFoundException" => {
return RusotoError::Service(DeleteEnvironmentError::NotFound(err.msg))
}
"TooManyRequestsException" => {
return RusotoError::Service(DeleteEnvironmentError::TooManyRequests(err.msg))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for DeleteEnvironmentError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for DeleteEnvironmentError {
fn description(&self) -> &str {
match *self {
DeleteEnvironmentError::BadRequest(ref cause) => cause,
DeleteEnvironmentError::Conflict(ref cause) => cause,
DeleteEnvironmentError::Forbidden(ref cause) => cause,
DeleteEnvironmentError::InternalServerError(ref cause) => cause,
DeleteEnvironmentError::LimitExceeded(ref cause) => cause,
DeleteEnvironmentError::NotFound(ref cause) => cause,
DeleteEnvironmentError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum DeleteEnvironmentMembershipError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl DeleteEnvironmentMembershipError {
pub fn from_response(
res: BufferedHttpResponse,
) -> RusotoError<DeleteEnvironmentMembershipError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(DeleteEnvironmentMembershipError::BadRequest(
err.msg,
))
}
"ConflictException" => {
return RusotoError::Service(DeleteEnvironmentMembershipError::Conflict(
err.msg,
))
}
"ForbiddenException" => {
return RusotoError::Service(DeleteEnvironmentMembershipError::Forbidden(
err.msg,
))
}
"InternalServerErrorException" => {
return RusotoError::Service(
DeleteEnvironmentMembershipError::InternalServerError(err.msg),
)
}
"LimitExceededException" => {
return RusotoError::Service(DeleteEnvironmentMembershipError::LimitExceeded(
err.msg,
))
}
"NotFoundException" => {
return RusotoError::Service(DeleteEnvironmentMembershipError::NotFound(
err.msg,
))
}
"TooManyRequestsException" => {
return RusotoError::Service(DeleteEnvironmentMembershipError::TooManyRequests(
err.msg,
))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for DeleteEnvironmentMembershipError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for DeleteEnvironmentMembershipError {
fn description(&self) -> &str {
match *self {
DeleteEnvironmentMembershipError::BadRequest(ref cause) => cause,
DeleteEnvironmentMembershipError::Conflict(ref cause) => cause,
DeleteEnvironmentMembershipError::Forbidden(ref cause) => cause,
DeleteEnvironmentMembershipError::InternalServerError(ref cause) => cause,
DeleteEnvironmentMembershipError::LimitExceeded(ref cause) => cause,
DeleteEnvironmentMembershipError::NotFound(ref cause) => cause,
DeleteEnvironmentMembershipError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum DescribeEnvironmentMembershipsError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl DescribeEnvironmentMembershipsError {
pub fn from_response(
res: BufferedHttpResponse,
) -> RusotoError<DescribeEnvironmentMembershipsError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(DescribeEnvironmentMembershipsError::BadRequest(
err.msg,
))
}
"ConflictException" => {
return RusotoError::Service(DescribeEnvironmentMembershipsError::Conflict(
err.msg,
))
}
"ForbiddenException" => {
return RusotoError::Service(DescribeEnvironmentMembershipsError::Forbidden(
err.msg,
))
}
"InternalServerErrorException" => {
return RusotoError::Service(
DescribeEnvironmentMembershipsError::InternalServerError(err.msg),
)
}
"LimitExceededException" => {
return RusotoError::Service(
DescribeEnvironmentMembershipsError::LimitExceeded(err.msg),
)
}
"NotFoundException" => {
return RusotoError::Service(DescribeEnvironmentMembershipsError::NotFound(
err.msg,
))
}
"TooManyRequestsException" => {
return RusotoError::Service(
DescribeEnvironmentMembershipsError::TooManyRequests(err.msg),
)
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for DescribeEnvironmentMembershipsError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for DescribeEnvironmentMembershipsError {
fn description(&self) -> &str {
match *self {
DescribeEnvironmentMembershipsError::BadRequest(ref cause) => cause,
DescribeEnvironmentMembershipsError::Conflict(ref cause) => cause,
DescribeEnvironmentMembershipsError::Forbidden(ref cause) => cause,
DescribeEnvironmentMembershipsError::InternalServerError(ref cause) => cause,
DescribeEnvironmentMembershipsError::LimitExceeded(ref cause) => cause,
DescribeEnvironmentMembershipsError::NotFound(ref cause) => cause,
DescribeEnvironmentMembershipsError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum DescribeEnvironmentStatusError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl DescribeEnvironmentStatusError {
pub fn from_response(res: BufferedHttpResponse) -> RusotoError<DescribeEnvironmentStatusError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(DescribeEnvironmentStatusError::BadRequest(
err.msg,
))
}
"ConflictException" => {
return RusotoError::Service(DescribeEnvironmentStatusError::Conflict(err.msg))
}
"ForbiddenException" => {
return RusotoError::Service(DescribeEnvironmentStatusError::Forbidden(err.msg))
}
"InternalServerErrorException" => {
return RusotoError::Service(
DescribeEnvironmentStatusError::InternalServerError(err.msg),
)
}
"LimitExceededException" => {
return RusotoError::Service(DescribeEnvironmentStatusError::LimitExceeded(
err.msg,
))
}
"NotFoundException" => {
return RusotoError::Service(DescribeEnvironmentStatusError::NotFound(err.msg))
}
"TooManyRequestsException" => {
return RusotoError::Service(DescribeEnvironmentStatusError::TooManyRequests(
err.msg,
))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for DescribeEnvironmentStatusError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for DescribeEnvironmentStatusError {
fn description(&self) -> &str {
match *self {
DescribeEnvironmentStatusError::BadRequest(ref cause) => cause,
DescribeEnvironmentStatusError::Conflict(ref cause) => cause,
DescribeEnvironmentStatusError::Forbidden(ref cause) => cause,
DescribeEnvironmentStatusError::InternalServerError(ref cause) => cause,
DescribeEnvironmentStatusError::LimitExceeded(ref cause) => cause,
DescribeEnvironmentStatusError::NotFound(ref cause) => cause,
DescribeEnvironmentStatusError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum DescribeEnvironmentsError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl DescribeEnvironmentsError {
pub fn from_response(res: BufferedHttpResponse) -> RusotoError<DescribeEnvironmentsError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(DescribeEnvironmentsError::BadRequest(err.msg))
}
"ConflictException" => {
return RusotoError::Service(DescribeEnvironmentsError::Conflict(err.msg))
}
"ForbiddenException" => {
return RusotoError::Service(DescribeEnvironmentsError::Forbidden(err.msg))
}
"InternalServerErrorException" => {
return RusotoError::Service(DescribeEnvironmentsError::InternalServerError(
err.msg,
))
}
"LimitExceededException" => {
return RusotoError::Service(DescribeEnvironmentsError::LimitExceeded(err.msg))
}
"NotFoundException" => {
return RusotoError::Service(DescribeEnvironmentsError::NotFound(err.msg))
}
"TooManyRequestsException" => {
return RusotoError::Service(DescribeEnvironmentsError::TooManyRequests(
err.msg,
))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for DescribeEnvironmentsError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for DescribeEnvironmentsError {
fn description(&self) -> &str {
match *self {
DescribeEnvironmentsError::BadRequest(ref cause) => cause,
DescribeEnvironmentsError::Conflict(ref cause) => cause,
DescribeEnvironmentsError::Forbidden(ref cause) => cause,
DescribeEnvironmentsError::InternalServerError(ref cause) => cause,
DescribeEnvironmentsError::LimitExceeded(ref cause) => cause,
DescribeEnvironmentsError::NotFound(ref cause) => cause,
DescribeEnvironmentsError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum ListEnvironmentsError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl ListEnvironmentsError {
pub fn from_response(res: BufferedHttpResponse) -> RusotoError<ListEnvironmentsError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(ListEnvironmentsError::BadRequest(err.msg))
}
"ConflictException" => {
return RusotoError::Service(ListEnvironmentsError::Conflict(err.msg))
}
"ForbiddenException" => {
return RusotoError::Service(ListEnvironmentsError::Forbidden(err.msg))
}
"InternalServerErrorException" => {
return RusotoError::Service(ListEnvironmentsError::InternalServerError(
err.msg,
))
}
"LimitExceededException" => {
return RusotoError::Service(ListEnvironmentsError::LimitExceeded(err.msg))
}
"NotFoundException" => {
return RusotoError::Service(ListEnvironmentsError::NotFound(err.msg))
}
"TooManyRequestsException" => {
return RusotoError::Service(ListEnvironmentsError::TooManyRequests(err.msg))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for ListEnvironmentsError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for ListEnvironmentsError {
fn description(&self) -> &str {
match *self {
ListEnvironmentsError::BadRequest(ref cause) => cause,
ListEnvironmentsError::Conflict(ref cause) => cause,
ListEnvironmentsError::Forbidden(ref cause) => cause,
ListEnvironmentsError::InternalServerError(ref cause) => cause,
ListEnvironmentsError::LimitExceeded(ref cause) => cause,
ListEnvironmentsError::NotFound(ref cause) => cause,
ListEnvironmentsError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum UpdateEnvironmentError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl UpdateEnvironmentError {
pub fn from_response(res: BufferedHttpResponse) -> RusotoError<UpdateEnvironmentError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(UpdateEnvironmentError::BadRequest(err.msg))
}
"ConflictException" => {
return RusotoError::Service(UpdateEnvironmentError::Conflict(err.msg))
}
"ForbiddenException" => {
return RusotoError::Service(UpdateEnvironmentError::Forbidden(err.msg))
}
"InternalServerErrorException" => {
return RusotoError::Service(UpdateEnvironmentError::InternalServerError(
err.msg,
))
}
"LimitExceededException" => {
return RusotoError::Service(UpdateEnvironmentError::LimitExceeded(err.msg))
}
"NotFoundException" => {
return RusotoError::Service(UpdateEnvironmentError::NotFound(err.msg))
}
"TooManyRequestsException" => {
return RusotoError::Service(UpdateEnvironmentError::TooManyRequests(err.msg))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for UpdateEnvironmentError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for UpdateEnvironmentError {
fn description(&self) -> &str {
match *self {
UpdateEnvironmentError::BadRequest(ref cause) => cause,
UpdateEnvironmentError::Conflict(ref cause) => cause,
UpdateEnvironmentError::Forbidden(ref cause) => cause,
UpdateEnvironmentError::InternalServerError(ref cause) => cause,
UpdateEnvironmentError::LimitExceeded(ref cause) => cause,
UpdateEnvironmentError::NotFound(ref cause) => cause,
UpdateEnvironmentError::TooManyRequests(ref cause) => cause,
}
}
}
#[derive(Debug, PartialEq)]
pub enum UpdateEnvironmentMembershipError {
BadRequest(String),
Conflict(String),
Forbidden(String),
InternalServerError(String),
LimitExceeded(String),
NotFound(String),
TooManyRequests(String),
}
impl UpdateEnvironmentMembershipError {
pub fn from_response(
res: BufferedHttpResponse,
) -> RusotoError<UpdateEnvironmentMembershipError> {
if let Some(err) = proto::json::Error::parse(&res) {
match err.typ.as_str() {
"BadRequestException" => {
return RusotoError::Service(UpdateEnvironmentMembershipError::BadRequest(
err.msg,
))
}
"ConflictException" => {
return RusotoError::Service(UpdateEnvironmentMembershipError::Conflict(
err.msg,
))
}
"ForbiddenException" => {
return RusotoError::Service(UpdateEnvironmentMembershipError::Forbidden(
err.msg,
))
}
"InternalServerErrorException" => {
return RusotoError::Service(
UpdateEnvironmentMembershipError::InternalServerError(err.msg),
)
}
"LimitExceededException" => {
return RusotoError::Service(UpdateEnvironmentMembershipError::LimitExceeded(
err.msg,
))
}
"NotFoundException" => {
return RusotoError::Service(UpdateEnvironmentMembershipError::NotFound(
err.msg,
))
}
"TooManyRequestsException" => {
return RusotoError::Service(UpdateEnvironmentMembershipError::TooManyRequests(
err.msg,
))
}
"ValidationException" => return RusotoError::Validation(err.msg),
_ => {}
}
}
return RusotoError::Unknown(res);
}
}
impl fmt::Display for UpdateEnvironmentMembershipError {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "{}", self.description())
}
}
impl Error for UpdateEnvironmentMembershipError {
fn description(&self) -> &str {
match *self {
UpdateEnvironmentMembershipError::BadRequest(ref cause) => cause,
UpdateEnvironmentMembershipError::Conflict(ref cause) => cause,
UpdateEnvironmentMembershipError::Forbidden(ref cause) => cause,
UpdateEnvironmentMembershipError::InternalServerError(ref cause) => cause,
UpdateEnvironmentMembershipError::LimitExceeded(ref cause) => cause,
UpdateEnvironmentMembershipError::NotFound(ref cause) => cause,
UpdateEnvironmentMembershipError::TooManyRequests(ref cause) => cause,
}
}
}
pub trait Cloud9 {
fn create_environment_ec2(
&self,
input: CreateEnvironmentEC2Request,
) -> RusotoFuture<CreateEnvironmentEC2Result, CreateEnvironmentEC2Error>;
fn create_environment_membership(
&self,
input: CreateEnvironmentMembershipRequest,
) -> RusotoFuture<CreateEnvironmentMembershipResult, CreateEnvironmentMembershipError>;
fn delete_environment(
&self,
input: DeleteEnvironmentRequest,
) -> RusotoFuture<DeleteEnvironmentResult, DeleteEnvironmentError>;
fn delete_environment_membership(
&self,
input: DeleteEnvironmentMembershipRequest,
) -> RusotoFuture<DeleteEnvironmentMembershipResult, DeleteEnvironmentMembershipError>;
fn describe_environment_memberships(
&self,
input: DescribeEnvironmentMembershipsRequest,
) -> RusotoFuture<DescribeEnvironmentMembershipsResult, DescribeEnvironmentMembershipsError>;
fn describe_environment_status(
&self,
input: DescribeEnvironmentStatusRequest,
) -> RusotoFuture<DescribeEnvironmentStatusResult, DescribeEnvironmentStatusError>;
fn describe_environments(
&self,
input: DescribeEnvironmentsRequest,
) -> RusotoFuture<DescribeEnvironmentsResult, DescribeEnvironmentsError>;
fn list_environments(
&self,
input: ListEnvironmentsRequest,
) -> RusotoFuture<ListEnvironmentsResult, ListEnvironmentsError>;
fn update_environment(
&self,
input: UpdateEnvironmentRequest,
) -> RusotoFuture<UpdateEnvironmentResult, UpdateEnvironmentError>;
fn update_environment_membership(
&self,
input: UpdateEnvironmentMembershipRequest,
) -> RusotoFuture<UpdateEnvironmentMembershipResult, UpdateEnvironmentMembershipError>;
}
#[derive(Clone)]
pub struct Cloud9Client {
client: Client,
region: region::Region,
}
impl Cloud9Client {
pub fn new(region: region::Region) -> Cloud9Client {
Cloud9Client {
client: Client::shared(),
region,
}
}
pub fn new_with<P, D>(
request_dispatcher: D,
credentials_provider: P,
region: region::Region,
) -> Cloud9Client
where
P: ProvideAwsCredentials + Send + Sync + 'static,
P::Future: Send,
D: DispatchSignedRequest + Send + Sync + 'static,
D::Future: Send,
{
Cloud9Client {
client: Client::new_with(credentials_provider, request_dispatcher),
region,
}
}
}
impl Cloud9 for Cloud9Client {
fn create_environment_ec2(
&self,
input: CreateEnvironmentEC2Request,
) -> RusotoFuture<CreateEnvironmentEC2Result, CreateEnvironmentEC2Error> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.CreateEnvironmentEC2",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<CreateEnvironmentEC2Result, _>()
}))
} else {
Box::new(
response.buffer().from_err().and_then(|response| {
Err(CreateEnvironmentEC2Error::from_response(response))
}),
)
}
})
}
fn create_environment_membership(
&self,
input: CreateEnvironmentMembershipRequest,
) -> RusotoFuture<CreateEnvironmentMembershipResult, CreateEnvironmentMembershipError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.CreateEnvironmentMembership",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<CreateEnvironmentMembershipResult, _>()
}))
} else {
Box::new(response.buffer().from_err().and_then(|response| {
Err(CreateEnvironmentMembershipError::from_response(response))
}))
}
})
}
fn delete_environment(
&self,
input: DeleteEnvironmentRequest,
) -> RusotoFuture<DeleteEnvironmentResult, DeleteEnvironmentError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.DeleteEnvironment",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<DeleteEnvironmentResult, _>()
}))
} else {
Box::new(
response
.buffer()
.from_err()
.and_then(|response| Err(DeleteEnvironmentError::from_response(response))),
)
}
})
}
fn delete_environment_membership(
&self,
input: DeleteEnvironmentMembershipRequest,
) -> RusotoFuture<DeleteEnvironmentMembershipResult, DeleteEnvironmentMembershipError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.DeleteEnvironmentMembership",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<DeleteEnvironmentMembershipResult, _>()
}))
} else {
Box::new(response.buffer().from_err().and_then(|response| {
Err(DeleteEnvironmentMembershipError::from_response(response))
}))
}
})
}
fn describe_environment_memberships(
&self,
input: DescribeEnvironmentMembershipsRequest,
) -> RusotoFuture<DescribeEnvironmentMembershipsResult, DescribeEnvironmentMembershipsError>
{
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.DescribeEnvironmentMemberships",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<DescribeEnvironmentMembershipsResult, _>()
}))
} else {
Box::new(response.buffer().from_err().and_then(|response| {
Err(DescribeEnvironmentMembershipsError::from_response(response))
}))
}
})
}
fn describe_environment_status(
&self,
input: DescribeEnvironmentStatusRequest,
) -> RusotoFuture<DescribeEnvironmentStatusResult, DescribeEnvironmentStatusError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.DescribeEnvironmentStatus",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<DescribeEnvironmentStatusResult, _>()
}))
} else {
Box::new(response.buffer().from_err().and_then(|response| {
Err(DescribeEnvironmentStatusError::from_response(response))
}))
}
})
}
fn describe_environments(
&self,
input: DescribeEnvironmentsRequest,
) -> RusotoFuture<DescribeEnvironmentsResult, DescribeEnvironmentsError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.DescribeEnvironments",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<DescribeEnvironmentsResult, _>()
}))
} else {
Box::new(
response.buffer().from_err().and_then(|response| {
Err(DescribeEnvironmentsError::from_response(response))
}),
)
}
})
}
fn list_environments(
&self,
input: ListEnvironmentsRequest,
) -> RusotoFuture<ListEnvironmentsResult, ListEnvironmentsError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.ListEnvironments",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<ListEnvironmentsResult, _>()
}))
} else {
Box::new(
response
.buffer()
.from_err()
.and_then(|response| Err(ListEnvironmentsError::from_response(response))),
)
}
})
}
fn update_environment(
&self,
input: UpdateEnvironmentRequest,
) -> RusotoFuture<UpdateEnvironmentResult, UpdateEnvironmentError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.UpdateEnvironment",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<UpdateEnvironmentResult, _>()
}))
} else {
Box::new(
response
.buffer()
.from_err()
.and_then(|response| Err(UpdateEnvironmentError::from_response(response))),
)
}
})
}
fn update_environment_membership(
&self,
input: UpdateEnvironmentMembershipRequest,
) -> RusotoFuture<UpdateEnvironmentMembershipResult, UpdateEnvironmentMembershipError> {
let mut request = SignedRequest::new("POST", "cloud9", &self.region, "/");
request.set_content_type("application/x-amz-json-1.1".to_owned());
request.add_header(
"x-amz-target",
"AWSCloud9WorkspaceManagementService.UpdateEnvironmentMembership",
);
let encoded = serde_json::to_string(&input).unwrap();
request.set_payload(Some(encoded));
self.client.sign_and_dispatch(request, |response| {
if response.status.is_success() {
Box::new(response.buffer().from_err().and_then(|response| {
proto::json::ResponsePayload::new(&response)
.deserialize::<UpdateEnvironmentMembershipResult, _>()
}))
} else {
Box::new(response.buffer().from_err().and_then(|response| {
Err(UpdateEnvironmentMembershipError::from_response(response))
}))
}
})
}
}