Unverified Commit 147958b0 authored by per1234's avatar per1234 Committed by GitHub

[skip changelog] Add documentation for board components of the gRPC interface (#694)

Comments added to the .proto files are included in the generated gRPC interface documentation.
parent 31517efa
......@@ -21,7 +21,10 @@ var _ = math.Inf
const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
type BoardDetailsReq struct {
// Arduino Core Service instance from the `Init` response.
Instance *Instance `protobuf:"bytes,1,opt,name=instance,proto3" json:"instance,omitempty"`
// The fully qualified board name of the board you want information about
// (e.g., `arduino:avr:uno`).
Fqbn string `protobuf:"bytes,2,opt,name=fqbn,proto3" json:"fqbn,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -68,17 +71,30 @@ func (m *BoardDetailsReq) GetFqbn() string {
}
type BoardDetailsResp struct {
// The fully qualified board name of the board.
Fqbn string `protobuf:"bytes,1,opt,name=fqbn,proto3" json:"fqbn,omitempty"`
// Name used to identify the board to humans (e.g., Arduino/Genuino Uno).
Name string `protobuf:"bytes,2,opt,name=name,proto3" json:"name,omitempty"`
// Installed version of the board's platform.
Version string `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"`
// The board ID component of the FQBN (e.g., `uno`).
PropertiesId string `protobuf:"bytes,4,opt,name=propertiesId,proto3" json:"propertiesId,omitempty"`
// Board alias that can be used as a more user friendly alternative to the
// FQBN.
Alias string `protobuf:"bytes,5,opt,name=alias,proto3" json:"alias,omitempty"`
// Whether this is an official or 3rd party board.
Official bool `protobuf:"varint,6,opt,name=official,proto3" json:"official,omitempty"`
// URL of the board's pinout documentation.
Pinout string `protobuf:"bytes,7,opt,name=pinout,proto3" json:"pinout,omitempty"`
// Data about the package that contains the board's platform.
Package *Package `protobuf:"bytes,8,opt,name=package,proto3" json:"package,omitempty"`
// Data about the board's platform.
Platform *BoardPlatform `protobuf:"bytes,9,opt,name=platform,proto3" json:"platform,omitempty"`
// Tool dependencies of the board.
ToolsDependencies []*ToolsDependencies `protobuf:"bytes,10,rep,name=toolsDependencies,proto3" json:"toolsDependencies,omitempty"`
// The board's custom configuration options.
ConfigOptions []*ConfigOption `protobuf:"bytes,11,rep,name=config_options,json=configOptions,proto3" json:"config_options,omitempty"`
// Identifying information for the board (e.g., USB VID/PID).
IdentificationPref []*IdentificationPref `protobuf:"bytes,12,rep,name=identification_pref,json=identificationPref,proto3" json:"identification_pref,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -195,6 +211,7 @@ func (m *BoardDetailsResp) GetIdentificationPref() []*IdentificationPref {
}
type IdentificationPref struct {
// Identifying information for USB-connected boards.
UsbID *USBID `protobuf:"bytes,1,opt,name=usbID,proto3" json:"usbID,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -234,7 +251,9 @@ func (m *IdentificationPref) GetUsbID() *USBID {
}
type USBID struct {
// USB vendor ID.
VID string `protobuf:"bytes,1,opt,name=VID,proto3" json:"VID,omitempty"`
// USB product ID.
PID string `protobuf:"bytes,2,opt,name=PID,proto3" json:"PID,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -281,11 +300,18 @@ func (m *USBID) GetPID() string {
}
type Package struct {
// Maintainer of the package.
Maintainer string `protobuf:"bytes,1,opt,name=maintainer,proto3" json:"maintainer,omitempty"`
// The URL of the platforms index file
// (e.g., https://downloads.arduino.cc/packages/package_index.json).
Url string `protobuf:"bytes,2,opt,name=url,proto3" json:"url,omitempty"`
// A URL provided by the package author, intended to point to their website.
WebsiteURL string `protobuf:"bytes,3,opt,name=websiteURL,proto3" json:"websiteURL,omitempty"`
// Email address of the package maintainer.
Email string `protobuf:"bytes,4,opt,name=email,proto3" json:"email,omitempty"`
// Package vendor name.
Name string `protobuf:"bytes,5,opt,name=name,proto3" json:"name,omitempty"`
// Resources for getting help about using the package.
Help *Help `protobuf:"bytes,6,opt,name=help,proto3" json:"help,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -360,6 +386,7 @@ func (m *Package) GetHelp() *Help {
}
type Help struct {
// URL for getting online help.
Online string `protobuf:"bytes,1,opt,name=online,proto3" json:"online,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -399,12 +426,19 @@ func (m *Help) GetOnline() string {
}
type BoardPlatform struct {
// Architecture of the platform (e.g., `avr`).
Architecture string `protobuf:"bytes,1,opt,name=architecture,proto3" json:"architecture,omitempty"`
// Category of the platform. Set to `Contributed` for 3rd party platforms.
Category string `protobuf:"bytes,2,opt,name=category,proto3" json:"category,omitempty"`
// Download URL of the platform archive file.
Url string `protobuf:"bytes,3,opt,name=url,proto3" json:"url,omitempty"`
// File name of the platform archive.
ArchiveFileName string `protobuf:"bytes,4,opt,name=archiveFileName,proto3" json:"archiveFileName,omitempty"`
// Checksum of the platform archive.
Checksum string `protobuf:"bytes,5,opt,name=checksum,proto3" json:"checksum,omitempty"`
// File size of the platform archive.
Size int64 `protobuf:"varint,6,opt,name=size,proto3" json:"size,omitempty"`
// Name used to identify the platform to humans.
Name string `protobuf:"bytes,7,opt,name=name,proto3" json:"name,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -486,9 +520,13 @@ func (m *BoardPlatform) GetName() string {
}
type ToolsDependencies struct {
// Vendor name of the package containing the tool definition.
Packager string `protobuf:"bytes,1,opt,name=packager,proto3" json:"packager,omitempty"`
// Tool name.
Name string `protobuf:"bytes,2,opt,name=name,proto3" json:"name,omitempty"`
// Tool version.
Version string `protobuf:"bytes,3,opt,name=version,proto3" json:"version,omitempty"`
// Data for the operating system-specific builds of the tool.
Systems []*Systems `protobuf:"bytes,4,rep,name=systems,proto3" json:"systems,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -549,10 +587,15 @@ func (m *ToolsDependencies) GetSystems() []*Systems {
}
type Systems struct {
// Checksum of the tool archive.
Checksum string `protobuf:"bytes,1,opt,name=checksum,proto3" json:"checksum,omitempty"`
// Operating system identifier.
Host string `protobuf:"bytes,2,opt,name=host,proto3" json:"host,omitempty"`
// File name of the tool archive.
ArchiveFileName string `protobuf:"bytes,3,opt,name=archiveFileName,proto3" json:"archiveFileName,omitempty"`
// Download URL of the tool archive.
Url string `protobuf:"bytes,4,opt,name=url,proto3" json:"url,omitempty"`
// File size of the tool archive.
Size int64 `protobuf:"varint,5,opt,name=size,proto3" json:"size,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -620,8 +663,11 @@ func (m *Systems) GetSize() int64 {
}
type ConfigOption struct {
// ID of the configuration option. For identifying the option to machines.
Option string `protobuf:"bytes,1,opt,name=option,proto3" json:"option,omitempty"`
// Name of the configuration option for identifying the option to humans.
OptionLabel string `protobuf:"bytes,2,opt,name=option_label,json=optionLabel,proto3" json:"option_label,omitempty"`
// Possible values of the configuration option.
Values []*ConfigValue `protobuf:"bytes,3,rep,name=values,proto3" json:"values,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -675,8 +721,11 @@ func (m *ConfigOption) GetValues() []*ConfigValue {
}
type ConfigValue struct {
// The configuration option value.
Value string `protobuf:"bytes,1,opt,name=value,proto3" json:"value,omitempty"`
// Label to identify the configuration option to humans.
ValueLabel string `protobuf:"bytes,2,opt,name=value_label,json=valueLabel,proto3" json:"value_label,omitempty"`
// Whether the configuration option is selected.
Selected bool `protobuf:"varint,3,opt,name=selected,proto3" json:"selected,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -730,9 +779,15 @@ func (m *ConfigValue) GetSelected() bool {
}
type BoardAttachReq struct {
// Arduino Core Service instance from the `Init` response.
Instance *Instance `protobuf:"bytes,1,opt,name=instance,proto3" json:"instance,omitempty"`
// The board's URI (e.g., /dev/ttyACM0).
BoardUri string `protobuf:"bytes,2,opt,name=board_uri,json=boardUri,proto3" json:"board_uri,omitempty"`
// Path of the sketch to attach the board to. The board attachment
// metadata will be saved to `{sketch_path}/sketch.json`.
SketchPath string `protobuf:"bytes,3,opt,name=sketch_path,json=sketchPath,proto3" json:"sketch_path,omitempty"`
// Duration in seconds to search the given URI for a connected board before
// timing out. The default value is 5 seconds.
SearchTimeout string `protobuf:"bytes,4,opt,name=search_timeout,json=searchTimeout,proto3" json:"search_timeout,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -793,6 +848,7 @@ func (m *BoardAttachReq) GetSearchTimeout() string {
}
type BoardAttachResp struct {
// Description of the current stage of the board attachment.
TaskProgress *TaskProgress `protobuf:"bytes,1,opt,name=task_progress,json=taskProgress,proto3" json:"task_progress,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -832,6 +888,7 @@ func (m *BoardAttachResp) GetTaskProgress() *TaskProgress {
}
type BoardListReq struct {
// Arduino Core Service instance from the `Init` response.
Instance *Instance `protobuf:"bytes,1,opt,name=instance,proto3" json:"instance,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -871,6 +928,7 @@ func (m *BoardListReq) GetInstance() *Instance {
}
type BoardListResp struct {
// List of ports and the boards detected on those ports.
Ports []*DetectedPort `protobuf:"bytes,1,rep,name=ports,proto3" json:"ports,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -910,9 +968,13 @@ func (m *BoardListResp) GetPorts() []*DetectedPort {
}
type DetectedPort struct {
// Address of the port (e.g., `serial:///dev/ttyACM0`).
Address string `protobuf:"bytes,1,opt,name=address,proto3" json:"address,omitempty"`
// Protocol of the port (e.g., `serial`).
Protocol string `protobuf:"bytes,2,opt,name=protocol,proto3" json:"protocol,omitempty"`
// A human friendly description of the protocol (e.g., "Serial Port (USB)").
ProtocolLabel string `protobuf:"bytes,3,opt,name=protocol_label,json=protocolLabel,proto3" json:"protocol_label,omitempty"`
// The boards attached to the port.
Boards []*BoardListItem `protobuf:"bytes,4,rep,name=boards,proto3" json:"boards,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -973,7 +1035,9 @@ func (m *DetectedPort) GetBoards() []*BoardListItem {
}
type BoardListAllReq struct {
// Arduino Core Service instance from the `Init` response.
Instance *Instance `protobuf:"bytes,1,opt,name=instance,proto3" json:"instance,omitempty"`
// The search query to filter the board list by.
SearchArgs []string `protobuf:"bytes,2,rep,name=search_args,json=searchArgs,proto3" json:"search_args,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -1020,6 +1084,7 @@ func (m *BoardListAllReq) GetSearchArgs() []string {
}
type BoardListAllResp struct {
// List of installed boards.
Boards []*BoardListItem `protobuf:"bytes,1,rep,name=boards,proto3" json:"boards,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......@@ -1059,7 +1124,9 @@ func (m *BoardListAllResp) GetBoards() []*BoardListItem {
}
type BoardListItem struct {
// The name for use when identifying the board to a human.
Name string `protobuf:"bytes,1,opt,name=name,proto3" json:"name,omitempty"`
// The fully qualified board name. Used to identify the board to a machine.
FQBN string `protobuf:"bytes,2,opt,name=FQBN,proto3" json:"FQBN,omitempty"`
XXX_NoUnkeyedLiteral struct{} `json:"-"`
XXX_unrecognized []byte `json:"-"`
......
......@@ -22,122 +22,189 @@ option go_package = "github.com/arduino/arduino-cli/rpc/commands";
import "commands/common.proto";
message BoardDetailsReq {
// Arduino Core Service instance from the `Init` response.
Instance instance = 1;
// The fully qualified board name of the board you want information about
// (e.g., `arduino:avr:uno`).
string fqbn = 2;
}
message BoardDetailsResp {
// The fully qualified board name of the board.
string fqbn = 1;
// Name used to identify the board to humans (e.g., Arduino/Genuino Uno).
string name = 2;
// Installed version of the board's platform.
string version = 3;
// The board ID component of the FQBN (e.g., `uno`).
string propertiesId = 4;
// Board alias that can be used as a more user friendly alternative to the
// FQBN.
string alias = 5;
// Whether this is an official or 3rd party board.
bool official = 6;
// URL of the board's pinout documentation.
string pinout = 7;
// Data about the package that contains the board's platform.
Package package = 8;
// Data about the board's platform.
BoardPlatform platform = 9;
// Tool dependencies of the board.
repeated ToolsDependencies toolsDependencies = 10;
// The board's custom configuration options.
repeated ConfigOption config_options = 11;
// Identifying information for the board (e.g., USB VID/PID).
repeated IdentificationPref identification_pref = 12;
}
message IdentificationPref {
// Identifying information for USB-connected boards.
USBID usbID = 1;
}
message USBID {
// USB vendor ID.
string VID = 1;
// USB product ID.
string PID = 2;
}
message Package {
// Maintainer of the package.
string maintainer = 1;
// The URL of the platforms index file
// (e.g., https://downloads.arduino.cc/packages/package_index.json).
string url = 2;
// A URL provided by the package author, intended to point to their website.
string websiteURL = 3;
// Email address of the package maintainer.
string email = 4;
// Package vendor name.
string name = 5;
// Resources for getting help about using the package.
Help help = 6;
}
message Help {
// URL for getting online help.
string online = 1;
}
message BoardPlatform {
// Architecture of the platform (e.g., `avr`).
string architecture = 1;
// Category of the platform. Set to `Contributed` for 3rd party platforms.
string category = 2;
// Download URL of the platform archive file.
string url = 3;
// File name of the platform archive.
string archiveFileName = 4;
// Checksum of the platform archive.
string checksum = 5;
// File size of the platform archive.
int64 size = 6;
// Name used to identify the platform to humans.
string name = 7;
}
message ToolsDependencies {
// Vendor name of the package containing the tool definition.
string packager = 1;
// Tool name.
string name = 2;
// Tool version.
string version = 3;
// Data for the operating system-specific builds of the tool.
repeated Systems systems = 4;
}
message Systems {
// Checksum of the tool archive.
string checksum = 1;
// Operating system identifier.
string host = 2;
// File name of the tool archive.
string archiveFileName = 3;
// Download URL of the tool archive.
string url = 4;
// File size of the tool archive.
int64 size = 5;
}
message ConfigOption {
// ID of the configuration option. For identifying the option to machines.
string option = 1;
// Name of the configuration option for identifying the option to humans.
string option_label = 2;
// Possible values of the configuration option.
repeated ConfigValue values = 3;
}
message ConfigValue {
// The configuration option value.
string value = 1;
// Label to identify the configuration option to humans.
string value_label = 2;
// Whether the configuration option is selected.
bool selected = 3;
}
message BoardAttachReq {
// Arduino Core Service instance from the `Init` response.
Instance instance = 1;
// The board's URI (e.g., /dev/ttyACM0).
string board_uri = 2;
// Path of the sketch to attach the board to. The board attachment
// metadata will be saved to `{sketch_path}/sketch.json`.
string sketch_path = 3;
// Duration in seconds to search the given URI for a connected board before
// timing out. The default value is 5 seconds.
string search_timeout = 4;
}
message BoardAttachResp {
// Description of the current stage of the board attachment.
TaskProgress task_progress = 1;
}
message BoardListReq {
// Arduino Core Service instance from the `Init` response.
Instance instance = 1;
}
message BoardListResp {
// List of ports and the boards detected on those ports.
repeated DetectedPort ports = 1;
}
message DetectedPort {
// Address of the port (e.g., `serial:///dev/ttyACM0`).
string address = 1;
// Protocol of the port (e.g., `serial`).
string protocol = 2;
// A human friendly description of the protocol (e.g., "Serial Port (USB)").
string protocol_label = 3;
// The boards attached to the port.
repeated BoardListItem boards = 4;
}
message BoardListAllReq {
// Arduino Core Service instance from the `Init` response.
Instance instance = 1;
// The search query to filter the board list by.
repeated string search_args = 2;
}
message BoardListAllResp {
// List of installed boards.
repeated BoardListItem boards = 1;
}
message BoardListItem {
// The name for use when identifying the board to a human.
string name = 1;
// The fully qualified board name. Used to identify the board to a machine.
string FQBN = 2;
}
......@@ -641,8 +641,12 @@ type ArduinoCoreClient interface {
Version(ctx context.Context, in *VersionReq, opts ...grpc.CallOption) (*VersionResp, error)
// Requests details about a board
BoardDetails(ctx context.Context, in *BoardDetailsReq, opts ...grpc.CallOption) (*BoardDetailsResp, error)
// Attach a board to a sketch. When the `fqbn` field of a request is not
// provided, the FQBN of the attached board will be used.
BoardAttach(ctx context.Context, in *BoardAttachReq, opts ...grpc.CallOption) (ArduinoCore_BoardAttachClient, error)
// List the boards currently connected to the computer.
BoardList(ctx context.Context, in *BoardListReq, opts ...grpc.CallOption) (*BoardListResp, error)
// List all the boards provided by installed platforms.
BoardListAll(ctx context.Context, in *BoardListAllReq, opts ...grpc.CallOption) (*BoardListAllResp, error)
Compile(ctx context.Context, in *CompileReq, opts ...grpc.CallOption) (ArduinoCore_CompileClient, error)
// Download and install a platform and its tool dependencies.
......@@ -1240,8 +1244,12 @@ type ArduinoCoreServer interface {
Version(context.Context, *VersionReq) (*VersionResp, error)
// Requests details about a board
BoardDetails(context.Context, *BoardDetailsReq) (*BoardDetailsResp, error)
// Attach a board to a sketch. When the `fqbn` field of a request is not
// provided, the FQBN of the attached board will be used.
BoardAttach(*BoardAttachReq, ArduinoCore_BoardAttachServer) error
// List the boards currently connected to the computer.
BoardList(context.Context, *BoardListReq) (*BoardListResp, error)
// List all the boards provided by installed platforms.
BoardListAll(context.Context, *BoardListAllReq) (*BoardListAllResp, error)
Compile(*CompileReq, ArduinoCore_CompileServer) error
// Download and install a platform and its tool dependencies.
......
......@@ -55,10 +55,14 @@ service ArduinoCore {
// Requests details about a board
rpc BoardDetails(BoardDetailsReq) returns (BoardDetailsResp);
// Attach a board to a sketch. When the `fqbn` field of a request is not
// provided, the FQBN of the attached board will be used.
rpc BoardAttach(BoardAttachReq) returns (stream BoardAttachResp);
// List the boards currently connected to the computer.
rpc BoardList(BoardListReq) returns (BoardListResp);
// List all the boards provided by installed platforms.
rpc BoardListAll(BoardListAllReq) returns (BoardListAllResp);
rpc Compile(CompileReq) returns (stream CompileResp);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment