blob: abdcb4a2bf97f8d9e19f36352c348d480c79adfe [file] [log] [blame]
Amit Ghosh09f28362020-06-12 21:52:19 +01001syntax = "proto3";
2
3option go_package = "github.com/opencord/device-management-interface/v3/go/dmi";
4package dmi;
5
6import "dmi/commons.proto";
7import "dmi/hw.proto";
8
9// Protos for the management of a hardware and it's components
10
11message PhysicalInventoryRequest {
12 Uuid device_uuid = 1;
13}
14
15message PhysicalInventoryResponse {
16 Status status = 1;
17 Reason reason = 2;
18 Hardware inventory = 3;
19}
20
21message HWComponentInfoGetRequest {
22 Uuid device_uuid = 1;
23 Uuid component_uuid = 2;
24 string component_name = 3;
25}
26
27message HWComponentInfoSetRequest {
28 Uuid device_uuid = 1;
29 Uuid component_uuid = 2;
30 string component_name = 3;
31 ModifiableComponent changes = 4;
32}
33
34message HWComponentInfoSetResponse {
35 Status status = 1;
36 Reason reason = 2;
37}
38
39message StartManagingDeviceResponse {
40 Status status = 1;
41 Reason reason = 2;
42 Uuid device_uuid = 3;
43}
44
Amit Ghosh366228e2020-07-06 13:46:42 +010045message StopManagingDeviceRequest {
46 string name = 1;
47}
48
49message StopManagingDeviceResponse {
50 Status status = 1;
51 Reason reason = 2;
52}
53
Amit Ghosh09f28362020-06-12 21:52:19 +010054service NativeHWManagementService {
55 // Initializes context for a device and sets up required states
Amit Ghosh704462f2020-06-24 16:44:56 +010056 // In the call to StartManagingDevice, the fields of ModifiableComponent which are relevant
57 // and their meanings in this context is mentioned below:
58 // name = The unique name that needs to be assigned to this hardware;
59 // class = COMPONENT_TYPE_UNDEFINED;
60 // parent = nil;
61 // alias = Optional;
62 // asset_id = Optional;
63 // uri = IP Address of the Hardware;
64 rpc StartManagingDevice(ModifiableComponent) returns(stream StartManagingDeviceResponse);
Amit Ghosh09f28362020-06-12 21:52:19 +010065
Amit Ghosh366228e2020-07-06 13:46:42 +010066 // Stop management of a device and clean up any context and caches for that device
67 rpc StopManagingDevice(StopManagingDeviceRequest) returns(StopManagingDeviceResponse);
68
Amit Ghosh09f28362020-06-12 21:52:19 +010069 // Get the HW inventory details of the Device
70 rpc GetPhysicalInventory(PhysicalInventoryRequest) returns(stream PhysicalInventoryResponse);
71
72 // Get the details of a particular HW component
73 rpc GetHWComponentInfo(HWComponentInfoGetRequest) returns(stream Component);
74
75 // Sets the permissible attributes of a HW component
76 rpc SetHWComponentInfo(HWComponentInfoSetRequest) returns(HWComponentInfoSetResponse);
77}