Define a new resource API
You can define a new, custom resource API if:
- You have a resource that does not fit into any of the existing component or service APIs.
- You have a resource that could fit into an existing API, but you want to define an API with different methods and messages than the one in the existing APIs.
Tip
Defining a new resource API is significantly more complex than using an existing API. In most cases, you should try to use an existing API rather than define a new one.
If you want to use most of an existing API but need just a few other functions, try using the DoCommand endpoint and extra parameters to add custom functionality to an existing API.
For example, if you have a sensor and you want to define a Calibrate method, you can use DoCommand.
If your use case uses only DoCommand and no other API methods, you can define a new model of generic component or generic service.
Define your new resource API
Viam uses protocol buffers for API definition.
To define a new API, you need to define the methods and messages of the API in protobuf, write code in Python or Go to implement the higher level server and client functions required, and generate all necessary protobuf module files. The following steps guide you through this process in more detail:
- Decide whether your custom API is a component or a service. If it provides an interface to control hardware, it is a component. If it provides higher-level functionality, it is a service. 
- Choose a name for your API. This is called the - subtypeof your API. For example,- gizmo.- Determine a valid API namespace triplet based on your API name. You can figure out the model namespace triplet later when you create a model that implements your custom API. 
- Create a directory for your module. Within that, create a directory called - src .- Tip- If you are writing your module using Python, you can use this module generator tool to generate stub files for the new API as well as a new module that implements the new API. 
- Define your new API: - Write the proto methods in a <API name>.protofile inside yoursrc/proto directory. For reference:
- And define the proto methods in a protobuf-supported language such as Python or Go in a file called api.pyorapi.go, respectively.
 
- Write the proto methods in a 
- In the root directory of your module, you need to generate some configuration files. You will typically need the following three files for most modules, though different files are required for some advanced use cases. See the Buf documentation for instructions. 
- In the - /src/ directory of your module, use the protobuf compiler to generate all other necessary protocol buffer code, based on the- <API name>.protofile you wrote.- Example generated files for a Python-based service.
The buf.files were generated. Thespeech.proto was manually written.
 
- Example generated files for a Python-based service.
The 
Next steps
Note
After you define a new API and create a model that implements it, keep the following in mind when writing code against your new API:
- You can’t use SDKs to call your new API unless you build out the client to support it. It is easiest to write code against your new API in the language you used to define it.
- Since your API doesn’t have built-in SDK support, you’ll need a local copy of the module code on whatever machine is running client code against it.
- Be sure to import the API definition from the module directory, for example in Python it would be of the form from path.to.module.src.gizmo import Gizmo. This example module written in Python uses a Python script to call the custom API from within the module directory.
Was this page helpful?
Glad to hear it! If you have any other feedback please let us know:
We're sorry about that. To help us improve, please tell us what we can do better:
Thank you!