1<?xml version="1.0" encoding="UTF-8"?>
2<!---->
3<!--################################################################################       -->
4<!--# Redfish Schema:  OutboundConnection v1.0.1                                           -->
5<!--#                                                                                      -->
6<!--# For a detailed change log, see the README file contained in the DSP8010 bundle,      -->
7<!--# available at http://www.dmtf.org/standards/redfish                                   -->
8<!--# Copyright 2014-2023 DMTF.                                                            -->
9<!--# For the full DMTF copyright policy, see http://www.dmtf.org/about/policies/copyright -->
10<!--################################################################################       -->
11<!---->
12<edmx:Edmx xmlns:edmx="http://docs.oasis-open.org/odata/ns/edmx" Version="4.0">
13  <edmx:Reference Uri="http://docs.oasis-open.org/odata/odata/v4.0/errata03/csd01/complete/vocabularies/Org.OData.Core.V1.xml">
14    <edmx:Include Namespace="Org.OData.Core.V1" Alias="OData"/>
15  </edmx:Reference>
16  <edmx:Reference Uri="http://docs.oasis-open.org/odata/odata/v4.0/errata03/csd01/complete/vocabularies/Org.OData.Capabilities.V1.xml">
17    <edmx:Include Namespace="Org.OData.Capabilities.V1" Alias="Capabilities"/>
18  </edmx:Reference>
19  <edmx:Reference Uri="http://redfish.dmtf.org/schemas/v1/RedfishExtensions_v1.xml">
20    <edmx:Include Namespace="RedfishExtensions.v1_0_0" Alias="Redfish"/>
21    <edmx:Include Namespace="Validation.v1_0_0" Alias="Validation"/>
22  </edmx:Reference>
23  <edmx:Reference Uri="http://redfish.dmtf.org/schemas/v1/Resource_v1.xml">
24    <edmx:Include Namespace="Resource"/>
25    <edmx:Include Namespace="Resource.v1_0_0"/>
26  </edmx:Reference>
27  <edmx:Reference Uri="http://redfish.dmtf.org/schemas/v1/CertificateCollection_v1.xml">
28    <edmx:Include Namespace="CertificateCollection"/>
29  </edmx:Reference>
30  <edmx:Reference Uri="http://redfish.dmtf.org/schemas/v1/Session_v1.xml">
31    <edmx:Include Namespace="Session"/>
32  </edmx:Reference>
33
34  <edmx:DataServices>
35
36    <Schema xmlns="http://docs.oasis-open.org/odata/ns/edm" Namespace="OutboundConnection">
37      <Annotation Term="Redfish.OwningEntity" String="DMTF"/>
38
39      <EntityType Name="OutboundConnection" BaseType="Resource.v1_0_0.Resource" Abstract="true">
40        <Annotation Term="OData.Description" String="The OutboundConnection schema defines how the Redfish service connects to a remote client over a WebSocket connection.  This allows a service behind a firewall to establish a connection to a remote client outside of the firewall."/>
41        <Annotation Term="OData.LongDescription" String="This resource shall represent the connection configuration necessary to connect to a remote client.  Services shall initiate the outbound connection over a WebSocket defined in the 'Outbound connections' clause of the Redfish Specification."/>
42        <Annotation Term="Capabilities.InsertRestrictions">
43          <Record>
44            <PropertyValue Property="Insertable" Bool="false"/>
45          </Record>
46        </Annotation>
47        <Annotation Term="Capabilities.UpdateRestrictions">
48          <Record>
49            <PropertyValue Property="Updatable" Bool="true"/>
50          </Record>
51        </Annotation>
52        <Annotation Term="Capabilities.DeleteRestrictions">
53          <Record>
54            <PropertyValue Property="Deletable" Bool="true"/>
55          </Record>
56        </Annotation>
57        <Annotation Term="Redfish.Uris">
58          <Collection>
59            <String>/redfish/v1/AccountService/OutboundConnections/{OutboundConnectionId}</String>
60          </Collection>
61        </Annotation>
62      </EntityType>
63    </Schema>
64
65    <Schema xmlns="http://docs.oasis-open.org/odata/ns/edm" Namespace="OutboundConnection.v1_0_0">
66      <Annotation Term="Redfish.OwningEntity" String="DMTF"/>
67      <Annotation Term="Redfish.Release" String="2023.2"/>
68
69      <EntityType Name="OutboundConnection" BaseType="OutboundConnection.OutboundConnection">
70        <Property Name="Status" Type="Resource.Status" Nullable="false">
71          <Annotation Term="OData.Description" String="The status and health of the resource and its subordinate or dependent resources."/>
72          <Annotation Term="OData.LongDescription" String="This property shall contain any status or health properties of the resource."/>
73        </Property>
74        <Property Name="Actions" Type="OutboundConnection.v1_0_0.Actions" Nullable="false">
75          <Annotation Term="OData.Description" String="The available actions for this resource."/>
76          <Annotation Term="OData.LongDescription" String="This property shall contain the available actions for this resource."/>
77        </Property>
78        <Property Name="Authentication" Type="OutboundConnection.v1_0_0.AuthenticationType">
79          <Annotation Term="Redfish.RequiredOnCreate"/>
80          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
81          <Annotation Term="OData.Description" String="The authentication mechanism for the WebSocket connection."/>
82          <Annotation Term="OData.LongDescription" String="This property shall contain the authentication mechanism for the WebSocket connection."/>
83        </Property>
84        <NavigationProperty Name="Certificates" Type="CertificateCollection.CertificateCollection" ContainsTarget="true" Nullable="false">
85          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
86          <Annotation Term="OData.Description" String="The link to a collection of server certificates for the remote client referenced by the EndpointURI property."/>
87          <Annotation Term="OData.LongDescription" String="This property shall contain a link to a resource collection of type CertificateCollection that represents the server certificates for the remote client referenced by the EndpointURI property.  If the Authentication property contains `MTLS`, the service shall compare the certificates in this collection with the certificate obtained during handshaking with the WebSocket service to verify the identity of the remote client prior to completing the connection.  If the remote client cannot be verified, the service shall not complete the connection.  Regardless of the contents of this collection, services may perform additional verification based on other factors, such as the configuration of the SecurityPolicy resource."/>
88          <Annotation Term="OData.AutoExpandReferences"/>
89        </NavigationProperty>
90        <NavigationProperty Name="ClientCertificates" Type="CertificateCollection.CertificateCollection" ContainsTarget="true" Nullable="false">
91          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
92          <Annotation Term="OData.Description" String="The link to a collection of client identity certificates provided to the remote client referenced by the EndpointURI property."/>
93          <Annotation Term="OData.LongDescription" String="This property shall contain a link to a resource collection of type CertificateCollection that represents the client identity certificates for the service.  If the Authentication property contains `MTLS`, these certificates are provided to the remote client referenced by the EndpointURI property as part of TLS handshaking."/>
94          <Annotation Term="OData.AutoExpandReferences"/>
95        </NavigationProperty>
96        <Property Name="ConnectionEnabled" Type="Edm.Boolean">
97          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/ReadWrite"/>
98          <Annotation Term="OData.Description" String="Indicates if the outbound connection is enabled."/>
99          <Annotation Term="OData.LongDescription" String="This property shall indicate if the outbound connection is enabled.  If `true`, the service shall attempt to establish an outbound connection to the remote client specified by the EndpointURI property.  If `false`, the service shall not attempt to establish a connection to the remote client and shall close the connection if one is already established.  When a connection is established, the service shall create a Session resource to represent the active connection.  When a connection is closed, the service shall delete the connection's respective Session resource.  If the client does not provide this property, the service shall default this value to `true`."/>
100        </Property>
101        <Property Name="EndpointURI" Type="Edm.String" Nullable="false">
102          <Annotation Term="Redfish.RequiredOnCreate"/>
103          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
104          <Annotation Term="OData.Description" String="The URI of the WebSocket connection to the remote client."/>
105          <Annotation Term="OData.LongDescription" String="This property shall contain the WebSocket URI to the external web service of the remote client.  The value shall follow the URI format defined in RFC6455.  Services shall reject URIs that do not contain the scheme `wss`."/>
106          <Annotation Term="OData.IsURL"/>
107        </Property>
108        <Property Name="Links" Type="OutboundConnection.v1_0_0.Links" Nullable="false">
109          <Annotation Term="OData.Description" String="The links to other resources that are related to this resource."/>
110          <Annotation Term="OData.LongDescription" String="This property shall contain links to resources that are related to but are not contained by, or subordinate to, this resource."/>
111        </Property>
112        <Property Name="PreUpgradeHTTPHeaders" Type="OutboundConnection.v1_0_0.HTTPHeaderProperty" Nullable="false">
113          <Annotation Term="OData.Description" String="The HTTP headers to send to the remote client during the initial connection prior to the WebSocket upgrade.  This property is an empty object in responses."/>
114          <Annotation Term="OData.LongDescription" String="This property shall contain an object consisting of the names and values of HTTP headers to send to the remote client during the initial connection prior to the WebSocket upgrade.  This property shall be an empty object in responses."/>
115        </Property>
116        <Property Name="RetryPolicy" Type="OutboundConnection.v1_0_0.RetryPolicyType" Nullable="false">
117          <Annotation Term="OData.Description" String="The retry policy for this outbound connection."/>
118          <Annotation Term="OData.LongDescription" String="This property shall contain the retry policy for this outbound connection.  If not specified by the client in the create request, the service shall assume ConnectionRetryPolicy contains `None`."/>
119        </Property>
120        <Property Name="Roles" Type="Collection(Edm.String)">
121          <Annotation Term="Redfish.RequiredOnCreate"/>
122          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
123          <Annotation Term="OData.Description" String="The Redfish roles that contain the privileges of the remote client for the outbound connection."/>
124          <Annotation Term="OData.LongDescription" String="This property shall contain the Redfish roles that contain the privileges of the remote client for the outbound connection."/>
125        </Property>
126        <Property Name="WebSocketPingIntervalMinutes" Type="Edm.Int64">
127          <Annotation Term="Redfish.RequiredOnCreate"/>
128          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/ReadWrite"/>
129          <Annotation Term="OData.Description" String="Interval for sending the WebSocket ping opcode in minutes.  The value `0` indicates the ping opcode is not sent."/>
130          <Annotation Term="OData.LongDescription" String="This property shall contain the interval for the service to send the WebSocket ping opcode to the remote client in minutes.  If `0`, the service shall not send the WebSocket ping opcode to the remote client."/>
131          <Annotation Term="Validation.Minimum" Int="0"/>
132          <Annotation Term="Validation.Maximum" Int="65535"/>
133        </Property>
134      </EntityType>
135
136      <EnumType Name="OutboundConnectionRetryPolicyType">
137        <Member Name="None">
138          <Annotation Term="OData.Description" String="No retries."/>
139          <Annotation Term="OData.LongDescription" String="This value shall indicate the service will not attempt to re-establish the outbound connection if the connection is dropped or not established.  If the connection is dropped or not established, the service shall set the ConnectionEnabled property to `false`."/>
140        </Member>
141        <Member Name="RetryForever">
142          <Annotation Term="OData.Description" String="Retry forever."/>
143          <Annotation Term="OData.LongDescription" String="This value shall indicate the service will attempt to re-establish the outbound connection at the interval specified by the RetryIntervalMinutes property regardless of the number of retries."/>
144        </Member>
145        <Member Name="RetryCount">
146          <Annotation Term="OData.Description" String="Retry until a maximum count is reached."/>
147          <Annotation Term="OData.LongDescription" String="This value shall indicate the service will attempt to re-establish the outbound connection at the interval specified by the RetryIntervalMinutes property until the number of retries reaches the count specified by the RetryCount property.  If the limit is reached, the service shall set the ConnectionEnabled property to `false`.  If a connection is established, the service shall reset the count."/>
148        </Member>
149      </EnumType>
150
151      <EnumType Name="AuthenticationType">
152        <Member Name="MTLS">
153          <Annotation Term="OData.Description" String="Mutual TLS."/>
154          <Annotation Term="OData.LongDescription" String="This value shall indicate the service will exchange and verify certificates during TLS handshaking when establishing the outbound connecting."/>
155        </Member>
156        <Member Name="JWT">
157          <Annotation Term="OData.Description" String="JSON Web Token."/>
158          <Annotation Term="OData.LongDescription" String="This value shall indicate an RFC7519-defined JSON Web Token (JWT) is specified in one of the HTTP headers in the PreUpgradeHTTPHeaders property.  This is typically encoded in the `Authorization` header with the scheme `Bearer`."/>
159        </Member>
160        <Member Name="None">
161          <Annotation Term="OData.Description" String="No authentication."/>
162          <Annotation Term="OData.LongDescription" String="This value shall indicate the service does not provide any authentication information to the remote client."/>
163        </Member>
164        <Member Name="OEM">
165          <Annotation Term="OData.Description" String="OEM-specific."/>
166          <Annotation Term="OData.LongDescription" String="This value shall indicate an OEM-specific authentication mechanism."/>
167        </Member>
168      </EnumType>
169
170      <ComplexType Name="HTTPHeaderProperty">
171        <Annotation Term="OData.AdditionalProperties" Bool="false"/>
172        <Annotation Term="OData.Description" String="The HTTP header value is the property value.  The header name is the property name."/>
173        <Annotation Term="OData.LongDescription" String="This type shall contain the HTTP header name and value to add to the Redfish responses over the WebSocket."/>
174        <Annotation Term="Redfish.DynamicPropertyPatterns">
175          <Collection>
176            <Record>
177              <PropertyValue Property="Pattern" String="^[^:\\s]+$"/>
178              <PropertyValue Property="Type" String="Edm.String"/>
179            </Record>
180          </Collection>
181        </Annotation>
182      </ComplexType>
183
184      <ComplexType Name="RetryPolicyType">
185        <Annotation Term="OData.AdditionalProperties" Bool="false"/>
186        <Annotation Term="OData.Description" String="The retry policy for an outbound connection."/>
187        <Annotation Term="OData.LongDescription" String="This type shall contain the retry policy for an outbound connection."/>
188        <Property Name="ConnectionRetryPolicy" Type="OutboundConnection.v1_0_0.OutboundConnectionRetryPolicyType">
189          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
190          <Annotation Term="OData.Description" String="The type of retry policy for this outbound connection."/>
191          <Annotation Term="OData.LongDescription" String="This property shall contain the type of retry policy for this outbound connection."/>
192        </Property>
193        <Property Name="RetryIntervalMinutes" Type="Edm.Int64">
194          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/ReadWrite"/>
195          <Annotation Term="OData.Description" String="The retry interval in minutes."/>
196          <Annotation Term="OData.LongDescription" String="This property shall contain the interval for the service to retry connecting to remote client in minutes."/>
197        </Property>
198        <Property Name="RetryCount" Type="Edm.Int64">
199          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/ReadWrite"/>
200          <Annotation Term="OData.Description" String="The number of retries to attempt if the retry policy specifies a maximum number of retries."/>
201          <Annotation Term="OData.LongDescription" String="This property shall contain the number of retries to attempt if the retry policy specifies a maximum number of retries."/>
202        </Property>
203      </ComplexType>
204
205      <ComplexType Name="Actions">
206        <Annotation Term="OData.AdditionalProperties" Bool="false"/>
207        <Annotation Term="OData.Description" String="The available actions for this resource."/>
208        <Annotation Term="OData.LongDescription" String="This type shall contain the available actions for this resource."/>
209        <Property Name="Oem" Type="OutboundConnection.v1_0_0.OemActions" Nullable="false">
210          <Annotation Term="OData.Description" String="The available OEM-specific actions for this resource."/>
211          <Annotation Term="OData.LongDescription" String="This property shall contain the available OEM-specific actions for this resource."/>
212        </Property>
213      </ComplexType>
214
215      <ComplexType Name="OemActions">
216        <Annotation Term="OData.AdditionalProperties" Bool="true"/>
217        <Annotation Term="OData.Description" String="The available OEM-specific actions for this resource."/>
218        <Annotation Term="OData.LongDescription" String="This type shall contain the available OEM-specific actions for this resource."/>
219      </ComplexType>
220
221      <ComplexType Name="Links" BaseType="Resource.Links">
222        <Annotation Term="OData.Description" String="The links to other resources that are related to this resource."/>
223        <Annotation Term="OData.LongDescription" String="This Redfish Specification-described type shall contain links to resources that are related to but are not contained by, or subordinate to, this resource."/>
224        <NavigationProperty Name="Session" Type="Session.Session">
225          <Annotation Term="OData.Permissions" EnumMember="OData.Permission/Read"/>
226          <Annotation Term="OData.Description" String="The link to the session for this outbound connection."/>
227          <Annotation Term="OData.LongDescription" String="This property shall contain the link to a resource of type Session that represents the active connection for this outbound connection."/>
228          <Annotation Term="OData.AutoExpandReferences"/>
229        </NavigationProperty>
230      </ComplexType>
231    </Schema>
232
233    <Schema xmlns="http://docs.oasis-open.org/odata/ns/edm" Namespace="OutboundConnection.v1_0_1">
234      <Annotation Term="Redfish.OwningEntity" String="DMTF"/>
235      <Annotation Term="OData.Description" String="This version was created to correct various typographical errors."/>
236      <EntityType Name="OutboundConnection" BaseType="OutboundConnection.v1_0_0.OutboundConnection"/>
237    </Schema>
238
239  </edmx:DataServices>
240</edmx:Edmx>
241