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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
#[allow(missing_docs)] // documentation missing in model
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub struct CreateFleetOutput {
    /// <p>The properties for the new fleet, including the current status. All fleets are placed in <code>NEW</code> status on creation. </p>
    pub fleet_attributes: ::std::option::Option<crate::types::FleetAttributes>,
    /// <p>The fleet's locations and life-cycle status of each location. For new fleets, the status of all locations is set to <code>NEW</code>. During fleet creation, Amazon GameLift updates each location status as instances are deployed there and prepared for game hosting. This list includes an entry for the fleet's home Region. For fleets with no remote locations, only one entry, representing the home Region, is returned.</p>
    pub location_states: ::std::option::Option<::std::vec::Vec<crate::types::LocationState>>,
    _request_id: Option<String>,
}
impl CreateFleetOutput {
    /// <p>The properties for the new fleet, including the current status. All fleets are placed in <code>NEW</code> status on creation. </p>
    pub fn fleet_attributes(&self) -> ::std::option::Option<&crate::types::FleetAttributes> {
        self.fleet_attributes.as_ref()
    }
    /// <p>The fleet's locations and life-cycle status of each location. For new fleets, the status of all locations is set to <code>NEW</code>. During fleet creation, Amazon GameLift updates each location status as instances are deployed there and prepared for game hosting. This list includes an entry for the fleet's home Region. For fleets with no remote locations, only one entry, representing the home Region, is returned.</p>
    pub fn location_states(&self) -> ::std::option::Option<&[crate::types::LocationState]> {
        self.location_states.as_deref()
    }
}
impl ::aws_http::request_id::RequestId for CreateFleetOutput {
    fn request_id(&self) -> Option<&str> {
        self._request_id.as_deref()
    }
}
impl CreateFleetOutput {
    /// Creates a new builder-style object to manufacture [`CreateFleetOutput`](crate::operation::create_fleet::CreateFleetOutput).
    pub fn builder() -> crate::operation::create_fleet::builders::CreateFleetOutputBuilder {
        crate::operation::create_fleet::builders::CreateFleetOutputBuilder::default()
    }
}

/// A builder for [`CreateFleetOutput`](crate::operation::create_fleet::CreateFleetOutput).
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::default::Default, ::std::fmt::Debug)]
pub struct CreateFleetOutputBuilder {
    pub(crate) fleet_attributes: ::std::option::Option<crate::types::FleetAttributes>,
    pub(crate) location_states: ::std::option::Option<::std::vec::Vec<crate::types::LocationState>>,
    _request_id: Option<String>,
}
impl CreateFleetOutputBuilder {
    /// <p>The properties for the new fleet, including the current status. All fleets are placed in <code>NEW</code> status on creation. </p>
    pub fn fleet_attributes(mut self, input: crate::types::FleetAttributes) -> Self {
        self.fleet_attributes = ::std::option::Option::Some(input);
        self
    }
    /// <p>The properties for the new fleet, including the current status. All fleets are placed in <code>NEW</code> status on creation. </p>
    pub fn set_fleet_attributes(mut self, input: ::std::option::Option<crate::types::FleetAttributes>) -> Self {
        self.fleet_attributes = input;
        self
    }
    /// <p>The properties for the new fleet, including the current status. All fleets are placed in <code>NEW</code> status on creation. </p>
    pub fn get_fleet_attributes(&self) -> &::std::option::Option<crate::types::FleetAttributes> {
        &self.fleet_attributes
    }
    /// Appends an item to `location_states`.
    ///
    /// To override the contents of this collection use [`set_location_states`](Self::set_location_states).
    ///
    /// <p>The fleet's locations and life-cycle status of each location. For new fleets, the status of all locations is set to <code>NEW</code>. During fleet creation, Amazon GameLift updates each location status as instances are deployed there and prepared for game hosting. This list includes an entry for the fleet's home Region. For fleets with no remote locations, only one entry, representing the home Region, is returned.</p>
    pub fn location_states(mut self, input: crate::types::LocationState) -> Self {
        let mut v = self.location_states.unwrap_or_default();
        v.push(input);
        self.location_states = ::std::option::Option::Some(v);
        self
    }
    /// <p>The fleet's locations and life-cycle status of each location. For new fleets, the status of all locations is set to <code>NEW</code>. During fleet creation, Amazon GameLift updates each location status as instances are deployed there and prepared for game hosting. This list includes an entry for the fleet's home Region. For fleets with no remote locations, only one entry, representing the home Region, is returned.</p>
    pub fn set_location_states(mut self, input: ::std::option::Option<::std::vec::Vec<crate::types::LocationState>>) -> Self {
        self.location_states = input;
        self
    }
    /// <p>The fleet's locations and life-cycle status of each location. For new fleets, the status of all locations is set to <code>NEW</code>. During fleet creation, Amazon GameLift updates each location status as instances are deployed there and prepared for game hosting. This list includes an entry for the fleet's home Region. For fleets with no remote locations, only one entry, representing the home Region, is returned.</p>
    pub fn get_location_states(&self) -> &::std::option::Option<::std::vec::Vec<crate::types::LocationState>> {
        &self.location_states
    }
    pub(crate) fn _request_id(mut self, request_id: impl Into<String>) -> Self {
        self._request_id = Some(request_id.into());
        self
    }

    pub(crate) fn _set_request_id(&mut self, request_id: Option<String>) -> &mut Self {
        self._request_id = request_id;
        self
    }
    /// Consumes the builder and constructs a [`CreateFleetOutput`](crate::operation::create_fleet::CreateFleetOutput).
    pub fn build(self) -> crate::operation::create_fleet::CreateFleetOutput {
        crate::operation::create_fleet::CreateFleetOutput {
            fleet_attributes: self.fleet_attributes,
            location_states: self.location_states,
            _request_id: self._request_id,
        }
    }
}