forked from bougou/go-ipmi
/
cmd_set_user_access.go
75 lines (57 loc) · 1.61 KB
/
cmd_set_user_access.go
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
package ipmi
// 22.26 Set User Access Command
type SetUserAccessRequest struct {
EnableChanging bool
RestrictedToCallback bool
EnableLinkAuth bool
EnableIPMIMessaging bool
ChannelNumber uint8
UserID uint8
MaxPrivLevel uint8
SessionLimit uint8
}
type SetUserAccessResponse struct {
}
func (req *SetUserAccessRequest) Command() Command {
return CommandSetUserAccess
}
func (req *SetUserAccessRequest) Pack() []byte {
out := make([]byte, 4)
b := req.ChannelNumber & 0x0f
if req.EnableChanging {
b = setBit7(b)
}
if req.RestrictedToCallback {
b = setBit6(b)
}
if req.EnableLinkAuth {
b = setBit5(b)
}
if req.EnableIPMIMessaging {
b = setBit4(b)
}
packUint8(b, out, 0)
packUint8(req.UserID&0x3f, out, 1)
packUint8(req.MaxPrivLevel&0x3f, out, 1)
packUint8(req.SessionLimit&0x0f, out, 3)
return out
}
func (res *SetUserAccessResponse) CompletionCodes() map[uint8]string {
// Note: an implementation will not return an error completion code if the user
// access level is set higher than the privilege limit for a given channel. If it is
// desired to bring attention to this condition, it is up to software to check the
// channel privilege limits set using the Set Channel Access command and
// provide notification of any mismatch.
return map[uint8]string{}
}
func (res *SetUserAccessResponse) Unpack(msg []byte) error {
return nil
}
func (res *SetUserAccessResponse) Format() string {
return ""
}
func (c *Client) SetUserAccess(request *SetUserAccessRequest) (response *SetUserAccessResponse, err error) {
response = &SetUserAccessResponse{}
err = c.Exchange(request, response)
return
}