Publish fetch packages
The Open Autonomy framework works with the concept of package: a collection of files that implement a specific component or functionality. Publishing a package is simply the process of storing the package into a registry (or in other words, a repository), either locally or remotely.
By publishing a package on a remote repository, its code is available for other developers to reuse it. Moreover, publishing a package on a public repository also facilitates minting the package in the Autonolas Protocol.
Note
It is not a strict requirement that a package be publicly available in a remote repository to register it in the on-chain protocol. The developer might want to keep the code private (and share it by different means), and still be able to register the package in the on-chain protocol.
What will you learn
In this guide, you will learn to:
- Manage the life cycle of packages with the framework.
- Publish and retrieve packages from local and remote registries.
How the local and remote registries work
Currently, the Open Autonomy framework supports two types of registries:
- local, and
- remote IPFS.
There are three main types of packages that can be stored in these registries:
- AI agents,
- agent blueprints, and
- components (which include connections, contracts, protocols and skills).
AI agents use agent blueprint packages, and agent blueprints use component packages. Packages are developed locally and stored in a registry to be retrieved and reused in a later stage. Every package has a public package ID that follows the naming convention <author_name>/<package_name>:<version>.
You can browse the list of default packages of the Open Autonomy framework available on the default remote IPFS registry.
Packages live in a different space when being used by the developer, and they are stored on and retrieved from a registry using different commands. The table below presents a summary.
| Package type | Command to store on a registry | Command to retrieve from a registry | 
|---|---|---|
| AI Agent | autonomy publish | autonomy fetch | 
| Agent Blueprint | autonomy publish | autonomy fetch | 
| Component | autonomy push | autonomy add | 
Workspace folder vs local registry
The figure below shows a typical setup, where you might identify some common traits with the Git methodology. Within the workspace folder, the arrows in the diagram point to the locations where the different operations can be executed in the local machine.
It is important not to confuse a local registry with a local workspace folder. The local registry is simply a repository to store finalized packages, mimicking the role of a remote registry on the local machine. A workspace folder is any folder where you can retrieve the contents of a registry (local or remote). The table below summarizes the main differences between these two locations.
| Workspace folder | Local registry | |
|---|---|---|
| Location | Any folder | Parent or child /packagesfolder of active folder (default). Alternatively, specified through--registry-pathtop-level flag. | 
| AI agent package location | ./<ai_agent_package> | ./<author_name>/agents/<ai_agent_package> | 
| Agent blueprint package location | ./<agent_blueprint_package> | ./<author_name>/agents/<agent_blueprint_package> | 
| Component package location | ./<agent_blueprint_package>/vendor/<author_name>/<component_type>/<component_package> | ./<author_name>/<component_type>/<component_package> | 
You can either:
- Develop a package in a workspace folder by retrieving a certain component from a registry, modify it and then store it in a local registry.
- Or develop a component directly in a local registry. This is the recommended approach. You can have as many local registries as you want, and you can always store finalized components on a remote registry.
Regardless of the methodology that you choose to develop your packages, it is important that they are developed with a clear separation of concerns, so that they can be reused in other projects.
How to tell the framework what registry to use
The push, add, publish and fetch commands use, by default, the registry specified when the framework was initiated (command autonomy init). See for example the set up guide, where we initialized the framework to use the default remote IPFS registry.
Additionally, the framework configuration can be overridden per command by using the flags --local or --remote in any of the commands  push, add, publish or fetch.
The framework assumes that the location of the local registry is the subfolder ./packages, or alternatively, the parent folder ../packages. Alternatively, you can specify the local registry folder with the top-level flag --registry-path, for example:
autonomy --registry-path=../my_registry publish --local
Push and add components
This section assumes that you have a newly created component, e.g., an FSM App skill, within an agent blueprint folder. It is out of the scope of this guide how to create agent blueprint components. You can review the guide to create an FSM App, or the Open AEA documentation. Your component should be located within an agent blueprint folder (i.e., a folder containing the file aea-config.yaml) in
<agent_blueprint_folder>/vendor/<author_name>/<component_type>/<package_name>.
<component_type> is one of connections, contracts, protocols or skills.
Push a component on a registry
- 
Ensure that the framework has been initialized with the desired registry (local or remote). 
- 
Within the agent blueprint folder, run the command autonomy push <component_type> ./vendor/<author_name>/<component_type>/<component_name>
- You should see a message
    Pushed component with: PublicId: <author_name>/<package_name>:<version> Package hash: <hash>
If you are using the default remote IPFS registry (/dns/registry.autonolas.tech/tcp/443/https), you can check that the AI agent has been successfully pushed by accessing the gateway https://gateway.autonolas.tech/ipfs/<hash> by substituting the appropriate <hash> value.
Add a component from a registry
- 
Ensure that the framework has been initialized with the desired registry (local or remote). 
- 
Within the agent blueprint folder, run the command autonomy add <component_type> <author_name>/<package_name>:<version>:<hash>
- You should see a message
    Adding item from hash: <hash> Successfully added <component_type> '<author_name>/<package_name>:<version>'.
Publish and fetch agent blueprints
This section assumes that you have a newly created agent blueprint in a workspace folder. It is out of the scope of this guide how to create agent blueprints. You can review the guide to define an agent blueprint, or the Open AEA documentation. Your agent blueprint should be located in an agent blueprint folder (i.e., a folder containing the file aea-config.yaml).
Publish an agent blueprint on a registry
- 
Ensure that the framework has been initialized with the desired registry (local or remote). 
- 
Within the agent blueprint folder, run the command autonomy publish
- 
You should see the message !!!! warning In case the agent blueprint contains components not yet pushed, it might be required that you run the commandSuccessfully published agent <package_name> to the Registry with. Public ID: <author_name>/<package_name>:<version> Package hash: <hash>autonomy publish --push-missing, which automatically will push any missing component package.
If you are using the default remote IPFS registry (/dns/registry.autonolas.tech/tcp/443/https), you can check that the agent blueprint has been successfully published by accessing the gateway https://gateway.autonolas.tech/ipfs/<hash> by substituting the appropriate <hash> value.
Fetch an agent blueprint from a registry
- 
Ensure that the framework has been initialized with the desired registry (local or remote). 
- 
Within the workspace folder, run the command autonomy fetch <author_name>/<package_name>:<version>:<hash>
- 
You should see a series of messages for each agent blueprint component being added, and a final messageAdding item from hash: <hash> Successfully added <component_type> '<author_name>/<package_name>:<version>'. (...)indicating that the agent blueprint has been successfully fetched.Agent <package_name> successfully fetched.
Publish and fetch AI agents
This section assumes that you have a newly created AI agent in a workspace folder. It is out of the scope of this guide how to create AI agents. You can review the guide to create an AI agent with an existing agent blueprint, or the guide to define an AI agent. Your AI agent should be located in an services folder (i.e., a folder containing the file service.yaml).
Publish an AI agent on a registry
- 
Ensure that the framework has been initialized with the desired registry (local or remote). 
- 
Within the AI agent folder, run the command autonomy publish
- 
You should see the message Published service package with PublicId: <author_name>/<package_name>:<version> Package hash: <hash>
If you are using the default remote IPFS registry (/dns/registry.autonolas.tech/tcp/443/https), you can check that the AI agent has been successfully published by accessing the gateway https://gateway.autonolas.tech/ipfs/<hash> by substituting the appropriate <hash> value.
Fetch an AI agent from a registry
- 
Ensure that the framework has been initialized with the desired registry (local or remote). 
- 
Within the workspace folder, run the command autonomy fetch <author_name>/<package_name>:<version>:<hash> --service
- 
You should see the message Downloaded service package <author_name>/<package_name>:<version> @ <workspace_path>