Smarter API Command-line Interface
The Smarter cli is a standalone application written in Go lang that runs on Windows, macOS and Linux. It is separately managed in github.com/smarter-sh/smarter-cli . It is a lightweight command-line UI for interacting with the Smarter API .
Commands
The cli implements a set of verbs for working with Smarter resources
- apply : executes services as necessary in order to migrate a Smarter resource from its present state to that which is described in the provided manifest.
- delete : permanently, unrecoverably destroys a Smarter resource.
- deploy : manages the deploy state of a deployable Smarter resource (Plugin and ChatBot).
- describe : returns a report in yaml or json format that is a superset of a manifest describing the present state of a Smarter resource.
- logs : returns log data in standard console log format for a Smarter resource
- status : returns a report in yaml or json format that provides real-time information on the state of the Smarter platform.
Related API endpoints
- https://api.smarter.sh/v0/cli/apply/: Apply a manifest
- https://api.smarter.sh/v0/cli/describe/: print the manifest
- https://api.smarter.sh/v0/cli/deploy/: Deploy a resource
- https://api.smarter.sh/v0/cli/logs/: Get logs for a resource
- https://api.smarter.sh/v0/cli/delete/: Delete a resource
- https://api.smarter.sh/v0/cli/status/: Smarter platform status
Manifest Spec
The cli is designed to work with a manifest utf-8 text document, in yaml or json format, inspired by Kubernetes' kubectl, itself modeled on the OpenAPI Specification v3.x . The actual implementation of this specification is located here . The Smarter API can manage escaped representations of characters outside of the utf-8 standard.
Kind
- Account
- ApiKey
- Chat
- ChatHistory
- ChatPluginUsage
- ChatToolCall
- ChatBot
- Plugin
- SqlConnection
- ApiConnection
- User
- Secret
Broker Model
              Manifest processing depends on a abstract broker service. Brokers are implemented inside of Django Views and are responsible for mapping the verb of an http request -- get, post, patch, put, delete -- to the Python class containing the necessary services for the manifest
              
               kind
              
              . Brokers are responsible for the following:
             
- Defining a manifest file structure using a collection of Python enumerated data types along with basic Pydantic features.
- Reading and parsing a manifest document in yaml or json format
- Validating manifests, using Pydantic models that enforce format, syntax, and data and business rule validations.
- Instantiating the correct Python class for the manifest
- Implementing the services that back http requests: get, post, patch, put, delete
A brokered entity consists of the following:
- Pydantic model . This is a Pydantic model that describes the Manifest yaml document. Smarter manifests closely resemble Kubernetes manifests.
- Broker . Brokers marshal requests to the correct Broker class and method.
- Transformer . Transformers map data to/from a Smarter manifest and a Django object relational model (ORM).
- Docs url endpoints . Examples: https://platform.smarter.sh/docs/manifest/secret/ and https://platform.smarter.sh/docs/json-schema/secret/
- Kind registration
- 
               
                Broker registration
               
               . The Broker class implements an enumeration of all resource
               Kinds.
- Json Schema docs view . Json schemas describe the Pydantic data model for the brokered resource. These are used for data-driven apps and services, such as the VS Code extension for Smarter manifests
- 
               
                Manifest docs view
               
               . All brokers implement an
               example_manifest()method which, intuitively, generates a valid example Smarter yaml manifest for theKindof resource.
Code samples
Controller Model
              In cases where there exist multiple variations of a manifest
              
               kind
              
              , we use a Controller pattern to route a Broker to the correct Python subclass.
             
- Abstract controller
- Example implementation for Plugin controller as an example.
 
          