diff --git a/.gitbook/assets/workspace.png b/.gitbook/assets/workspace.png
new file mode 100644
index 0000000..93811bf
Binary files /dev/null and b/.gitbook/assets/workspace.png differ
diff --git a/README.md b/README.md
index 1419db4..2239d79 100644
--- a/README.md
+++ b/README.md
@@ -1,116 +1,43 @@
-# Giza Command Line Interface
-
-[![GitHub Workflow Status](https://github.com/gizatechxyz/giza-cli/actions/workflows/onpush.yml/badge.svg)](https://github.com/gizatechxyz/giza-cli/actions/workflows/onpush.yml)
-[![Project license](https://img.shields.io/github/license/gizatechxyz/orion.svg?style=flat-square)](LICENSE)
-[![Pull Requests welcome](https://img.shields.io/badge/PRs-welcome-ff69b4.svg?style=flat-square)](https://github.com/gizatechxyz/orion/issues?q=is%3Aissue+is%3Aopen)
-[![Join the community](https://dcbadge.vercel.app/api/server/FR3Cd88x6r?style=flat-square)](https://discord.gg/FR3Cd88x6r)
-
-[![All Contributors](https://img.shields.io/badge/all_contributors-3-orange.svg?style=flat-square)](#contributors-)
-
-
-```text
- _______ __ ________ ___ ______ __ __
- / _____|| | | / / \ / || | | |
-| | __ | | `---/ / / ^ \ | ,----'| | | |
-| | |_ | | | / / / /_\ \ | | | | | |
-| |__| | | | / /----./ _____ \ | `----.| `----.| |
- \______| |__| /________/__/ \__\ \______||_______||__|
-
-```
+---
+description: Giza CLI 0.9.0
+---
+
+# Giza CLI
Welcome to Giza CLI!
This CLI provides the utilities to interact with Giza using the terminal.
-**Disclaimer**: this is still in an experimental stage so the functionality is subject to change.
-
-- [Giza Command Line Interface](#giza-command-line-interface)
- - [π Installation](#-installation)
- - [Recommended installation with pipx](#recommended-installation-with-pipx)
- - [Install from PyPi](#install-from-pypi)
- - [Installing from source](#installing-from-source)
- - [π Documentation](#-documentation)
- - [π What's new](#-whats-new)
- - [π€ Join the community!](#-join-the-community)
- - [Contributors β¨](#contributors-)
- - [License](#license)
-
-## π Installation
-
-### Recommended installation with pipx
-
-[pipx](https://pypa.github.io/pipx/) allows to install the dependency in an isolated environment. With this we can make sure that it does not conflict with any of our installed dependencies.
-
-```bash
-pipx install giza-cli
-```
-
-### Install from PyPi
-
-For the latest release:
-
-```bash
-pip install giza-cli
-```
-
-### Installing from source
+## π€ What capabilities does the CLI offer?
-Clone the repository and install it with `pip`:
+The CLI will serve as the main entrypoint for Giza Platform for developers. It aims to provide a tool to ease the managing of resources that exists in Giza Platform.
-```bash
- git clone git@github.com:gizatechxyz/giza-cli.git
- cd giza-cli
- pip install .
-```
+For now it provides the following capabilities:
-Or install it directly from the repo:
+* User related utilities, like `create`, `login` (JWT Authentication) and `create_api_key` (API Key Authentication)
+* Model transpilation with `transpile` using multiple frameworks, like Cairo or EZKL
+* Model versioning
+* Proof generation for multiple frameworks, like Orion Cairo or EZKL
+* Deployment of models to the Giza Platform for verifiable inferences
+* Workspace management to help you with Giza Actions
+* Actions jumpstart with `new` command to help you get started with your actions
-```bash
- pip install git+ssh://git@github.com/gizatechxyz/giza-cli.git
-```
+In the future each new resource added to Giza will have its corresponding capability in the CLI.
-## π Documentation
-
-You can check our official docs [here](https://cli.gizatech.xyz).
-
-- **Examples** includes examples on how to use the CLI functionalities.
-
-- **Resources** brings the documentation of the different resources and actions that can be done with the CLI.
-
-- π§ **Reference** for the API reference and internals of the CLI.
-
-## π What's new
+## β¨ What's new?
For a detailed list of changes, please refer to the [CHANGELOG](CHANGELOG.md) file.
-## π€ Join the community!
+## π Join the community!
Join the community and help build a safer and transparent AI in our [Discord](https://discord.gg/Kt24CsMb5k)!
-## Contributors β¨
+## βοΈ Authors & contributors
-Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
-
-
-
-
-
-
-
-
-
-
-
-This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!
+For a full list of all authors and contributors, see [the contributors page](https://github.com/gizatechxyz/giza-cli/graphs/contributors).
## License
-[MIT](https://choosealicense.com/licenses/mit/)
+This project is licensed under the **MIT license**.
+
+See [LICENSE](LICENSE/) for more information.
diff --git a/SUMMARY.md b/SUMMARY.md
new file mode 100644
index 0000000..762630d
--- /dev/null
+++ b/SUMMARY.md
@@ -0,0 +1,56 @@
+# Table of contents
+
+## π Welcome
+
+* [Giza CLI](README.md)
+* [Installation](welcome/installation.md)
+* [Authentication](welcome/authentication.md)
+* [Frameworks](welcome/frameworks.md)
+* [Actions](welcome/actions.md)
+
+## π¦ Resources
+
+* [Users](resources/users.md)
+* [Models](resources/models.md)
+* [Versions](resources/versions.md)
+* [Workspaces](resources/workspaces.md)
+* [Deployments](resources/deployments.md)
+
+## π Frameworks
+
+* [Cairo](frameworks/cairo/README.md)
+ * [Transpile](frameworks/cairo/transpile.md)
+ * [Prove](frameworks/cairo/prove.md)
+ * [Verify](frameworks/cairo/verify.md)
+* [EZKL](frameworks/ezkl/README.md)
+ * [Transpile](frameworks/ezkl/transpile.md)
+ * [Prove](frameworks/ezkl/prove.md)
+ * [Verify](frameworks/ezkl/verify.md)
+
+## π Examples
+
+* [Basic Cairo CLI Example](examples/basic.md)
+* [Reset Your Password](examples/reset\_password.md)
+
+## 𧱠Reference
+
+* [API Overview](reference/api/README.md)
+ * [callbacks](reference/api/callbacks.md)
+ * [cli](reference/api/cli.md)
+ * [client](reference/api/client.md)
+ * [commands](reference/api/commands.md)
+ * [commands.deploy](reference/api/commands.deploy.md)
+ * [commands.models](reference/api/commands.models.md)
+ * [commands.prove](reference/api/commands.prove.md)
+ * [commands.reset\_password](reference/api/commands.reset\_password.md)
+ * [commands.transpile](reference/api/commands.transpile.md)
+ * [commands.users](reference/api/commands.users.md)
+ * [commands.version](reference/api/commands.version.md)
+ * [commands.versions](reference/api/commands.versions.md)
+ * [commands.workspaces](reference/api/commands.workspaces.md)
+ * [exceptions](reference/api/exceptions.md)
+ * [options](reference/api/options.md)
+ * [utils.decorators](reference/api/utils.decorators.md)
+ * [utils.echo](reference/api/utils.echo.md)
+ * [utils.enum](reference/api/utils.enum.md)
+ * [utils](reference/api/utils.md)
diff --git a/examples/basic.md b/examples/basic.md
new file mode 100644
index 0000000..f83967d
--- /dev/null
+++ b/examples/basic.md
@@ -0,0 +1,115 @@
+# Basic Cairo CLI Example
+
+For this example we will create a user, retrieve information from it and transpile a model.
+
+## Create User
+
+This is the first step! We create the user and then we need to verify the account by checking the email.
+
+```console
+> giza users create
+
+Enter your username π: my-username
+Enter your password π₯· : (this is a secret)
+Enter your email π§: gonzalo@gizatech.xyz
+[giza][2023-06-23 12:29:40.543] Creating user in Giza β
+[giza][2023-06-23 12:29:41.417] User created β
. Check for a verification email π§
+```
+
+Then we need to verify the email. We just need to click on the button and we'll be redirected to the verification endpoint.
+
+## Login
+
+If it is not verified login will be disabled!
+
+```console
+> giza users login
+
+Enter your username π: my-username
+Enter your password π₯· :
+[giza][2023-06-23 12:32:17.917] Log into Giza
+[giza][2023-06-23 12:32:18.716] βοΈCould not authorize the userβοΈ
+[giza][2023-06-23 12:32:18.718] βοΈStatus code -> 400βοΈ
+[giza][2023-06-23 12:32:18.719] βοΈError message -> {'detail': 'Inactive user'}βοΈ
+```
+
+But once we verify the account we will be able to authenticate with Giza.
+
+```console
+> giza users login
+
+Enter your username π: my-username
+Enter your password π₯· :
+[giza][2023-06-23 12:34:33.576] Log into Giza
+[giza][2023-06-23 12:34:34.400] Successfully logged into Giza β
+```
+
+## Retrieve user information
+
+Now that we are authenticated we can connect with Giza!
+
+```console
+> giza users me
+
+[giza][2023-06-23 12:35:33.287] Retrieving information about me!
+{
+ "username": "my-username",
+ "email": "gonzalo@gizatech.xyz",
+ "is_active": true
+}
+```
+
+## Create API Key
+
+You can also create an API key for the current user. This API key will be stored and will be used to authenticate the user in the future.
+
+```console
+> giza users create-api-key
+[giza][2024-01-17 15:27:27.936] Creating API Key β
+[giza][2024-01-17 15:27:53.605] API Key written to: /Users/gizabrain/.giza/.api_key.json
+[giza][2024-01-17 15:27:53.606] Successfully created API Key. It will be used for future requests β
+```
+
+**NOTE: The usage of API key is less secure than JWT, so use it with caution.**
+
+## Transpiling a Model
+
+Now that we have our `onnx` model, it's time to transpile it into a format that's compatible with `giza`. Transpilation is a process where we convert the model from one format to another without changing its underlying functionality. In this case, we're converting our `onnx` model into a `cairo` model. This is a crucial step as it allows us to leverage the power of `giza` and its ecosystem.
+
+But don't worry, `giza` makes this process a breeze with a simple command! Let's dive into it.
+
+```console
+> giza transpile awesome_model.onnx --output-path cairo_model
+
+[giza][2023-09-13 12:56:43.725] No model id provided, checking if model exists β
+[giza][2023-09-13 12:56:43.726] Model name is: awesome_model
+[giza][2023-09-13 12:56:43.978] Model Created with id -> 25! β
+[giza][2023-09-13 12:56:44.568] Sending model for transpilation β
+[giza][2023-09-13 12:56:55.577] Transpilation recieved! β
+[giza][2023-09-13 12:56:55.583] Transpilation saved at: cairo_model
+```
+
+As you can see from the console output, if the model does not previously exist, `giza` will automatically create one for you. It assigns a unique id to the new model, in this case, the id is 25. This is indicated by the line `[giza][2023-09-13 12:56:43.978] Model Created with id -> 25! β
`.
+
+After the model is created, `giza` will create a new version for it and send it for transpilation. This is indicated by the line `[giza][2023-09-13 12:56:44.568] Sending model for transpilation β
`. The transpiled model is then saved at the specified output path.
+
+This feature of `giza` makes it easy to manage and version your models. You don't have to worry about manually creating a new model or version, `giza` handles it for you.
+
+Additionally, `giza` provides an option to specify the model id while transpiling. If you already have a model and want to create a new version for it, you can use the `--model-id` option followed by the id of the model. This will create a new version for the existing model instead of creating a new model. Here's how you can do it:
+
+Now let's check the result:
+
+```console
+> tree cairo_model
+
+cairo_model
+βββ inference
+β βββ Scarb.toml
+β βββ src
+β βββ lib.cairo
+βββ initializers
+ βββ node_l1
+ β βββ Scarb.toml
+ β βββ src
+ β βββ lib.cairo
+```
diff --git a/examples/reset_password.md b/examples/reset_password.md
new file mode 100644
index 0000000..e4c127c
--- /dev/null
+++ b/examples/reset_password.md
@@ -0,0 +1,35 @@
+# Reset Password Example
+
+In case you forget your password, Giza provides a secure and straightforward way to reset it. The process involves two main steps:
+
+## Request a Reset Token
+
+The first step is to request a reset token. This token will be sent to your registered email address. You can request a reset token by running the following command:
+
+```console
+> giza request-reset-password-token --email your_email@example.com
+
+[giza][2023-08-30 12:53:18.423] Password recovery email sent
+[giza][2023-08-30 12:53:18.428] Please check your email for a password reset token π¬
+```
+
+The reset token is a unique string of characters that is used to verify your identity and allow you to change your password. It is only valid for a short period of time for security reasons. If you do not use it within this time, you will need to request a new one.
+
+## Reset Password
+
+Once you have received your reset token, you can use it to reset your password. Run the following command, replacing `your_reset_token` with the token you received in your email:
+
+```console
+> giza reset-password --token your_reset_token
+
+Please enter your new password π: # Your new password goes here
+Please confirm your new password π:
+[giza][2023-08-30 12:55:32.128] Password updated successfully
+[giza][2023-08-30 12:55:32.132] Password reset was successful π
+```
+
+With the above steps, you have successfully reset your password. Remember, it's important to keep your password secure and not share it with anyone. If you suspect that your password has been compromised, repeat the steps above to reset it.
+
+In case you encounter any issues or need further assistance, feel free to reach out to our support team. We're here to help!
+
+Stay secure! π
diff --git a/frameworks/cairo/README.md b/frameworks/cairo/README.md
new file mode 100644
index 0000000..ab5bbd7
--- /dev/null
+++ b/frameworks/cairo/README.md
@@ -0,0 +1,12 @@
+# Cairo
+
+Cairo is a programming language specifically designed for creating verifiable and efficient smart contracts and cryptographic proofs. Its core strength lies in its ability to create succinct and secure programs while ensuring formal verification of their correctness.
+
+In the realm of Giza, Cairo serves as the backbone for generating provable machine learning models. Leveraging Cairo as the backend provides a reliable infrastructure to transpile, prove and verify these models within the Giza platform.
+
+## Cairo Framework Features
+
+1. Transpilation Process: Dive into Giza's streamlined process to seamlessly convert ONNX machine learning models into Cairo code. This transformation ensures optimal compatibility and functionality within the Cairo ecosystem, leveraging the power of [β¨Orionβ¨](https://github.com/gizatechxyz/orion). More on this in the [transpile documentation for cairo](transpile.md).
+2. Creating Verifiable Proofs: Use the transpile model to generate the `casm.json` file to create a proof and validate the correctness and reliability of your transformed models. Discover how Giza harnesses Cairo's robust features to create evidence ensuring the credibility of your machine learning outputs. More on this in the [prove documentation for cairo](prove.md).
+
+[Cairo official documentation](https://docs.cairo-lang.org/)
diff --git a/frameworks/cairo/prove.md b/frameworks/cairo/prove.md
new file mode 100644
index 0000000..28fbad1
--- /dev/null
+++ b/frameworks/cairo/prove.md
@@ -0,0 +1,59 @@
+# Prove
+
+Giza provides two methods for proving Orion Cairo programs: through the CLI or directly after running inference on the Giza Platform. Below are detailed instructions for both methods
+
+## Option 1: Prove a Model After Running Inference
+
+**Deploying Your Model**
+
+After deploying your model on the Giza Platform, you will receive a URL for your deployed model. Refer to the [Deployments section](../../resources/deployments.md) for more details on deploying models.
+
+**Running Inference**
+
+To run inference, use the `/cairo_run` endpoint of your deployed model's URL. For example:
+
+```
+https://deployment-gizabrain-38-1-53427f44-dagsgas-ew.a.run.app/cairo_run
+```
+
+This action will execute the inference, generate Trace and Memory files on the platform, and initiate a proving job. The inference process will return the output result along with a request ID.
+
+**Checking Proof Status**
+
+To check the status of your proof, use the following command:
+
+```
+giza deployments get-proof --model-id --version-id --deployment-id --proof-id
+```
+
+**Downloading Your Proof**
+
+Once the proof is ready, you can download it using:
+
+```
+giza deployments download-proof --model-id --version-id --deployment-id --proof-id --output-path
+```
+
+{% hint style="info" %}
+You can find an extensive example in [Giza Action tutorial](https://actions.gizatech.xyz/tutorials/build-a-verifiable-neural-network-with-giza-actions#run-and-prove)
+{% endhint %}
+
+## Option 2: Proving a Model Directly from the CLI
+
+Alternatively, you can prove a model directly using the CLI without deploying the model for inference. This method requires providing Trace and Memory files, which can only be obtained by running [CairoVM](https://github.com/lambdaclass/cairo-vm) in proof mode.
+
+**Running the Prove Command**
+
+Execute the following command to prove your model:
+
+```
+giza prove --trace --memory --output-path
+```
+
+{% hint style="info" %}
+This option is less preferred due to the necessity of dealing with CairoVM.
+{% endhint %}
+
+{% hint style="danger" %}
+If you opt for this method, ensure you use the following commit of CairoVM: `1a78237`.
+{% endhint %}
diff --git a/frameworks/cairo/transpile.md b/frameworks/cairo/transpile.md
new file mode 100644
index 0000000..e322b9d
--- /dev/null
+++ b/frameworks/cairo/transpile.md
@@ -0,0 +1,156 @@
+# Transpile
+
+Transpilation is a crucial process in the deployment of Verifiable Machine Learning models. It involves the transformation of an ONNX model into a Cairo model. These models can generate proofs that can be verified, ensuring the integrity and reliability of the model's predictions.
+
+The transpilation of an ONNX model to a Cairo model is powered by [β¨Orionβ¨](https://github.com/gizatechxyz/orion)
+
+The transpilation process begins by reading the model from the specified path. The model is then sent for transpilation. By default, the output of this process is saved in the `cairo_model/` folder. However, you can specify a different output path using the `--output-path` option.
+
+```console
+> giza transpile awesome_model.onnx --output-path my_awesome_model
+[giza][2023-09-13 12:56:43.725] No model id provided, checking if model exists β
+[giza][2023-09-13 12:56:43.726] Model name is: awesome_model
+[giza][2023-09-13 12:56:43.978] Model Created with id -> 1! β
+[giza][2023-09-13 12:56:44.568] Sending model for transpilation β
+[giza][2023-09-13 12:56:55.577] Transpilation recieved! β
+[giza][2023-09-13 12:56:55.583] Transpilation saved at: cairo_model
+```
+
+The result of the transpilation process is saved at the provided path, in this case, `my_awesome_model/`.
+
+```console
+> tree my_awesome_model/
+my_awesome_model
+βββ inference
+β βββ Scarb.toml
+β βββ src
+β βββ lib.cairo
+βββ initializers
+ βββ node_l1
+ β βββ Scarb.toml
+ β βββ src
+ β βββ lib.cairo
+```
+
+## Supported Operators
+
+| Operator | Implemented |
+| :------: | :------------------: |
+| Abs | :white\_check\_mark: |
+| Acos | :white\_check\_mark: |
+| Acosh | :white\_check\_mark: |
+| Add | :white\_check\_mark: |
+| And | :white\_check\_mark: |
+| Div | :white\_check\_mark: |
+| Mul | :white\_check\_mark: |
+| Sub | :white\_check\_mark: |
+| Argmax | :white\_check\_mark: |
+| Argmin | :white\_check\_mark: |
+| Asin | :white\_check\_mark: |
+| Asinh | :white\_check\_mark: |
+| Atan | :white\_check\_mark: |
+| Relu | :white\_check\_mark: |
+| Constant | :white\_check\_mark: |
+| MatMul | :white\_check\_mark: |
+| Gemm | :white\_check\_mark: |
+
+## How do we transpile a model?
+
+There are three main methods for transpiling a model:
+
+### **Method 1: Using the `giza transpile` command**
+
+```
+ giza transpile awesome_model.onnx --output-path my_awesome_model
+```
+
+This is the simplest method and is recommended for most users.\
+When you run this command, Giza handles everything for you:
+
+* It first checks if a model with the specified name already exists. If not, it creates a new model and then transpiles it.
+* The output of this process is saved in the `cairo_model/` folder by default, but you can specify a different output path using the `--output-path` option.
+
+This is the strategy that we followed in the example before.
+
+### **Method 2: Manually creating a model and then transpiling it**
+
+This method gives you more control over the process.
+
+1. First, you create a model manually using the `giza models create` command.
+2. After the model is created, you can transpile it using the `giza transpile --model-id ...`
+
+This method is useful when you want to specify particular options or parameters during the model creation and transpilation process.
+
+```console
+> giza models create --name awesome_model --description "A Model for testing different models"
+[giza][2023-09-13 14:04:59.532] Creating model β
+{
+ "id": 2,
+ "name": "awesome_model",
+ "description": "A Model for testing different models"
+}
+```
+
+```console
+> giza transpile --model-id 2 awesome_model.onnx --output-path new_awesome_model
+[giza][2023-09-13 14:08:38.022] Model found with id -> 2! β
+[giza][2023-09-13 14:08:38.712] Sending model for transpilation β
+[giza][2023-09-13 14:08:49.879] Transpilation recieved! β
+[giza][2023-09-13 14:08:49.885] Transpilation saved at: new_awesome_model
+```
+
+### **Method 3: Using a previous model**
+
+If you have a previously created model, you can transpile it by indicating the model-id in the `giza transpile --model-id ...` or `giza versions transpile --model-id` command.
+
+* This method is useful when you want to create a new version of an existing model.
+* The output of the transpilation process is saved in the same location as the original model.
+
+```console
+# Using the previous model (id: 2) we can transpile a new model, which will create version 2 of the model.
+giza transpile --model-id 29 awesome_model.onnx --output-path new_awesome_model
+[giza][2023-09-13 14:11:30.015] Model found with id -> 2! β
+[giza][2023-09-13 14:11:30.541] Sending model for transpilation β
+[giza][2023-09-13 14:11:41.601] Transpilation recieved! β
+[giza][2023-09-13 14:11:41.609] Transpilation saved at: new_awesome_model
+```
+
+## What is happening with the models and versions?
+
+In Giza, a model is essentially a container for versions. Each version represents a transpilation of a machine learning model at a specific point in time. This allows you to keep track of different versions of your model as it evolves and improves over time.
+
+To check the current models and versions that have been created, you can use the following steps:
+
+1. Use the `giza models list` command to list all the models that have been created.
+2. For each model, you can use the `giza versions list --model-id ...` command to list all the versions of that model.
+
+Remember, each version represents a specific transpilation of the model. So, if you have made changes to your machine learning model and transpiled it again, it will create a new version.
+
+This system of models and versions allows you to manage and keep track of the evolution of your machine learning models over time.
+
+For example, let's say you have created a model called `awesome_model` and transpiled it twice. This will create two versions of the model, version 1 and version 2. You can check the status of these versions using the `giza versions list --model-id ...` command.
+
+```console
+giza versions list --model-id 29
+[giza][2023-09-13 14:17:08.006] Listing versions for the model β
+[
+ {
+ "version": 1,
+ "size": 52735,
+ "status": "COMPLETED",
+ "message": "Transpilation Successful!",
+ "description": "Initial version",
+ "created_date": "2023-09-13T12:08:38.177605",
+ "last_update": "2023-09-13T12:08:43.986137"
+ },
+ {
+ "version": 2,
+ "size": 52735,
+ "status": "COMPLETED",
+ "message": "Transpilation Successful!",
+ "description": "Initial version",
+ "created_date": "2023-09-13T12:11:30.165440",
+ "last_update": "2023-09-13T12:11:31.625834"
+ }
+]
+```
diff --git a/frameworks/cairo/verify.md b/frameworks/cairo/verify.md
new file mode 100644
index 0000000..347bc51
--- /dev/null
+++ b/frameworks/cairo/verify.md
@@ -0,0 +1,37 @@
+# Verify
+
+After successfully creating a proof for your Orion Cairo model, the next step is to verify its validity. Giza offers two methods for proof verification: using the `proof-id` or directly specifying the proof file path.
+
+## Option 1: Verify Using Proof-ID
+
+To verify a proof by providing the `proof-id`, use the following command:
+
+```
+giza verify --model-id 1 --version-id 1 --proof-id 1 --size S
+```
+
+Upon successful submission, you will see a confirmation message indicating that the verification job has been created, along with its name and ID. Once the verification process is complete, a success message will confirm the validity of the proof:
+
+```
+[giza][2023-12-04 19:43:37.686] Verification job created with name 'verify-cairo-20231204-32f44715' and id -> 1 β
+[giza][2023-12-04 19:45:18.683] Verification job is successful β
+```
+
+## Option 2: Verify by Providing the Proof Path
+
+Alternatively, you can verify a proof by specifying the path to the proof file directly:
+
+```
+giza verify --proof /path/to/the/proof --size S
+```
+
+Similar to the first option, you will receive confirmation of the verification job creation followed by a success message upon completion:
+
+```
+[giza][2023-12-04 19:43:37.686] Verification job created with name 'verify-cairo-20231204-32f44715' and id -> 1 β
+[giza][2023-12-04 19:45:18.683] Verification job is successful β
+```
+
+## Verification Outcome
+
+If the verification job completes successfully, it indicates that the proof is valid. If there are any issues during the verification process, Giza will provide an error message detailing the problem.
diff --git a/frameworks/ezkl/README.md b/frameworks/ezkl/README.md
new file mode 100644
index 0000000..9410b42
--- /dev/null
+++ b/frameworks/ezkl/README.md
@@ -0,0 +1,21 @@
+# EZKL
+
+`ezkl` is a library and command-line tool for doing inference for deep learning models and other computational graphs in a zk-snark (ZKML) using `halo2` as a backend. [Official documentation](https://docs.ezkl.xyz/).
+
+`ezkl` represents a pioneering framework in zero-knowledge machine learning (ZKML) trusted by Giza. It is designed with ease of use in mind and efficiency to make easy zero-knowledge inference.
+
+## EZKL Framework Features
+
+1. Transpilation Process
+
+The transpilation process refers to performing the `setup` for the model where an ONNX model and a set of input data are used to generate the `circuit settings`, `proving key` and `verification key` files that are used to perform the inference. In Giza we aim to provide an easy way to perform this step providing compute resources and a simple command line interface. More on this in the [transpile documentation for ezkl](transpile.md).
+
+1. Creating Verifiable Proofs
+
+Create a proof using the generated outputs of the setup process, we handle this step for you by loading the necessary files and performing the proof generation for you. More on this in the [prove documentation for ezkl](prove.md).
+
+1. Verifying Proofs
+
+Verify the proof generated by an `ezkl` version, here we manage the execution of the verification process and the compute as well for you. More on this in the [verify documentation for ezkl](verify.md)
+
+For detailed information check the [ezkl repository](https://github.com/zkonduit/ezkl)
diff --git a/frameworks/ezkl/prove.md b/frameworks/ezkl/prove.md
new file mode 100644
index 0000000..1fc95fc
--- /dev/null
+++ b/frameworks/ezkl/prove.md
@@ -0,0 +1,22 @@
+# Prove
+
+Time to create a Proof of our EZKL version!
+
+Once we have the input data that we want to use we can use the `prove` command to create our proof!
+
+This command will create a proving job at Giza and once the job is completed we will download the created proof.
+
+```console
+> giza prove --framework EZKL --model-id 1 --version-id 1 --size M input.json
+[giza][2023-12-04 19:41:55.236] Proving job created with name 'proof-ezkl-20231204-33e59441' and id -> 1 β
+[giza][2023-12-04 19:43:36.337] Proving job is successful β
[giza][2023-12-04 19:43:36.447] Proof created with id -> 1 β
+[giza][2023-12-04 19:43:36.448] Proof metrics:
+{
+ "proving_time": 12.2238187789917
+}
+[giza][2023-12-04 19:43:37.046] Proof saved at: zk.proof
+```
+
+As we can see the job takes some time, and because of this we are actively waiting for the job to be completed, once it's done all information and the proof are retrieved.
+
+Now we can see that we have a proof successfully created! Now if we want we could verify it! Let's check the [verify](../../docs/frameworks/frameworks/ezkl/verify.md) documentation to see how to do it!
diff --git a/frameworks/ezkl/transpile.md b/frameworks/ezkl/transpile.md
new file mode 100644
index 0000000..5fa1f01
--- /dev/null
+++ b/frameworks/ezkl/transpile.md
@@ -0,0 +1,113 @@
+# Transpile
+
+Transpilation is a crucial process in the deployment of Verifiable Machine Learning models and its powered by is powered by [ezkl](https://github.com/zkonduit/ezkl). It involves the usage of an ONNX model and input data to perform the `setup`. With this `setup` we can generate proofs that can be verified, ensuring the integrity and reliability of the model's predictions.
+
+The transpilation process begins by reading the model and input data from the specified path. The model and data are then sent for transpilation. By default, the output of this process is managed by Giza for later use.
+
+```console
+> giza transpile --framework EZKL --input-data input.json awesome_model.onnx
+[giza][2023-12-04 19:40:11.274] No model id provided, checking if model exists β
+[giza][2023-12-04 19:40:11.275] Model name is: awesome_model
+[giza][2023-12-04 19:40:11.424] Model Created with id -> 1! β
+[giza][2023-12-04 19:40:11.944] Sending model for setup β
+[giza][2023-12-04 19:40:13.046] Setup job created with name 'ezkl-job-20231204-32a4a1c1' and id -> 1 β
+[giza][2023-12-04 19:41:54.277] Setup job is successful β
+```
+
+The result of the transpilation process is the following:
+
+* Circuit settings
+* Proving key
+* Verification key
+
+## How do we transpile a model
+
+There are three main methods for transpiling a model:
+
+### **Method 1: Using the `giza transpile --framework EZKL` command**
+
+- This is the simplest method and is recommended for most users.
+- When you run this command, Giza handles everything for you.
+- It first checks if a model with the specified name already exists. If not, it creates a new model and then transpiles it.
+- The output of this process is managed by Giza.
+- This is the strategy that we followed in the example before.
+
+### **Method 2: Manually creating a model and then transpiling it**
+
+- This method gives you more control over the process.
+- First, you create a model manually using the `giza models create` command.
+- After the model is created, you can transpile it using the `giza transpile --framework EZKL --model-id ...` or `giza versions transpile --framework EZKL --model-id` command.
+- This method is useful when you want to specify particular options or parameters during the model creation and transpilation process.
+
+```console
+> giza models create --name awesome_model --description "A Model for testing different models"
+[giza][2023-09-13 14:04:59.532] Creating model β
+{
+ "id": 2,
+ "name": "awesome_model",
+ "description": "A Model for testing different models"
+}
+```
+
+```console
+> giza transpile --framework EZKL --model-id 2 --input-data input.json awesome_model.onnx
+[giza][2023-12-04 19:40:10.646] Model found with id -> 2! β
+[giza][2023-12-04 19:40:12.176] Sending model for Setup β
+[giza][2023-12-04 19:40:13.046] Setup job created with name 'ezkl-job-20231204-32a4a1c1' and id -> 13 β
+[giza][2023-12-04 19:41:54.277] Setup job is successful β
+```
+
+### **Method 3: Using a previous model**
+
+- If you have a previously created model, you can transpile it by indicating the model-id in the `giza transpile --framework EZKL --model-id ...` or `giza versions transpile --framework EZKL --model-id` command.
+- This method is useful when you want to create a new version of an existing model.
+- The output of the transpilation process is saved in the same location as the original model.
+
+```console
+# Using the previous model (id: 2) we can transpile a new model, which will create version 2 of the model.
+> giza transpile --framework EZKL --model-id 2 --input-data input.json awesome_model.onnx
+[giza][2023-12-04 19:40:10.646] Model found with id -> 2! β
+[giza][2023-12-04 19:40:12.176] Sending model for Setup β
+[giza][2023-12-04 19:40:13.046] Setup job created with name 'ezkl-job-20231204-123fadc1' and id -> 14 β
+[giza][2023-12-04 19:41:54.277] Setup job is successful β
+```
+
+## What is happening with the models and versions
+
+In Giza, a model is essentially a container for versions. Each version represents a transpilation of a machine learning model at a specific point in time. This allows you to keep track of different versions of your model as it evolves and improves over time.
+
+To check the current models and versions that have been created, you can use the following steps:
+
+1. Use the `giza models list` command to list all the models that have been created.
+2. For each model, you can use the `giza versions list --model-id ...` command to list all the versions of that model.
+
+Remember, each version represents a specific transpilation of the model. So, if you have made changes to your machine learning model and transpiled it again, it will create a new version.
+
+This system of models and versions allows you to manage and keep track of the evolution of your machine learning models over time.
+
+For example, let's say you have created a model called `awesome_model` and transpiled it twice. This will create two versions of the model, version 1 and version 2. You can check the status of these versions using the `giza versions list --model-id ...` command.
+
+```console
+giza versions list --model-id 29
+[giza][2023-12-04 14:17:08.006] Listing versions for the model β
+[
+ {
+ "version": 1,
+ "size": 52735,
+ "status": "COMPLETED",
+ "message": "Setup Successful!",
+ "description": "Initial version",
+ "created_date": "2023-09-13T12:08:38.177605",
+ "last_update": "2023-09-13T12:08:43.986137"
+ },
+ {
+ "version": 2,
+ "size": 52735,
+ "status": "Setup",
+ "message": "Transpilation Successful!",
+ "description": "Initial version",
+ "created_date": "2023-12-04T12:11:30.165440",
+ "last_update": "2023-12-04T12:11:31.625834"
+ }
+]
+```
diff --git a/frameworks/ezkl/verify.md b/frameworks/ezkl/verify.md
new file mode 100644
index 0000000..f2beae2
--- /dev/null
+++ b/frameworks/ezkl/verify.md
@@ -0,0 +1,15 @@
+# Verify
+
+We have created a Proof of our EZKL version, now it's time to verify it!
+
+As we already have the proof we can use the `verify` command to verify it, using the `--proof-id` option we can specify the proof that we want to verify.
+
+As we are using a managed `version` we need to specify `--model-id` and `--version-id` to indicate which version we want to verify, so we can retrieve the generated files in the `setup` process (`giza transpile`).
+
+```console
+> giza verify -f EZKL --model-id 1 --version-id 1 --proof-id 1 --size S
+[giza][2023-12-04 19:43:37.686] Verification job created with name 'verify-ezkl-20231204-32f44715' and id -> 1 β
+[giza][2023-12-04 19:45:18.683] Verification job is successful β
+```
+
+If the job is successful that means that the proof is valid! Otherwise, we will get an error message.
diff --git a/reference/api/README.md b/reference/api/README.md
new file mode 100644
index 0000000..0ca7959
--- /dev/null
+++ b/reference/api/README.md
@@ -0,0 +1,91 @@
+# API Overview
+
+## Modules
+
+* [`callbacks`](callbacks.md#module-callbacks)
+* [`cli`](cli.md#module-cli)
+* [`client`](client.md#module-client)
+* [`commands`](commands.md#module-commands)
+* [`commands.actions`](../../docs/reference/api/commands.actions.md#module-commandsactions)
+* [`commands.deployments`](../../docs/reference/api/commands.deployments.md#module-commandsdeployments)
+* [`commands.models`](commands.models.md#module-commandsmodels)
+* [`commands.prove`](commands.prove.md#module-commandsprove)
+* [`commands.reset_password`](commands.reset\_password.md#module-commandsreset\_password)
+* [`commands.users`](commands.users.md#module-commandsusers)
+* [`commands.verify`](../../docs/reference/api/commands.verify.md#module-commandsverify)
+* [`commands.version`](commands.version.md#module-commandsversion)
+* [`commands.versions`](commands.versions.md#module-commandsversions)
+* [`commands.workspaces`](commands.workspaces.md#module-commandsworkspaces)
+* [`exceptions`](exceptions.md#module-exceptions)
+* [`frameworks`](../../docs/reference/api/frameworks.md#module-frameworks)
+* [`frameworks.cairo`](../../docs/reference/api/frameworks.cairo.md#module-frameworkscairo)
+* [`frameworks.ezkl`](../../docs/reference/api/frameworks.ezkl.md#module-frameworksezkl)
+* [`options`](options.md#module-options)
+* [`utils`](utils.md#module-utils)
+* [`utils.decorators`](utils.decorators.md#module-utilsdecorators)
+* [`utils.echo`](utils.echo.md#module-utilsecho)
+* [`utils.enums`](../../docs/reference/api/utils.enums.md#module-utilsenums)
+* [`utils.misc`](../../docs/reference/api/utils.misc.md#module-utilsmisc)
+
+## Classes
+
+* [`client.ApiClient`](client.md#class-apiclient): Implementation of the API client to interact with core-services
+* [`client.DeploymentsClient`](client.md#class-deploymentsclient): Client to interact with `deployments` endpoint.
+* [`client.JobsClient`](client.md#class-jobsclient): Client to interact with `jobs` endpoint.
+* [`client.ModelsClient`](client.md#class-modelsclient): Client to interact with `models` endpoint.
+* [`client.ProofsClient`](client.md#class-proofsclient): Client to interact with `proofs` endpoint.
+* [`client.TranspileClient`](client.md#class-transpileclient): Client to interact with `users` endpoint.
+* [`client.UsersClient`](client.md#class-usersclient): Client to interact with `users` endpoint.
+* [`client.VersionJobsClient`](client.md#class-versionjobsclient): Client to interact with `jobs` endpoint.
+* [`client.VersionsClient`](client.md#class-versionsclient): Client to interact with `versions` endpoint.
+* [`client.WorkspaceClient`](client.md#class-workspaceclient): Client to interact with `workspaces` endpoint.
+* [`exceptions.PasswordError`](exceptions.md#class-passworderror)
+* [`echo.Echo`](utils.echo.md#class-echo): Helper class to use when printing output of the CLI.
+* [`enums.Framework`](../../docs/reference/api/utils.enums.md#class-framework)
+* [`enums.JobKind`](../../docs/reference/api/utils.enums.md#class-jobkind)
+* [`enums.JobSize`](../../docs/reference/api/utils.enums.md#class-jobsize)
+* [`enums.JobStatus`](../../docs/reference/api/utils.enums.md#class-jobstatus)
+* [`enums.ServiceSize`](../../docs/reference/api/utils.enums.md#class-servicesize)
+* [`enums.VersionStatus`](../../docs/reference/api/utils.enums.md#class-versionstatus)
+
+## Functions
+
+* [`callbacks.debug_callback`](callbacks.md#function-debug\_callback): If a call adds the `--debug` flag debugging mode is activated for external requests and API Clients.
+* [`callbacks.version_callback`](callbacks.md#function-version\_callback): Prints the current version when `--version` flag is added to a call.
+* [`cli.entrypoint`](cli.md#function-entrypoint)
+* [`actions.new`](../../docs/reference/api/commands.actions.md#function-new): This command will create a new action by generating a Python project.
+* [`deployments.deploy`](../../docs/reference/api/commands.deployments.md#function-deploy)
+* [`deployments.get`](../../docs/reference/api/commands.deployments.md#function-get)
+* [`deployments.list`](../../docs/reference/api/commands.deployments.md#function-list)
+* [`models.create`](commands.models.md#function-create): Command to create a model. Asks for the new model's information and validates the input,
+* [`models.get`](commands.models.md#function-get): Command to create a user. Asks for the new users information and validates the input,
+* [`models.list`](commands.models.md#function-list): Command to list all models.
+* [`prove.prove`](commands.prove.md#function-prove)
+* [`reset_password.handle_http_error`](commands.reset\_password.md#function-handle\_http\_error): Handle an HTTP error.
+* [`reset_password.prompt_for_input`](commands.reset\_password.md#function-prompt\_for\_input): Prompt the user for input.
+* [`reset_password.request_reset_password_token`](commands.reset\_password.md#function-request\_reset\_password\_token): Request a password reset token for a given email.
+* [`reset_password.reset_password`](commands.reset\_password.md#function-reset\_password): Reset the password for a user using a reset token.
+* [`users.create`](commands.users.md#function-create): Command to create a user. Asks for the new users information and validates the input,
+* [`users.create_api_key`](commands.users.md#function-create\_api\_key): Create an API key for your user. You need to be logged in to create an API key.
+* [`users.login`](commands.users.md#function-login): Logs the current user into Giza. Under the hood this will retrieve the token for the next requests.
+* [`users.me`](commands.users.md#function-me): Retrieve information about the current user and print it as json to stdout.
+* [`users.resend_email`](commands.users.md#function-resend\_email): Command to resend verification email. Asks for the user's email and sends the request to the API
+* [`verify.verify`](../../docs/reference/api/commands.verify.md#function-verify)
+* [`version.check_version`](commands.version.md#function-check\_version): Check if there is a new version available of the cli in pypi to suggest upgrade
+* [`versions.download`](commands.versions.md#function-download): Retrieve information about the current user and print it as json to stdout.
+* [`versions.download_original`](commands.versions.md#function-download\_original): Retrieve information about the current user and print it as json to stdout.
+* [`versions.get`](commands.versions.md#function-get)
+* [`versions.list`](commands.versions.md#function-list)
+* [`versions.transpile`](commands.versions.md#function-transpile)
+* [`versions.update`](commands.versions.md#function-update)
+* [`workspaces.create`](commands.workspaces.md#function-create): Command to create a Giza Workspace.
+* [`workspaces.delete`](commands.workspaces.md#function-delete)
+* [`workspaces.get`](commands.workspaces.md#function-get)
+* [`cairo.deploy`](../../docs/reference/api/frameworks.cairo.md#function-deploy): Command to deploy a specific version of a model. This will create a deployment for the specified version and check the status, once it finishes if COMPLETED the deployment is ready to be used.
+* [`cairo.prove`](../../docs/reference/api/frameworks.cairo.md#function-prove): Command to prove as spceific cairo program, previously converted to CASM.
+* [`cairo.transpile`](../../docs/reference/api/frameworks.cairo.md#function-transpile): This function is responsible for transpiling a model. The overall objective is to prepare a model for use by converting it into a different format (transpiling).
+* [`ezkl.prove`](../../docs/reference/api/frameworks.ezkl.md#function-prove)
+* [`ezkl.setup`](../../docs/reference/api/frameworks.ezkl.md#function-setup): This function executes the setup of the model and creates the outputs, handled by Giza.
+* [`ezkl.verify`](../../docs/reference/api/frameworks.ezkl.md#function-verify): Create a verification job.
+* [`utils.get_response_info`](utils.md#function-get\_response\_info): Utility to retrieve information of the client response.
+* [`decorators.auth`](utils.decorators.md#function-auth): Check that we have the token and it is not expired before executing
diff --git a/reference/api/callbacks.md b/reference/api/callbacks.md
new file mode 100644
index 0000000..6460f65
--- /dev/null
+++ b/reference/api/callbacks.md
@@ -0,0 +1,61 @@
+
+
+
+
+# module `callbacks`
+
+
+
+
+
+---
+
+
+
+## function `version_callback`
+
+```python
+version_callback(value: bool) β None
+```
+
+Prints the current version when `--version` flag is added to a call.
+
+
+
+**Args:**
+
+ - `value` (bool): represents if the flag has been added or not to the call.
+
+
+
+**Raises:**
+
+ - `Exit`: exit the CLI execution
+
+
+---
+
+
+
+## function `debug_callback`
+
+```python
+debug_callback(_, value: bool)
+```
+
+If a call adds the `--debug` flag debugging mode is activated for external requests and API Clients.
+
+
+
+**Args:**
+
+ - `_` (_type_): discarded value
+ - `value` (bool): represents if the flag has been added to the call or not
+
+
+
+**Returns:**
+
+ - `bool`: pass the value back so it can be used in the clients
+
+
diff --git a/reference/api/cli.md b/reference/api/cli.md
new file mode 100644
index 0000000..197313b
--- /dev/null
+++ b/reference/api/cli.md
@@ -0,0 +1,28 @@
+
+
+
+
+# module `cli`
+
+
+
+
+**Global Variables**
+---------------
+- **click**
+
+---
+
+
+
+## function `entrypoint`
+
+```python
+entrypoint()
+```
+
+
+
+
+
+
diff --git a/reference/api/client.md b/reference/api/client.md
new file mode 100644
index 0000000..8b81e58
--- /dev/null
+++ b/reference/api/client.md
@@ -0,0 +1,1660 @@
+
+
+
+
+# module `client`
+
+
+
+
+**Global Variables**
+---------------
+- **DEFAULT_API_VERSION**
+- **GIZA_TOKEN_VARIABLE**
+- **MODEL_URL_HEADER**
+- **API_KEY_HEADER**
+
+
+---
+
+
+
+## class `ApiClient`
+Implementation of the API client to interact with core-services
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
+---
+
+
+
+## class `UsersClient`
+Client to interact with `users` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create(user: UserCreate) β UserResponse
+```
+
+Call the API to create a new user
+
+
+
+**Args:**
+
+ - `user` (users.UserCreate): information used to create a new user
+
+
+
+**Returns:**
+
+ - `users.UserResponse`: the created user information
+
+---
+
+
+
+### method `create_api_key`
+
+```python
+create_api_key()
+```
+
+Call the API to create a new API key
+
+
+
+**Returns:**
+
+ - `users.UserResponse`: the created user information
+
+---
+
+
+
+### method `me`
+
+```python
+me() β UserResponse
+```
+
+Retrieve information about the current user. Must have a valid token to perform the operation, enforced by `@auth`
+
+
+
+**Returns:**
+
+ - `users.UserResponse`: User information from the server
+
+---
+
+
+
+### method `request_reset_password_token`
+
+```python
+request_reset_password_token(email: str) β Msg
+```
+
+Sends a request to the server to generate a password reset token. The token is sent to the user's email.
+
+
+
+**Args:**
+
+ - `email` (str): The email of the user who wants to reset their password.
+
+
+
+**Returns:**
+
+ - `Msg`: A message indicating the success or failure of the request.
+
+---
+
+
+
+### method `resend_email`
+
+```python
+resend_email(email: str) β Msg
+```
+
+Resend the verification email to the user.
+
+
+
+**Args:**
+
+ - `email` (EmailStr): The email of the user who wants to resend the verification email.
+
+
+
+**Returns:**
+
+ - `Msg`: A message indicating the success or failure of the request.
+
+---
+
+
+
+### method `reset_password`
+
+```python
+reset_password(token: str, new_password: str) β Msg
+```
+
+Resets the user's password using the provided token and new password.
+
+
+
+**Args:**
+
+ - `token` (str): The password reset token sent to the user's email.
+ - `new_password` (str): The new password the user wants to set.
+
+
+
+**Returns:**
+
+ - `Msg`: A message indicating the success or failure of the password reset.
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
+---
+
+
+
+## class `DeploymentsClient`
+Client to interact with `deployments` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create(
+ model_id: int,
+ version_id: int,
+ deployment_create: DeploymentCreate,
+ f: BufferedReader
+) β Deployment
+```
+
+Create a new deployment.
+
+
+
+**Args:**
+
+ - `deployment_create`: Deployment information to create
+
+
+
+**Returns:**
+ The recently created deployment information
+
+---
+
+
+
+### method `get`
+
+```python
+get(model_id: int, version_id: int, deployment_id: int) β Deployment
+```
+
+Get a deployment.
+
+
+
+**Args:**
+
+ - `deployment_id`: Deployment identifier
+
+
+
+**Returns:**
+ The deployment information
+
+---
+
+
+
+### method `list`
+
+```python
+list(model_id: int, version_id: int) β List[Deployment]
+```
+
+List deployments.
+
+
+
+**Returns:**
+ A list of deployments created by the user
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
+---
+
+
+
+## class `TranspileClient`
+Client to interact with `users` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+---
+
+
+
+### method `transpile`
+
+```python
+transpile(f: ) β Response
+```
+
+Make a call to the API transpile endpoint with the model as a file.
+
+
+
+**Args:**
+
+ - `f` (BinaryIO): model to send for transpilation
+
+
+
+**Returns:**
+
+ - `Response`: raw response from the server with the transpiled model as a zip
+
+
+---
+
+
+
+## class `ModelsClient`
+Client to interact with `models` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create(model_create: ModelCreate) β Model
+```
+
+Create a new model.
+
+
+
+**Args:**
+
+ - `model_create`: Model information to create
+
+
+
+**Raises:**
+
+ - `Exception`: if there is no upload Url
+
+
+
+**Returns:**
+
+ - `Tuple[Model, str]`: the recently created model and a url, used to upload the model.
+
+---
+
+
+
+### method `get`
+
+```python
+get(model_id: int, **kwargs) β Model
+```
+
+Make a call to the API to retrieve model information.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier to retrieve information
+
+
+
+**Returns:**
+
+ - `Model`: model entity with the retrieved information
+
+---
+
+
+
+### method `get_by_name`
+
+```python
+get_by_name(model_name: str, **kwargs) β Optional[Model]
+```
+
+Make a call to the API to retrieve model information by its name.
+
+
+
+**Args:**
+
+ - `model_name`: Model name to retrieve information
+
+
+
+**Returns:**
+
+ - `Model`: model entity with the retrieved information
+
+---
+
+
+
+### method `list`
+
+```python
+list(**kwargs) β ModelList
+```
+
+List all the models related to the user.
+
+
+
+**Returns:**
+ A list of models created by the user
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+---
+
+
+
+### method `update`
+
+```python
+update(model_id: int, model_update: ModelUpdate) β Model
+```
+
+Update a model.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier to retrieve information
+ - `model_update`: body to partially update the model
+
+
+
+**Returns:**
+
+ - `Model`: the updated model
+
+
+---
+
+
+
+## class `JobsClient`
+Client to interact with `jobs` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create(job_create: JobCreate, f: BufferedReader) β Job
+```
+
+Create a new job.
+
+
+
+**Args:**
+
+ - `job_create`: Job information to create
+ - `f`: filed to upload, a CASM json
+
+
+
+**Raises:**
+
+ - `Exception`: if there is no upload Url
+
+
+
+**Returns:**
+
+ - `Tuple[Model, str]`: the recently created model and a url, used to upload the model.
+
+---
+
+
+
+### method `get`
+
+```python
+get(job_id: int, params: Optional[dict[str, str]] = None) β Job
+```
+
+Make a call to the API to retrieve job information.
+
+
+
+**Args:**
+
+ - `job_id`: Job identifier to retrieve information
+
+
+
+**Returns:**
+
+ - `Job`: job entity with the retrieved information
+
+---
+
+
+
+### method `list`
+
+```python
+list() β List[Job]
+```
+
+List jobs.
+
+
+
+**Returns:**
+ A list of jobs created by the user
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
+---
+
+
+
+## class `VersionJobsClient`
+Client to interact with `jobs` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create(
+ model_id: int,
+ version_id: int,
+ job_create: JobCreate,
+ f: BufferedReader
+) β Job
+```
+
+Create a new job.
+
+
+
+**Args:**
+
+ - `job_create`: Job information to create
+ - `f`: filed to upload, a CASM json
+
+
+
+**Raises:**
+
+ - `Exception`: if there is no upload Url
+
+
+
+**Returns:**
+
+ - `Tuple[Model, str]`: the recently created model and a url, used to upload the model.
+
+---
+
+
+
+### method `get`
+
+```python
+get(model_id: int, version_id: int, job_id: int) β Job
+```
+
+Make a call to the API to retrieve job information.
+
+
+
+**Args:**
+
+ - `job_id`: Job identifier to retrieve information
+
+
+
+**Returns:**
+
+ - `Job`: job entity with the retrieved information
+
+---
+
+
+
+### method `list`
+
+```python
+list(model_id: int, version_id: int) β List[Job]
+```
+
+List jobs.
+
+
+
+**Returns:**
+ A list of jobs created by the user
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
+---
+
+
+
+## class `ProofsClient`
+Client to interact with `proofs` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `download`
+
+```python
+download(proof_id: int) β bytes
+```
+
+Download a proof.
+
+
+
+**Args:**
+
+ - `proof_id`: Proof identifier
+
+
+
+**Returns:**
+ The proof binary file
+
+---
+
+
+
+### method `get`
+
+```python
+get(proof_id: int) β Proof
+```
+
+Make a call to the API to retrieve proof information.
+
+
+
+**Args:**
+
+ - `proof_id`: Proof identifier to retrieve information
+
+
+
+**Returns:**
+
+ - `Proof`: proof entity with the desired information
+
+---
+
+
+
+### method `get_by_job_id`
+
+```python
+get_by_job_id(job_id: int) β Proof
+```
+
+Make a call to the API to retrieve proof information based on the job id.
+
+
+
+**Args:**
+
+ - `job_id`: Job identifier to query by.
+
+
+
+**Returns:**
+
+ - `Proof`: proof entity with the desired information
+
+---
+
+
+
+### method `list`
+
+```python
+list() β List[Proof]
+```
+
+List all the proofs related to the user.
+
+
+
+**Returns:**
+ A list of proofs created by the user
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
+---
+
+
+
+## class `VersionsClient`
+Client to interact with `versions` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create(
+ model_id: int,
+ version_create: VersionCreate,
+ filename: Optional[str] = None
+) β Tuple[Version, str]
+```
+
+Create a new version.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier
+ - `version_create`: Version information to create
+
+
+
+**Returns:**
+ The recently created version information
+
+---
+
+
+
+### method `download`
+
+```python
+download(model_id: int, version_id: int) β bytes
+```
+
+Download a version.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier
+ - `version_id`: Version identifier
+
+
+
+**Returns:**
+ The version binary file
+
+---
+
+
+
+### method `download_original`
+
+```python
+download_original(model_id: int, version_id: int) β bytes
+```
+
+Download the original version.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier
+ - `version_id`: Version identifier
+
+
+
+**Returns:**
+ The version binary file
+
+---
+
+
+
+### method `get`
+
+```python
+get(model_id: int, version_id: int) β Version
+```
+
+Get a version.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier
+ - `version_id`: Version identifier
+
+
+
+**Returns:**
+ The version information
+
+---
+
+
+
+### method `list`
+
+```python
+list(model_id: int) β VersionList
+```
+
+List all the versions related to a model.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier
+
+
+
+**Returns:**
+ A list of versions related to the model
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+---
+
+
+
+### method `update`
+
+```python
+update(model_id: int, version_id: int, version_update: VersionUpdate) β Version
+```
+
+Update a specific version.
+
+
+
+**Args:**
+
+ - `model_id`: Model identifier
+ - `version_id`: Version identifier
+ - `version_update`: Version information to update
+
+
+
+**Returns:**
+ The updated version information
+
+
+---
+
+
+
+## class `WorkspaceClient`
+Client to interact with `workspaces` endpoint.
+
+
+
+### method `__init__`
+
+```python
+__init__(
+ host: str,
+ token: Optional[str] = None,
+ api_key: Optional[str] = None,
+ api_version: str = 'v1',
+ verify: bool = True,
+ debug: Optional[bool] = False
+) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `create`
+
+```python
+create() β Workspace
+```
+
+Call the API to create a new workspace. If the workspace already exists it will return a 400.
+
+
+
+**Returns:**
+
+ - `Workspace`: the created workspace information
+
+---
+
+
+
+### method `delete`
+
+```python
+delete() β None
+```
+
+Call the API to delete the workspace. If the workspace does not exist it will return a 404.
+
+
+
+**Returns:**
+ None
+
+---
+
+
+
+### method `get`
+
+```python
+get() β Workspace
+```
+
+Make a call to the API to retrieve workspace information. Only one should exist.
+
+
+
+**Returns:**
+
+ - `Workspace`: workspace information
+
+---
+
+
+
+### method `retrieve_api_key`
+
+```python
+retrieve_api_key() β None
+```
+
+Retrieve the API key from the `~/.giza/.api_key.json` file.
+
+
+
+**Raises:**
+
+ - `Exception`: if the file does not exist
+
+
+
+**Returns:**
+
+ - `str`: the API key
+
+---
+
+
+
+### method `retrieve_token`
+
+```python
+retrieve_token(
+ user: Optional[str] = None,
+ password: Optional[str] = None,
+ renew: bool = False
+) β None
+```
+
+Get the JWT token.
+
+First, it will try to get it from GIZA_TOKEN. Second, from ~/.giza/.credentials.json. And finally it will try to retrieve it from the API login the user in.
+
+
+
+**Args:**
+
+ - `user`: if provided it will be used to check against current credentials and if provided with `password` used to retrieve a new token.
+ - `password`: if provided with `user` it will be used to retrieve a new token.
+ - `renew`: for renewal of the JWT token by user login.
+
+
+
+**Raises:**
+
+ - `Exception`: if token could not be retrieved in any way
+
+
diff --git a/reference/api/commands.deploy.md b/reference/api/commands.deploy.md
new file mode 100644
index 0000000..94c65b9
--- /dev/null
+++ b/reference/api/commands.deploy.md
@@ -0,0 +1,2 @@
+# commands.deploy
+
diff --git a/reference/api/commands.md b/reference/api/commands.md
new file mode 100644
index 0000000..95ba3fa
--- /dev/null
+++ b/reference/api/commands.md
@@ -0,0 +1,11 @@
+
+
+
+
+# module `commands`
+
+
+
+
+
+
diff --git a/reference/api/commands.models.md b/reference/api/commands.models.md
new file mode 100644
index 0000000..015c595
--- /dev/null
+++ b/reference/api/commands.models.md
@@ -0,0 +1,106 @@
+
+
+
+
+# module `commands.models`
+
+
+
+
+**Global Variables**
+---------------
+- **API_HOST**
+
+---
+
+
+
+## function `get`
+
+```python
+get(
+ model_id: int = typer.Option(
+ ..., "--model-id", "-m", help="Model id to retrieve information from"
+ ),
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Command to create a user. Asks for the new users information and validates the input, then sends the information to the API
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False).
+
+
+
+**Raises:**
+
+ - `ValidationError`: input fields are validated, if these are not suitable the exception is raised
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
+---
+
+
+
+## function `list`
+
+```python
+list(
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Command to list all models.
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False).
+
+
+
+**Raises:**
+
+ - `ValidationError`: input fields are validated, if these are not suitable the exception is raised
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
+---
+
+
+
+## function `create`
+
+```python
+create(
+ name: str = typer.Option(
+ ..., "--name", "-n", help="Name of the model to be created"
+ ),
+ description: str = typer.Option(
+ None, "--description", "-d", help="Description of the model to be created"
+ ),
+ debug: Optional[bool] = **DEBUG_OPTION**
+) β None
+```
+
+Command to create a model. Asks for the new model's information and validates the input, then sends the information to the API
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False).
+
+
+
+**Raises:**
+
+ - `ValidationError`: input fields are validated, if these are not suitable the exception is raised
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
diff --git a/reference/api/commands.prove.md b/reference/api/commands.prove.md
new file mode 100644
index 0000000..e405a91
--- /dev/null
+++ b/reference/api/commands.prove.md
@@ -0,0 +1,33 @@
+
+
+
+
+# module `commands.prove`
+
+
+
+
+
+---
+
+
+
+## function `prove`
+
+```python
+prove(
+ data: str = typer.Argument(None),
+ model_id: Optional[str] = typer.Option(None, "--model-id", "-m"),
+ version_id: Optional[str] = typer.Option(None, "--version-id", "-v"),
+ size: JobSize = typer.Option(JobSize.S, "--size", "-s"),
+ framework: Framework = typer.Option(Framework.CAIRO, "--framework", "-f"),
+ output_path: str = typer.Option("zk.proof", "--output-path", "-o"),
+ debug: Optional[bool] = DEBUG_OPTION,
+) β None
+```
+
+
+
+
+
+
diff --git a/reference/api/commands.reset_password.md b/reference/api/commands.reset_password.md
new file mode 100644
index 0000000..9242361
--- /dev/null
+++ b/reference/api/commands.reset_password.md
@@ -0,0 +1,126 @@
+
+
+
+
+# module `commands.reset_password`
+
+
+
+
+**Global Variables**
+---------------
+- **API_HOST**
+
+---
+
+
+
+## function `prompt_for_input`
+
+```python
+prompt_for_input(
+ prompt_message: str,
+ type: Optional[type] = ,
+ hide_input: bool = False
+) β str
+```
+
+Prompt the user for input.
+
+
+
+**Args:**
+
+ - `prompt_message` (str): The message to display when prompting the user.
+ - `type` (type, optional): The type of input to expect. Defaults to str.
+ - `hide_input` (bool, optional): Whether to hide the input (for passwords). Defaults to False.
+
+
+
+**Returns:**
+
+ - `str`: The user's input.
+
+
+---
+
+
+
+## function `handle_http_error`
+
+```python
+handle_http_error(
+ e: HTTPError,
+ error_msg: str,
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Handle an HTTP error.
+
+
+
+**Args:**
+
+ - `e` (HTTPError): The error to handle.
+ - `debug` (Optional[bool]): Whether to raise the error for debugging. Defaults to DEBUG_OPTION.
+
+
+---
+
+
+
+## function `request_reset_password_token`
+
+```python
+request_reset_password_token(
+ email: str = typer.Option(None, "--email"),
+ debug: Optional[bool] = DEBUG_OPTION
+) β bool
+```
+
+Request a password reset token for a given email.
+
+
+
+**Args:**
+
+ - `email` (str): The email to request a password reset for.
+ - `debug` (Optional[bool]): Whether to raise errors for debugging. Defaults to DEBUG_OPTION.
+
+
+
+**Returns:**
+
+ - `bool`: True if the request was successful, False if not.
+
+
+---
+
+
+
+## function `reset_password`
+
+```python
+reset_password(
+ token: str = typer.Option(None, "--token"),
+ debug: Optional[bool] = DEBUG_OPTION
+) β bool
+```
+
+Reset the password for a user using a reset token.
+
+
+
+**Args:**
+
+ - `token` (str): The reset token received by email.
+ - `debug` (Optional[bool]): Whether to raise errors for debugging. Defaults to DEBUG_OPTION.
+
+
+
+**Returns:**
+
+ - `bool`: True if the reset was successful, False if not.
+
+
diff --git a/reference/api/commands.transpile.md b/reference/api/commands.transpile.md
new file mode 100644
index 0000000..590a7b3
--- /dev/null
+++ b/reference/api/commands.transpile.md
@@ -0,0 +1,49 @@
+
+
+
+
+# module `commands.transpile`
+
+
+
+
+**Global Variables**
+---------------
+- **API_HOST**
+
+---
+
+
+
+## function `transpile`
+
+```python
+transpile(
+ model_path: str = typer.Argument(None, help="Path of the model to transpile"),
+ output_path: str = typer.Option(
+ "cairo_model", "--output-path", "-o", help="Path to output the cairo model"
+ )
+ debug: Optional[bool] = DEBUG_OPTION,
+) β None
+```
+
+Command to transpile the model using the client. Sends the model and then unzips it to the desired location.
+
+This command will do a couple of things behind the scenes: * Create a Model entity * Upload the model * Update the status of the model * Poll the model until the status is either FAILED or COMPLETED * If COMPLETED the model is downloaded
+
+
+
+**Args:**
+
+ - `model_path` (str): path for the model to load
+ - `output_path` (str): ouput to store the transpiled model. Defaults to "cairo_model".
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION(False).
+
+
+
+**Raises:**
+
+ - `BadZipFile`: if the received file is not a zip, could be due to a transpilation error at the API.
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
diff --git a/reference/api/commands.users.md b/reference/api/commands.users.md
new file mode 100644
index 0000000..5c3b8c1
--- /dev/null
+++ b/reference/api/commands.users.md
@@ -0,0 +1,146 @@
+
+
+
+
+# module `commands.users`
+
+
+
+
+**Global Variables**
+---------------
+- **API_HOST**
+
+---
+
+
+
+## function `create`
+
+```python
+create(
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Command to create a user. Asks for the new users information and validates the input, then sends the information to the API
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False).
+
+
+
+**Raises:**
+
+ - `ValidationError`: input fields are validated, if these are not suitable the exception is raised
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
+---
+
+
+
+## function `login`
+
+```python
+login(
+ renew: bool = typer.Option(False, help="Force the renewal of the JWT token"),
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Logs the current user into Giza. Under the hood this will retrieve the token for the next requests. This token will be saved at `home` directory for further usage.
+
+
+
+**Args:**
+
+ - `renew` (bool): Force the retrieval of the token to create a new one. Defaults to False.
+ - `debug` (Optional[bool]): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False)
+
+
+
+**Raises:**
+
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
+---
+
+
+
+## function `create_api_key`
+
+```python
+create_api_key(
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Create an API key for your user. You need to be logged in to create an API key. The API Key will be saved at `home` directory for further usage.
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool]): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False)
+
+
+
+**Raises:**
+
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
+---
+
+
+
+## function `me`
+
+```python
+me(
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Retrieve information about the current user and print it as json to stdout.
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False)
+
+
+---
+
+
+
+## function `resend_email`
+
+```python
+resend_email(
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Command to resend verification email. Asks for the user's email and sends the request to the API
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False).
+
+
+
+**Raises:**
+
+ - `ValidationError`: input fields are validated, if these are not suitable the exception is raised
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
diff --git a/reference/api/commands.version.md b/reference/api/commands.version.md
new file mode 100644
index 0000000..5cffba8
--- /dev/null
+++ b/reference/api/commands.version.md
@@ -0,0 +1,23 @@
+
+
+
+
+# module `commands.version`
+
+
+
+
+
+---
+
+
+
+## function `check_version`
+
+```python
+check_version()
+```
+
+Check if there is a new version available of the cli in pypi to suggest upgrade
+
+
diff --git a/reference/api/commands.versions.md b/reference/api/commands.versions.md
new file mode 100644
index 0000000..7d7f420
--- /dev/null
+++ b/reference/api/commands.versions.md
@@ -0,0 +1,162 @@
+
+
+
+
+# module `commands.versions`
+
+
+
+
+**Global Variables**
+---------------
+- **API_HOST**
+
+---
+
+
+
+## function `get`
+
+```python
+get(
+ model_id: int = typer.Option(None, help="The ID of the model"),
+ version_id: int = typer.Option(None, help="The ID of the version"),
+ debug: Optional[bool] = DEBUG_OPTION,
+) β None
+```
+
+
+
+
+
+
+---
+
+
+
+## function `transpile`
+
+```python
+transpile(
+ model_path: str = typer.Argument(None, help="Path of the model to transpile"),
+ model_id: int = typer.Option(
+ None, help="The ID of the model where a new version will be created"
+ ),
+ desc: str = typer.Option(None, help="Description of the version"),
+ model_desc: int = typer.Option(
+ None, help="Description of the Model to create if model_id is not provided"
+ ),
+ framework: Framework = typer.Option(Framework.CAIRO, "--framework", "-f"),
+ output_path: str = typer.Option(
+ "cairo_model",
+ "--output-path",
+ "-o",
+ help="The path where the cairo model will be saved",
+ ),
+ input_data: str = typer.Option(
+ None,
+ "--input-data",
+ "-i",
+ help="The input data to use for the transpilation",
+ ),
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+
+
+
+
+
+---
+
+
+
+## function `update`
+
+```python
+update(
+ model_id: int = typer.Option(None, help="The ID of the model"),
+ version_id: int = typer.Option(None, help="The ID of the version"),
+ description: str = typer.Option(
+ None, "--description", "-d", help="New description for the version"
+ ),
+ debug: Optional[bool] = DEBUG_OPTION,
+) β None
+```
+
+
+
+
+
+
+---
+
+
+
+## function `list`
+
+```python
+list(
+ model_id: int = typer.Option(None, help="The ID of the model"),
+ debug: Optional[bool] = DEBUG_OPTION,
+) β None
+```
+
+
+
+
+
+
+---
+
+
+
+## function `download`
+
+```python
+download(
+ model_id: int = typer.Option(None, help="The ID of the model"),
+ version_id: int = typer.Option(None, help="The ID of the version")
+ output_path: str = typer.Option(
+ "cairo_model", "--output-path", "-o", help="Path to output the cairo model"
+ ),
+ debug: Optional[bool] = DEBUG_OPTION,
+) β None
+```
+
+Retrieve information about the current user and print it as json to stdout.
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False)
+
+
+---
+
+
+
+## function `download_original`
+
+```python
+download_original(
+ model_id: int = typer.Option(None, help="The ID of the model"),
+ version_id: int = typer.Option(None, help="The ID of the version")
+ output_path: str = typer.Option(
+ "cairo_model", "--output-path", "-o", help="Path to output the cairo model"
+ ),
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Retrieve information about the current user and print it as json to stdout.
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False)
+
+
diff --git a/reference/api/commands.workspaces.md b/reference/api/commands.workspaces.md
new file mode 100644
index 0000000..681d4fb
--- /dev/null
+++ b/reference/api/commands.workspaces.md
@@ -0,0 +1,69 @@
+
+
+
+
+# module `commands.workspaces`
+
+
+
+
+**Global Variables**
+---------------
+- **API_HOST**
+
+---
+
+
+
+## function `get`
+
+```python
+get(
+ debug: debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+
+
+
+
+
+---
+
+
+
+## function `create`
+
+```python
+create(
+ debug: debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
+
+Command to create a Giza Workspace.
+
+
+
+**Args:**
+
+ - `debug` (Optional[bool], optional): Whether to add debug information, will show requests, extra logs and traceback if there is an Exception. Defaults to DEBUG_OPTION (False).
+
+
+
+**Raises:**
+
+ - `ValidationError`: input fields are validated, if these are not suitable the exception is raised
+ - `HTTPError`: request error to the API, 4XX or 5XX
+
+
+---
+
+
+
+## function `delete`
+
+```python
+delete(
+ debug: Optional[bool] = DEBUG_OPTION
+) β None
+```
diff --git a/reference/api/exceptions.md b/reference/api/exceptions.md
new file mode 100644
index 0000000..0060c2d
--- /dev/null
+++ b/reference/api/exceptions.md
@@ -0,0 +1,24 @@
+
+
+
+
+# module `exceptions`
+
+
+
+
+
+
+---
+
+
+
+## class `PasswordError`
+
+
+
+
+
+
+
+
diff --git a/reference/api/options.md b/reference/api/options.md
new file mode 100644
index 0000000..62436e2
--- /dev/null
+++ b/reference/api/options.md
@@ -0,0 +1,11 @@
+
+
+
+
+# module `options`
+
+
+
+
+
+
diff --git a/reference/api/utils.decorators.md b/reference/api/utils.decorators.md
new file mode 100644
index 0000000..060c1f9
--- /dev/null
+++ b/reference/api/utils.decorators.md
@@ -0,0 +1,40 @@
+
+
+
+
+# module `utils.decorators`
+
+
+
+
+**Global Variables**
+---------------
+- **TYPE_CHECKING**
+
+---
+
+
+
+## function `auth`
+
+```python
+auth(func: Callable)
+```
+
+Check that we have the token and it is not expired before executing
+
+Expects to be called from an instance of ApiClient to and endpoint that needs authorization
+
+
+
+**Args:**
+
+ - `func` (Callable): function to decorate
+
+
+
+**Returns:**
+
+ - `Callable`: decorated function
+
+
diff --git a/reference/api/utils.echo.md b/reference/api/utils.echo.md
new file mode 100644
index 0000000..d10dbb1
--- /dev/null
+++ b/reference/api/utils.echo.md
@@ -0,0 +1,225 @@
+
+
+
+
+# module `utils.echo`
+
+
+
+
+
+
+---
+
+
+
+## class `Echo`
+Helper class to use when printing output of the CLI.
+
+Provides utilities to print different levels of the messages and provides formatting capabilities to each of the levels.
+
+
+
+### method `__init__`
+
+```python
+__init__(debug: Optional[bool] = False) β None
+```
+
+
+
+
+
+
+
+
+---
+
+
+
+### method `debug`
+
+```python
+debug(message: str) β None
+```
+
+Format and echo a debug message
+
+
+
+**Args:**
+
+ - `message` (str): debug message to format and echo
+
+---
+
+
+
+### method `echo`
+
+```python
+echo(message: str, formatted: str) β None
+```
+
+Main function to print information of a message, original message is provided as well as the formatted one. Original is used when formatting is not possible.
+
+
+
+**Args:**
+
+ - `message` (str): original message
+ - `formatted` (str): formatted message
+
+---
+
+
+
+### method `error`
+
+```python
+error(message: str) β None
+```
+
+Format and echo an error message
+
+
+
+**Args:**
+
+ - `message` (str): error message to format and echo
+
+---
+
+
+
+### method `format_debug`
+
+```python
+format_debug(message: str) β str
+```
+
+Specific format for debug purposes
+
+
+
+**Args:**
+
+ - `message` (str): message to format
+
+
+
+**Returns:**
+
+ - `str`: debug formatted message
+
+---
+
+
+
+### method `format_error`
+
+```python
+format_error(message: str) β str
+```
+
+Specific format for error purposes
+
+
+
+**Args:**
+
+ - `message` (str): message to format
+
+
+
+**Returns:**
+
+ - `str`: error formatted message
+
+---
+
+
+
+### method `format_message`
+
+```python
+format_message(message: str, field: str = 'giza', color: str = 'orange3') β str
+```
+
+Format a message with an specific field and color. Adds current time, provided field and prints it with the specified color.
+
+
+
+**Args:**
+
+ - `message` (str): the message to format with the CLI
+ - `field` (str): Main field to format with the message. Defaults to "giza".
+ - `color` (str): Color to format the message with. Defaults to "orange3".
+
+
+
+**Returns:**
+
+ - `str`: the formatted message
+
+---
+
+
+
+### method `format_warning`
+
+```python
+format_warning(message: str) β str
+```
+
+Specific format for warning purposes
+
+
+
+**Args:**
+
+ - `message` (str): message to format
+
+
+
+**Returns:**
+
+ - `str`: error formatted message
+
+---
+
+
+
+### method `info`
+
+```python
+info(message: str) β None
+```
+
+Format and echo a message
+
+
+
+**Args:**
+
+ - `message` (str): message to format and echo
+
+---
+
+
+
+### method `warning`
+
+```python
+warning(message: str) β None
+```
+
+Format and echo a warning message
+
+
+
+**Args:**
+
+ - `message` (str): message to format and echo
+
+
diff --git a/reference/api/utils.enum.md b/reference/api/utils.enum.md
new file mode 100644
index 0000000..eca5654
--- /dev/null
+++ b/reference/api/utils.enum.md
@@ -0,0 +1,2 @@
+# utils.enum
+
diff --git a/reference/api/utils.md b/reference/api/utils.md
new file mode 100644
index 0000000..0c124c7
--- /dev/null
+++ b/reference/api/utils.md
@@ -0,0 +1,40 @@
+
+
+
+
+# module `utils`
+
+
+
+
+**Global Variables**
+---------------
+- **REQUEST_ID_HEADER**
+
+---
+
+
+
+## function `get_response_info`
+
+```python
+get_response_info(response: Response | None) β Dict[str, Any]
+```
+
+Utility to retrieve information of the client response.
+
+Try to get the body, if not just get the text.
+
+
+
+**Args:**
+
+ - `response` (Response): a response from the API
+
+
+
+**Returns:**
+
+ - `dict`: information about the returned response
+
+
diff --git a/resources/deployments.md b/resources/deployments.md
new file mode 100644
index 0000000..0a07d54
--- /dev/null
+++ b/resources/deployments.md
@@ -0,0 +1,84 @@
+# Deployments
+
+Deployments in our platform provide a mechanism for creating services that accept predictions via a designated endpoint. These services, based on existing platform versions, leverage Cairo under the hood to ensure provable inferences. Using the CLI, users can effortlessly deploy and retrieve information about these machine learning services.
+
+## Deploying a model
+
+To deploy a model, you must first have a version of that model. If you have not yet created a version, please refer to the [versions](versions.md) documentation.
+
+To create a new service, users can employ the `deploy` command. This command facilitates the deployment of a machine learning service ready to accept predictions at the `/cairo_run` endpoint, providing a straightforward method for deploying and utilizing machine learning capabilities.
+
+```console
+> giza deployments deploy --model-id 1 --version-id 1 model.sierra
+β°β°β°β°β°β±β± Creating deployment!
+[giza][2024-01-17 17:18:17.055] Deployment is successful β
+[giza][2024-01-17 17:18:17.056] Deployment created with endpoint URL: https://deployment-gizabrain-38-1-53427f44-dagsgas-ew.a.run.app π
+```
+
+### Example request
+
+Now our service is ready to accept predictions at the provided endpoint URL. To test this, we can use the `curl` command to send a POST request to the endpoint with a sample input.
+
+```console
+> curl -X POST https://deployment-gizabrain-38-1-53427f44-dagsgas-ew.a.run.app/cairo_run \
+ -H "Content-Type: application/json" \
+ -d '{
+ "args": "[\"2\", \"2\", \"2\", \"4\", \"1\", \"2\", \"3\", \"4\"]"
+ }' | jq
+{
+ "result": [
+ {
+ "value": {
+ "val": [
+ 1701737587,
+ 1919382893,
+ 1869750369,
+ 1852252262,
+ 1864395887,
+ 1948284015,
+ 1231974517
+ ]
+ }
+ }
+ ]
+}
+```
+
+## Listing deployments
+
+The list command is designed to retrieve information about all existing deployments. It provides an overview of the deployed machine learning services, allowing users to monitor and manage multiple deployments efficiently.
+
+```console
+giza deployments list --model-id 1 --version-id 1
+[giza][2024-01-17 17:19:00.631] Listing deployments β
+[
+ {
+ "id": 1,
+ "status": "COMPLETED",
+ "uri": "https://deployment-gizabrain-38-1-53427f44-dagsgas-ew.a.run.app",
+ "size": "S",
+ "service_name": "deployment-gizabrain-38-1-53427f44",
+ "model_id": 1,
+ "version_id": 1
+ }
+]
+```
+
+Executing this command will display a list of all current deployments, including relevant details such as service names, version numbers, and deployment status.
+
+## Retrieving a deployment
+
+For retrieving detailed information about a specific deployment, users can utilize the get command. This command allows users to query and view specific details of a single deployment, providing insights into the configuration, status, and other pertinent information.
+
+```console
+> giza deployments get --model-id 1 --version-id 1 --deployment-id 1
+{
+ "id": 1,
+ "status": "COMPLETED",
+ "uri": "https://deployment-gizabrain-38-1-53427f44-dagsgas-ew.a.run.app",
+ "size": "S",
+ "service_name": "deployment-gizabrain-38-1-53427f44",
+ "model_id": 38,
+ "version_id": 1
+}
+```
diff --git a/resources/models.md b/resources/models.md
new file mode 100644
index 0000000..10aed9e
--- /dev/null
+++ b/resources/models.md
@@ -0,0 +1,116 @@
+# Models
+
+Handle your models at Giza!
+
+In Giza, a model represents a container for versions of your machine learning model. This design allows you to iterate and improve your ML model by creating new versions for it. Each model can have multiple versions, providing a robust and flexible way to manage the evolution of your ML models. This traceability feature ensures that you have a clear record of the original `onnx` model used for transpilation, who performed the transpilation, and the output generated.
+
+Remember, you need to be logged in to use these functionalities!
+
+## Create a Model
+
+Creating a new model in Giza is a straightforward process. You only need to provide a name for the model using the `--name` option. However, you can also add a description of the model using the `--description` option. This can be helpful for keeping track of different models and their purposes.
+
+Here's how you can do it:
+
+```console
+> giza models create --name my_new_model --description "A New Model"
+[giza][2023-09-13 13:24:28.223] Creating model β
+{
+ "id": 1,
+ "name": "my_new_model",
+ "description": "A New Model"
+}
+```
+
+Typically, the `transpile` command is used to handle model creation. During this process, the filename is checked for an existing model. If none is found, a new model is automatically created. However, manual creation of a model is also supported. For more information, refer to the transpile documentation ([cairo](../frameworks/cairo/transpile.md) and [ezkl](../frameworks/ezkl/transpile.md)).
+
+## List Models
+
+Giza provides a simple and efficient way to list all the models you have stored on the server. This feature is especially useful when you have multiple models and need to manage them effectively.
+
+To list all your models, you can use the `list` command. This command retrieves and displays a list of all models stored in the server. Each model's information is printed in a json format for easy readability and further processing.
+
+Here's how you can do it:
+
+```console
+> giza models list
+[giza][2023-09-13 13:11:39.403] Listing models β
+[
+ {
+ "id": 1,
+ "name": "my_new_model",
+ "description": "A New Model"
+ },
+ {
+ "id": 2,
+ "name": "Test",
+ "description": "A Model for testing different models"
+ }
+]
+```
+
+## Retrieve Model Information
+
+You can retrieve detailed information about a model stored on the server using its unique model id. This includes its name, description, and other id:
+
+```console
+> giza models get --model-id 1 # When we create model for you we output it in the logs so be aware
+[giza][2023-09-13 13:17:53.594] Retrieving model information β
+{
+ "id": 1,
+ "name": "my_new_model",
+ "description": "A New Model"
+}
+```
+
+Now we can see that we have a model successfully transpiled! Now if we want we could download it again!
+
+## Transpile a model
+
+{% hint style="info" %}
+**Note:** This is explained extensively in the transpile documentation ([Orion Cairo](../frameworks/cairo/transpile.md) and [EZKL](../frameworks/ezkl/transpile.md)).
+{% endhint %}
+
+Transpiling a model in Giza is a crucial step in the model deployment process. Transpilation is the process of converting your machine learning model into a format that can be executed on Giza. Depending the ZKML framework chosen, this process involves converting the model into a series of Cairo instructions or performing the setup using EZKL.
+
+When you execute the 'transpile' command, it initially checks for the presence of the model on the Giza platform. If no model is found, it automatically generates one and performs the transpilation. Here is an example of the command:
+
+```
+giza transpile --framework CAIRO awesome_model.onnx --output-path my_awesome_model
+```
+
+It's worth noting that if you already have created a model, you can transpile it by specifying the model ID:
+
+```
+giza transpile --model-id 1 --framework CAIRO awesome_model.onnx --output-path my_awesome_model
+```
+
+This method proves useful when you intend to create a new version of an existing model.
+
+For more information, refer to the transpile documentation ([cairo](../frameworks/cairo/transpile.md) and [ezkl](../frameworks/ezkl/transpile.md)).
+
+## Download a successfully transpiled model
+
+For this we can use the `download` command available in the CLI which only needs a `model_id` to download it again!
+
+```console
+> giza models download 1
+[giza][2023-08-04 10:33:14.271] Transpilation is ready, downloading! β
+[giza][2023-08-04 10:33:15.134] Transpilation saved at: cairo_model
+```
+
+Let's check the downloaded model:
+
+```console
+> tree cairo_model/
+cairo_model
+βββ inference
+β βββ Scarb.toml
+β βββ src
+β βββ lib.cairo
+βββ initializers
+ βββ node_l1
+ β βββ Scarb.toml
+ β βββ src
+ β βββ lib.cairo
+```
diff --git a/resources/users.md b/resources/users.md
new file mode 100644
index 0000000..5a07106
--- /dev/null
+++ b/resources/users.md
@@ -0,0 +1,123 @@
+# Users
+
+Giza CLI provides the capabilities to manage users in Giza.
+
+- [Users](#users)
+ - [Available commands](#available-commands)
+ - [Create](#create)
+ - [Login](#login)
+ - [Create API Key](#create-api-key)
+ - [Me](#me)
+
+## Available commands
+
+### Create
+
+Allows to create a user using the CLI. The username must be unique and the email account should not have been used previously for another user.
+
+```console
+> giza users create
+
+Enter your username π: my-username
+Enter your password π₯· : (this is a secret)
+Enter your email π§: gonzalo@gizatech.xyz
+[giza][2023-06-23 12:29:41.417] User created β
. Check for a verification email π§
+```
+
+This will create an *inactive* user in Giza, to activate it you need to verify your user through the verification email.
+
+If there is an error or you want to have more information about what it's going on there is a `--debug` flag that will add more information about the error. This will print outgoing requests to the API, debug logs and python traceback about what happened.
+
+β οΈ**Note**: be aware that the debug option will print everything that its going to the API, in this case the password will be printed as plain text in the terminal, if you are using the debug option to fill an issue make sure to remove the credentials.
+
+### Login
+
+Log into Giza platfrom and retrieve a JWT for authentication. This JWT will be stored to authenticate you later until the token expires.
+
+**You need te have an active account to log in**
+
+```console
+> giza users login
+
+Enter your username π: my-username
+Enter your password π₯· :
+[giza][2023-06-23 12:32:17.917] Log into Giza
+[giza][2023-06-23 12:32:18.716] βοΈCould not authorize the userβοΈ
+[giza][2023-06-23 12:32:18.718] βοΈStatus code -> 400βοΈ
+[giza][2023-06-23 12:32:18.719] βοΈError message -> {'detail': 'Inactive user'}βοΈ
+```
+
+Once activated you can successfully log into Giza:
+
+```console
+> giza users login
+
+Enter your username π: gizabrain
+Enter your password π₯· :
+[giza][2023-07-12 10:52:25.199] Log into Giza
+[giza][2023-07-12 10:52:46.998] Credentials written to: /Users/gizabrain/.giza/.credentials.json
+[giza][2023-07-12 10:52:47.000] Successfully logged into Giza β
+```
+
+If you want force the renewal of the token you can use `--renew` to force the log in. If the flag is not present we verify if there has been a previous log in and check that the token it's still valid.
+
+```console
+> giza users login
+
+Enter your username π: gizabrain
+Enter your password π₯· :
+[giza][2023-07-12 10:55:26.219] Log into Giza
+[giza][2023-07-12 10:55:26.224] Token it still valid, re-using it from ~/.giza
+[giza][2023-07-12 10:55:26.224] Successfully logged into Giza β
+```
+
+With `--renew`:
+
+```console
+> giza users login --renew
+
+Enter your username π: gizabrain
+Enter your password π₯· :
+[giza][2023-07-12 10:56:44.316] Log into Giza
+[giza][2023-07-12 10:56:44.979] Credentials written to: /Users/gizabrain/.giza/.credentials.json
+[giza][2023-07-12 10:56:44.980] Successfully logged into Giza β
+```
+
+**Note**: `--debug` its also available.
+
+### Create API Key
+
+Create an API key for the current user. This API key will be stored and will be used to authenticate the user in the future.
+
+**You need te have an active account to log in**
+
+```console
+> giza users create-api-key
+[giza][2024-01-17 15:27:27.936] Creating API Key β
+[giza][2024-01-17 15:27:53.605] API Key written to: /Users/gizabrain/.giza/.api_key.json
+[giza][2024-01-17 15:27:53.606] Successfully created API Key. It will be used for future requests β
+```
+
+Now you can use the API key to authenticate yourself withouth the need of login again and again.
+
+**NOTE: The usage of API key is less secure than JWT, so use it with caution.**
+
+### Me
+
+Retrieve information about the current user.
+
+**You need te have an active account**
+
+```console
+> giza users me
+
+[giza][2023-07-12 10:59:43.821] Retrieving information about me!
+[giza][2023-07-12 10:59:43.823] Token it still valid, re-using it from ~/.giza
+{
+ "username": "gizabrain",
+ "email": "gizabrain@gizatech.xyz",
+ "is_active": true
+}
+```
+
+**Note**: `--debug` its also available.
diff --git a/resources/versions.md b/resources/versions.md
new file mode 100644
index 0000000..7f68882
--- /dev/null
+++ b/resources/versions.md
@@ -0,0 +1,116 @@
+# Versions
+
+Manage your model versions at Giza!
+
+In Giza, a version represents a specific iteration of your machine learning model within a Giza Model. This design allows you to iterate and improve your ML model by creating new versions for it. Each model can have multiple versions, providing a robust and flexible way to manage the evolution of your ML models. This traceability feature ensures that you have a clear record of each version of your model.
+
+Remember, you need to be logged in to use these functionalities!
+
+## Retrieve Version Information
+
+You can retrieve detailed information about a specific version of a model using its unique model ID and version ID. This includes its version number, size, description, status, creation date, and last update date.
+
+Here's how you can do it:
+
+```console
+> giza versions get --model-id 1 --version-id 1
+[giza][2023-09-13 14:38:30.965] Retrieving version information β
+{
+ "version": 1,
+ "size": 52735,
+ "status": "COMPLETED",
+ "message": "Transpilation Successful",
+ "description": "Initial version of the model",
+ "created_date": "2023-07-04T11:15:09.448709",
+ "last_update": "2023-08-25T11:08:51.815545"
+}
+```
+
+## List Versions
+
+Giza provides a simple and efficient way to list all the versions of a specific model you have. This feature is especially useful when you have multiple versions of a model and need to manage them effectively.
+
+To list all your versions of a model, you can use the list command. Each version's information is printed in a json format for easy readability and further processing.
+
+Here's how you can do it:
+
+```console
+> giza versions list --model-id 1
+[giza][2023-09-13 14:41:09.209] Listing versions for the model β
+[
+ {
+ "version": 1,
+ "size": 52735,
+ "status": "COMPLETED",
+ "message": "Transpilation Successful",
+ "description": "Initial version of the model",
+ "created_date": "2023-07-04T11:15:09.448709",
+ "last_update": "2023-08-25T11:08:51.815545"
+ },
+ {
+ "version": 2,
+ "size": 52735,
+ "status": "COMPLETED",
+ "message": "Transpilation Successful!",
+ "description": "Intial version",
+ "created_date": "2023-09-13T10:24:20.018476",
+ "last_update": "2023-09-13T10:24:24.376009"
+ }
+]
+```
+
+## Transpile a Model Version
+
+{% hint style="info" %}
+**Note:** This is explained extensively in the transpile documentation ([Orion Cairo](../frameworks/cairo/transpile.md) and [EZKL](../frameworks/ezkl/transpile.md)).
+{% endhint %}
+
+Transpiling a model version in Giza is a crucial step in the model deployment process. Transpilation is the process of converting your machine learning model into a format that can be executed on Giza. Depending the ZKML framework chosen, this process involves converting the model into a series of Cairo instructions or performing the setup using EZKL.
+
+When you transpile a model, you're essentially creating a new version of that model. Each version represents a specific iteration of your machine learning model, allowing you to track and manage the evolution of your models effectively.
+
+Here's how you can transpile a model version:
+
+```console
+> giza versions transpile --framework CAIRO awesome_model.onnx --output-path my_awesome_model
+[giza][2023-09-13 12:56:43.725] No model id provided, checking if model exists β
+[giza][2023-09-13 12:56:43.726] Model name is: awesome_model
+[giza][2023-09-13 12:56:43.978] Model Created with id -> 1! β
+[giza][2023-09-13 12:56:44.568] Sending model for transpilation β
+[giza][2023-09-13 12:56:55.577] Transpilation recieved! β
+[giza][2023-09-13 12:56:55.583] Transpilation saved at: cairo_model
+```
+
+Once the transpilation process is complete, a new version of the model is created in Giza. The version will be downloaded and saved at the specified output path, but you can also execute later with the `download` command to download it again.
+
+## Download a Transpiled Version
+
+Once a model has been successfully transpiled, it's not necessary to go through the transpilation process again. The transpiled version is stored and can be downloaded anytime you need it. This is done using the `download` command in the CLI. This command specifically requires the `model_id` and `version_id` to accurately identify and download the correct transpiled version. This feature saves time and computational resources, making the management of your models more efficient.
+
+{% hint style="warning" %}
+The \`download\` feature is currently only available for the Orion Cairo framework.
+{% endhint %}
+
+```console
+> giza versions download --model-id 1 --version-id 1 --output-path path
+[giza][2023-08-04 10:33:14.271] Transpilation is ready, downloading! β
+[giza][2023-08-04 10:33:15.134] Transpilation saved at: path
+```
+
+Let's check the downloaded version:
+
+```console
+> tree cairo_model/
+cairo_model
+βββ inference
+β βββ Scarb.toml
+β βββ src
+β βββ lib.cairo
+βββ initializers
+ βββ node_l1
+ β βββ Scarb.toml
+ β βββ src
+ β βββ lib.cairo
+```
+
+For more information on how to transpile a model, refer to the transpile documentation ([cairo](../frameworks/cairo/transpile.md) and [ezkl](../frameworks/ezkl/transpile.md)).
diff --git a/resources/workspaces.md b/resources/workspaces.md
new file mode 100644
index 0000000..58da7b4
--- /dev/null
+++ b/resources/workspaces.md
@@ -0,0 +1,63 @@
+# Workspaces
+
+Workspaces in our platform are a crucial component designed to enhance user interaction with Giza Actions. These workspaces provide a user-friendly interface (UI) for managing and tracking runs, tasks, and metadata associated with action executions. Leveraging a command-line interface (CLI), users can seamlessly interact with workspaces, ensuring a smooth and efficient experience.
+
+The incorporation of Workspaces stems from our commitment to optimizing user interaction with Giza Actions. These dedicated workspaces serve as a strategic enhancement, providing a cohesive environment for users to oversee, manage, and delve into the intricate details of action runs, tasks, and associated metadata. The introduction of Workspaces aims to elevate user efficiency, offering a centralized hub that streamlines navigation and organization.
+
+## Create a Workspace
+
+To create a new workspace, users can utilize the giza workspace create command. This command initiates the creation process, setting up a new workspace. If a workspace with the specified name already exists, the command will gracefully handle this scenario by throwing an error, ensuring that each workspace has a unique identifier.
+
+The workspace creation process can take up to 10 minutes as we are creating isolated resources for each respective workspace.
+
+```console
+> giza workspaces create
+[giza][2024-01-17 14:40:02.046] Creating Workspace β
+[WARNING][2024-01-17 14:40:02.047] This process can take up to 10 minutes β³
+[giza][2024-01-17 14:41:51.248] Waiting for workspace creation...
+[giza][2024-01-17 14:43:12.291] Workspace status is 'PROCESSING'
+[giza][2024-01-17 14:45:54.365] Worksace creation is successful β
+[giza][2024-01-17 14:45:54.366] β
Workspace URL: https://actions-server-gizabrain-gageadsga-ew.a.run.app β
+```
+
+Once created, the workspace will be available for use. The workspace URL will be printed in the console, and it can be used to access the workspace.
+
+![workspace](../.gitbook/assets/workspace.png)
+
+Now you can start using the workspace to run actions!
+
+## Retrieve a Workspace
+
+For retrieving information about an existing workspace, the giza workspace get command comes into play. This command provides users with a comprehensive overview of the specified workspace, including details about the url. It serves as a quick reference point to get the workspace URL for the user.
+
+```console
+> giza workspaces get
+[giza][2024-01-17 14:46:35.654] Retrieving workspace information β
+[giza][2024-01-17 14:46:35.805] β
Workspace URL: https://actions-server-gizabrain-gageadsga-ew.a.run.app β
+{
+ "url": "https://actions-server-gizabrain-gageadsga-ew.a.run.app",
+ "status": "COMPLETED"
+}
+```
+
+## Delete a Workspace
+
+In situations where a workspace is no longer needed, users can use the giza workspace delete command to remove it. This command ensures a clean and straightforward deletion process for an existing workspace, allowing users to manage their resources efficiently.
+
+It will prompt a confirmation message before deleting the workspace as **USER DATA WILL BE ERASED**.
+
+```console
+> giza workspaces delete
+[WARNING][2024-01-17 14:48:29.103] THIS WILL ERASE ALL YOUR WORKSPACE DATA β
+Are you sure you want to delete the workspace? [y/N]: y
+[giza][2024-01-17 14:49:05.777] Deleting Workspace β
+[giza][2024-01-17 14:49:08.507] Workspace Deleted β
+```
+
+## About Giza Actions
+
+Giza Actions is the core component within the platform, Workspaces act as an interface to connect with these actions, providing users with a centralized hub to monitor and manage their executions. This integration enhances the overall usability and accessibility of Giza Actions, making it easier for users to interact with and control their workflows.
+
+By integrating workspaces into our platform, we aim to simplify the user experience, offering a powerful yet intuitive solution for managing Giza Actions effectively.
+
+The Actions-SDK can be found at: [https://actions.gizatech.xyz/welcome/giza-actions-sdk](https://actions.gizatech.xyz/welcome/giza-actions-sdk)
diff --git a/welcome/actions.md b/welcome/actions.md
new file mode 100644
index 0000000..05d533c
--- /dev/null
+++ b/welcome/actions.md
@@ -0,0 +1,42 @@
+# Actions
+
+Build Verifiable ML products with ease.
+
+Giza Actions empowers developers to build and scale Verifiable ML solutions quickly, turning their python scripts and ML models into resilient, recurrent workflows. Every model contained in an Action has verifiability properties without any code change using ZKML with and Giza Platform.
+
+At the core of Giza Actions are Actions themselves. An action serves as a framework for coding ML inferencing workflow logic, enabling users to tailor the behaviour of their workflows. Defined as Python functions, any Python function has the potential to be transformed into an action.
+
+More information about Giza Actions can be found in the [Actions Documentation](https://actions.gizatech.xyz/concepts/actions).
+
+## Starting with Actions
+
+Jumpstarting the creation of actions is made efficient through the use of a template powered by [Cookiecutter](https://github.com/cookiecutter/cookiecutter). This template serves as a foundation for creating actions and pipelines, streamlining the development process. The `actions-sdk` provides the necessary tools to create, visualize, and monitor these pipelines, enabling users to deploy and manage their actions seamlessly.
+
+```console
+> giza actions new actions_project
+[giza][2024-01-18 11:38:43.180] Creating a new Action project with name: actions_project β
+[giza][2024-01-18 11:38:44.173] Action project created successfully at ./actions_project β
+```
+
+This will create a new directory with the following structure:
+
+```console
+> tree actions_project
+actions_project
+βββ README.md
+βββ actions_project
+β βββ __init__.py
+β βββ action.py
+βββ pyproject.toml
+βββ tests
+ βββ __init__.py
+
+3 directories, 5 files
+```
+
+## Related Topics
+
+* [Actions SDK](https://actions.gizatech.xyz/welcome/giza-actions-sdk)
+* [Workspace](../resources/workspaces.md)
+* [Models](../resources/models.md)
+* [Versions](../resources/versions.md)
diff --git a/welcome/authentication.md b/welcome/authentication.md
new file mode 100644
index 0000000..8c7e887
--- /dev/null
+++ b/welcome/authentication.md
@@ -0,0 +1,21 @@
+# Authentication
+
+Authentication is a critical aspect of our platform, ensuring secure access to resources. Currently, there are two primary methods for authentication: the usage of JSON Web Tokens (JWT) through the giza users login command and the utilization of API keys.
+
+## What are JWT and API keys?
+
+* *JWT (JSON Web Token)*: A JWT is a compact, URL-safe means of representing claims between two parties. In the context of our platform, it serves as a secure authentication token obtained through the giza users login command. This token is then used to establish and maintain a secure communication channel with the platform.
+
+* *API Key*: An API key is a unique alphanumeric code generated by the platform that provides a secure way for applications or users to authenticate themselves. Once created, an API key serves as a credential to communicate with the platform, eliminating the need for repeated login procedures.
+
+## Key Differences
+
+The primary distinction between JWT and API keys lies in their nature and usage:
+
+* JWT is a token-based authentication mechanism that is time-sensitive and typically used for short-lived authentication sessions.
+
+* API keys, on the other hand, are static credentials that persist and provide a more long-term solution for authentication without the need for frequent renewals.
+
+## How to authenticate
+
+For information about using the CLI to authenticate yourself please refer to the [users](../resources/users.md) documentation.
diff --git a/welcome/frameworks.md b/welcome/frameworks.md
new file mode 100644
index 0000000..91c14bd
--- /dev/null
+++ b/welcome/frameworks.md
@@ -0,0 +1,37 @@
+# Frameworks
+
+Giza operates on multiple frameworks simultaneously. This allows you to switch between frameworks as needed, providing flexibility and control over your development process.
+
+## Orion Cairo
+
+_Cairo_ is A [STARK](https://starkware.co/stark/)-based Turing-complete language for writing provable programs. It is designed to be highly expressive, allowing developers to write programs that are both complex and efficient. [Orion](https://orion.gizatech.xyz/welcome/readme) is an open-source, framework dedicated to Provable Machine Learning writing in Cairo. It provides essential components and a new ONNX runtime for building verifiable Machine Learning models using STARKs.
+
+## EZKL
+
+`ezkl` is an engine for doing inference for deep learning models and other computational graphs in a zk-snark using `halo2` as the backend. For more information about `ezkl`, see the [ezkl repository](https://github.com/zkonduit/ezkl)
+
+## Switching between frameworks
+
+As we aim to bring the best of both worlds to developers, Giza allows us to perform the same operations on both frameworks just with a single change in the command line, the `--framework` flag.
+
+This flag allows you to specify which framework you want to use for the current operation but the underlying work that we do is the same.
+
+For example, if you want to use the Cairo framework, you would use the `--framework CAIRO` flag. Similarly, for the EZKL framework, you would use the `--framework EZKL` flag.
+
+For example, if you want to transpile a program using the Cairo framework, you would use the following command:
+
+```bash
+giza transpile --framework CAIRO model.onnx
+```
+
+Similarly, if you want to transpile a program using the EZKL framework, you would use the following command:
+
+```bash
+giza transpile --framework EZKL --input-data input.json model.onnx
+```
+
+The `transpile` command in EZKL is essentially the same as the `setup()` command used to perform the trusted setup, as we need extra information to perform the `setup` it has an additional `--input-data` flag that allows you to specify the input data for the model.
+
+This allows you to switch between frameworks as needed, providing flexibility and control over your development process.
+
+For more information about the available commands for each framework, please refer to the [Cairo](../frameworks/cairo/) and [EZKL](../frameworks/ezkl/) documentation.
diff --git a/welcome/installation.md b/welcome/installation.md
new file mode 100644
index 0000000..e62109b
--- /dev/null
+++ b/welcome/installation.md
@@ -0,0 +1,57 @@
+# Installation
+
+* [Installation](installation.md#-installation)
+ * [Recommended installation with pipx](installation.md#recommended-installation-with-pipx)
+ * [Install from PyPi](installation.md#install-from-pypi)
+ * [Installing from source](installation.md#installing-from-source)
+
+## Handling Python versions with Pyenv
+
+As we are using Python 3.11, it's recommended to use [Pyenv](https://github.com/pyenv/pyenv) to manage your Python versions. Here are the steps to install Pyenv and set Python 3.11 as your local version:
+
+1. First, we need to get pyenv, for information about how to install it, please refer to the [official documentation](https://github.com/pyenv/pyenv)
+2. Install Python 3.11 with Pyenv:
+
+```bash
+pyenv install 3.11.5
+```
+
+3. Set Python 3.11 as the local version for your project:
+
+```bash
+pyenv local 3.11.5
+```
+
+Now, your terminal session will use Python 3.11 for this project.
+
+## Recommended installation with pipx
+
+[pipx](https://pypa.github.io/pipx/) allows the installation of the dependency in an isolated environment. With this, we can make sure that it does not conflict with any of our installed dependencies.
+
+```bash
+pipx install giza-cli
+```
+
+## Install from PyPi
+
+For the latest release:
+
+```bash
+pip install giza-cli
+```
+
+## Installing from source
+
+Clone the repository and install it with `pip`:
+
+```bash
+git clone git@github.com:gizatechxyz/giza-cli.git
+cd giza-cli
+pip install .
+```
+
+Or install it directly from the repo:
+
+```bash
+pip install git+ssh://git@github.com/gizatechxyz/giza-cli.git
+```