blob: 7dc4677bed26d30f106b73091d220086e32e782a [file] [log] [blame]
Tom Joseph4a8f34d2016-12-06 17:07:46 +05301#pragma once
2
Tom Joseph4a8f34d2016-12-06 17:07:46 +05303#include "message_handler.hpp"
4
Vernon Mauery9e801a22018-10-12 13:20:49 -07005#include <vector>
6
Tom Joseph4a8f34d2016-12-06 17:07:46 +05307namespace command
8{
9
Tom Joseph3563f8f2017-05-08 15:42:54 +053010/**
11 * @struct GetChannelCapabilitiesReq
Tom Joseph4a8f34d2016-12-06 17:07:46 +053012 *
13 * IPMI Request data for Get Channel Authentication Capabilities command
14 */
15struct GetChannelCapabilitiesReq
16{
17 uint8_t channelNumber;
18 uint8_t reqMaxPrivLevel;
19} __attribute__((packed));
20
Tom Joseph3563f8f2017-05-08 15:42:54 +053021/**
22 * @struct GetChannelCapabilitiesResp
Tom Joseph4a8f34d2016-12-06 17:07:46 +053023 *
24 * IPMI Response data for Get Channel Authentication Capabilities command
25 */
26struct GetChannelCapabilitiesResp
27{
Vernon Mauery9e801a22018-10-12 13:20:49 -070028 uint8_t completionCode; // Completion Code
Tom Joseph4a8f34d2016-12-06 17:07:46 +053029
Patrick Williams099fb092023-05-10 07:50:31 -050030 uint8_t channelNumber; // Channel number that the request was
Tom Joseph4a8f34d2016-12-06 17:07:46 +053031 // received on
32
33#if BYTE_ORDER == LITTLE_ENDIAN
Patrick Williams7b534092023-10-20 11:18:45 -050034 uint8_t none:1;
35 uint8_t md2:1;
36 uint8_t md5:1;
37 uint8_t reserved2:1;
38 uint8_t straightKey:1; // Straight password/key support
Tom Joseph4a8f34d2016-12-06 17:07:46 +053039 // Support OEM identified by the IANA OEM ID in RMCP+ ping response
Patrick Williams7b534092023-10-20 11:18:45 -050040 uint8_t oem:1;
41 uint8_t reserved1:1;
42 uint8_t ipmiVersion:1; // 0b = IPMIV1.5 support only, 1B = IPMI V2.0
Tom Joseph4a8f34d2016-12-06 17:07:46 +053043 // support
44#endif
45
46#if BYTE_ORDER == BIG_ENDIAN
Patrick Williams7b534092023-10-20 11:18:45 -050047 uint8_t ipmiVersion:1; // 0b = IPMIV1.5 support only, 1B = IPMI V2.0
Tom Joseph4a8f34d2016-12-06 17:07:46 +053048 // support
Patrick Williams7b534092023-10-20 11:18:45 -050049 uint8_t reserved1:1;
Tom Joseph4a8f34d2016-12-06 17:07:46 +053050 // Support OEM identified by the IANA OEM ID in RMCP+ ping response
Patrick Williams7b534092023-10-20 11:18:45 -050051 uint8_t oem:1;
52 uint8_t straightKey:1; // Straight password/key support
53 uint8_t reserved2:1;
54 uint8_t md5:1;
55 uint8_t md2:1;
56 uint8_t none:1;
Tom Joseph4a8f34d2016-12-06 17:07:46 +053057#endif
58
59#if BYTE_ORDER == LITTLE_ENDIAN
Tom Joseph4a8f34d2016-12-06 17:07:46 +053060 // Anonymous login status for anonymous login enabled/disabled
Patrick Williams7b534092023-10-20 11:18:45 -050061 uint8_t anonymousLogin:1;
Tom Josephdc3e8b92019-02-09 20:21:33 +053062 // Anonymous login status for null usernames enabled/disabled
Patrick Williams7b534092023-10-20 11:18:45 -050063 uint8_t nullUsers:1;
Tom Josephdc3e8b92019-02-09 20:21:33 +053064 // Anonymous login status for non-null usernames enabled/disabled
Patrick Williams7b534092023-10-20 11:18:45 -050065 uint8_t nonNullUsers:1;
66 uint8_t userAuth:1; // User level authentication status
67 uint8_t perMessageAuth:1; // Per-message authentication support
Tom Josephdc3e8b92019-02-09 20:21:33 +053068 // Two key login status . only for IPMI V2.0 RMCP+ RAKP
Patrick Williams7b534092023-10-20 11:18:45 -050069 uint8_t KGStatus:1;
70 uint8_t reserved3:2;
Tom Joseph4a8f34d2016-12-06 17:07:46 +053071#endif
72
73#if BYTE_ORDER == BIG_ENDIAN
Patrick Williams7b534092023-10-20 11:18:45 -050074 uint8_t reserved3:2;
Tom Joseph4a8f34d2016-12-06 17:07:46 +053075 // Two key login status . only for IPMI V2.0 RMCP+ RAKP
Patrick Williams7b534092023-10-20 11:18:45 -050076 uint8_t KGStatus:1;
77 uint8_t perMessageAuth:1; // Per-message authentication support
78 uint8_t userAuth:1; // User level authentication status
Tom Josephdc3e8b92019-02-09 20:21:33 +053079 // Anonymous login status for non-null usernames enabled/disabled
Patrick Williams7b534092023-10-20 11:18:45 -050080 uint8_t nonNullUsers:1;
Tom Josephdc3e8b92019-02-09 20:21:33 +053081 // Anonymous login status for null usernames enabled/disabled
Patrick Williams7b534092023-10-20 11:18:45 -050082 uint8_t nullUsers:1;
Tom Josephdc3e8b92019-02-09 20:21:33 +053083 // Anonymous login status for anonymous login enabled/disabled
Patrick Williams7b534092023-10-20 11:18:45 -050084 uint8_t anonymousLogin:1;
Tom Joseph4a8f34d2016-12-06 17:07:46 +053085#endif
86
87#if BYTE_ORDER == LITTLE_ENDIAN
88 // Extended capabilities will be present only if IPMI version is V2.0
Patrick Williams7b534092023-10-20 11:18:45 -050089 uint8_t extCapabilities:2; // Channel support for IPMI V2.0 connections
90 uint8_t reserved4:6;
Tom Joseph4a8f34d2016-12-06 17:07:46 +053091#endif
92
93#if BYTE_ORDER == BIG_ENDIAN
94 // Extended capabilities will be present only if IPMI version is V2.0
Patrick Williams7b534092023-10-20 11:18:45 -050095 uint8_t reserved4:6;
96 uint8_t extCapabilities:2; // Channel support for IPMI V2.0 connections
Tom Joseph4a8f34d2016-12-06 17:07:46 +053097#endif
98
99 // Below 4 bytes will all the 0's if no OEM authentication type available.
Vernon Mauery9e801a22018-10-12 13:20:49 -0700100 uint8_t oemID[3]; // IANA enterprise number for OEM/organization
101 uint8_t oemAuxillary; // Addition OEM specific information..
Tom Joseph4a8f34d2016-12-06 17:07:46 +0530102} __attribute__((packed));
103
Tom Joseph3563f8f2017-05-08 15:42:54 +0530104/**
Tom Joseph4a8f34d2016-12-06 17:07:46 +0530105 * @brief Get Channel Authentication Capabilities
106 *
107 * This message exchange provides a way for a remote console to discover what
108 * IPMI version is supported i.e. whether or not the BMC supports the IPMI
109 * v2.0 / RMCP+ packet format. It also provides information that the remote
110 * console can use to determine whether anonymous, “one-key”, or “two-key”
111 * logins are used.This information can guide a remote console in how it
112 * presents queries to users for username and password information. This is a
113 * ‘session-less’ command that the BMC accepts in both IPMI v1.5 and v2.0/RMCP+
114 * packet formats.
115 *
116 * @param[in] inPayload - Request Data for the command
117 * @param[in] handler - Reference to the Message Handler
118 *
119 * @return Response data for the command
120 */
Vernon Mauery9e801a22018-10-12 13:20:49 -0700121std::vector<uint8_t>
122 GetChannelCapabilities(const std::vector<uint8_t>& inPayload,
Vernon Mauery41ff9b52021-06-11 11:37:40 -0700123 std::shared_ptr<message::Handler>& handler);
Tom Joseph4a8f34d2016-12-06 17:07:46 +0530124
Vernon Mauery60d6e4e2021-07-26 13:51:35 -0700125/**
126 * @brief Get Channel Cipher Suites
127 *
128 * This command is used to look up what authentication, integrity, and
129 * confidentiality algorithms are supported. The algorithms are used in
130 * combination as ‘Cipher Suites’. This command only applies to implementations
131 * that support IPMI v2.0/RMCP+ sessions. This command can be executed prior to
132 * establishing a session with the BMC.
133 *
134 * @param[in] inPayload - Request Data for the command
135 * @param[in] handler - Reference to the Message Handler
136 *
137 * @return Response data for the command
138 */
139std::vector<uint8_t>
140 getChannelCipherSuites(const std::vector<uint8_t>& inPayload,
141 std::shared_ptr<message::Handler>& handler);
142
Tom Joseph4a8f34d2016-12-06 17:07:46 +0530143} // namespace command