Skip to main content

CLI for deploying AI services with Agents to watsonx.ai.

Project description

ibm-watsonx-ai-cli

CLI tool that enables developers to deploy AI services to watsonx.ai directly from their local environment.

IBM watsonx.ai CLI for Agents

Repository containing source code for ibm-watsonx-ai-cli package.

Contact info

Maintainers

Installation

pip install -U ibm-watsonx-ai-cli

Usage

Run CLI

$ watsonx-ai [OPTIONS] COMMAND [ARGS]...

[OPTIONS]

--version  -v           Print the current CLI version.
--help                  Show this message and exit.

COMMAND

- template              Explore, download and try-out the template.
- service               Work with deployed templates.

TEMPLATE

- list                  List all available templates.
- new                   Creates a selected template in a local env.  [ARGS: name, target]
- invoke                Executes the template code locally with demo data.  [OPTIONAL ARGS: query]

SERVICE

- list                   List all deployed AI services.
- new                    Create & deploy a new ai service. [OPTIONAL ARGS: name]
- get                    Get service details. [OPTIONAL ARGS: deployment_id (deployment_id)]
- delete                 Deletes ai service. [ARGS: deployment_id]
- invoke                 Calls the service by providing the test record. [OPTIONAL ARGS: deployment_id, query]

Template

watsonx-ai template list

List all available templates.

Usage:

$ watsonx-ai template list [OPTIONS]

Options:

  • --help: Show this message and exit.

watsonx-ai template new

Creates a selected template in a local env.

Usage:

$ watsonx-ai template new [OPTIONS] name target

Arguments:

  • name: Name of the template to download or its index in the list of available templates.
  • target: Target directory where template will be saved.

Options:

  • --help: Show this message and exit.

watsonx-ai template invoke

Executes the template code locally with demo data.

Usage:

$ watsonx-ai template invoke [OPTIONS] query

Arguments:

  • query:[Optional] Input query for template code. If not specified, searches for the cli.options.payload_path file to be specified in config.toml. Content of cli.options.payload_path will be directly send to the AI service and should agree with AI service request schema.

Options:

  • --help: Show this message and exit.

Service

watsonx-ai service list

List all deployed AI services.

Usage:

$ watsonx-ai service list [OPTIONS]

Options:

  • --help: Show this message and exit.

watsonx-ai service new

Create & deploy a new AI service. After successful deployment creation the deployment_id will be saved automatically in section [deployment] in config.toml.

When running this command a package distribution with implemented agent will be created in folder dist. Warning! If dist already exists, distribution creation is skipped.

Usage:

$ watsonx-ai service new [OPTIONS] name

Arguments:

  • name:[Optional] Name for the deployed AI service. If not provided, name for the deployment will be the same as name of current directory.

Options:

  • --help: Show this message and exit.

watsonx-ai service get

Get deployed service details.

Usage:

$ watsonx-ai service get [OPTIONS] deployment_id

Arguments:

  • deployment_id: Id of the deployed AI service.

Options:

  • --help: Show this message and exit.

watsonx-ai service delete

Deletes ai service.

Usage:

$ watsonx-ai service delete [OPTIONS] deployment_id

Arguments:

  • deployment_id: Id of the deployed AI service.

Options:

  • --help: Show this message and exit.

watsonx-ai service invoke

Calls the service by providing the test record.

Usage:

$ watsonx-ai service invoke [OPTIONS] query

Arguments:

  • query:[Optional] Test data to send to deployed AI service. If not specified, searches for the cli.options.payload_path file to be specified in config.toml. Content of cli.options.payload_path will be directly send to the deployed AI service and should agree with AI service request schema.

Options:

  • --deployment_id:[Optional] Id of a deployed AI service. If not provided, taken from deployment.deployment_id field from config.toml.
  • --help: Show this message and exit.

Secrets

Environment Variables for IBM watsonx.ai for IBM Cloud

For security reasons, it's recommended to not hard-code your API key or other secrets directly in your scripts or config.toml. Instead, set it up as an environment variable. Below variables will be used to authenticate to watsonx.ai APIs if analogous ones not provided in configuration file.

import os

WATSONX_URL = os.environ.get("WATSONX_URL", "")
WATSONX_APIKEY = os.environ.get("WATSONX_APIKEY", "")
WATSONX_TOKEN = os.environ.get("WATSONX_TOKEN", "")
WATSONX_SPACE_ID = os.environ.get("WATSONX_SPACE_ID", "")
WATSONX_PROJECT_ID = os.environ.get("WATSONX_PROJECT_ID", "")

Environment Variables for IBM watsonx.ai Software

In the IBM watsonx.ai Software, the environment variable configuration is extended. In addition to supporting the variables listed above for the Cloud Environment, the following environment variables are also supported:

import os

WATSONX_PASSWORD = os.environ.get("WATSONX_PASSWORD", "")
WATSONX_USERNAME = os.environ.get("WATSONX_USERNAME", "")
WATSONX_INSTANCE_ID = os.environ.get("WATSONX_INSTANCE_ID", "")

Note: All environment variables supported in the Cloud Environment are also available in the IBM watsonx.ai Software.

Config file (config.toml)

config.toml is an optional file that can be defined in template's directory. Please note, that some templates will require a correctly prepared config.toml since template's content may depends on some of the available configuration options. If a downloaded template has config.toml with placeholders, please read its description carefully and fill in required fields.

Available configuration options

Below are all the sections and options you can have in your config.toml

[cli.options]

[cli.options]
  # If true, cli `invoke` command is trying to use `ai_service.generate_stream` function for local tests, and `ai_service.generate` otherwise.
  # Default: true
  stream = true

  # Path to json file with a complete payload that will be send to proper AI service generate function.
  # Note that, the payload file will be only used when no `query` is provided when running `invoke ` command
  # Default: None
  payload_path = ""

[deployment]

If present, its fields will be used for authentication to watsonx.ai APIs.

[deployment]
  # One of the below is required.
  # To determine your `api_key`, refer to `IBM Cloud console API keys <https://cloud.ibm.com/iam/apikeys>`_.
  watsonx_apikey = "PLACEHOLDER FOR YOUR APIKEY"
  watsonx_token = "PLACEHOLDER FOR YOUR TOKEN"

  # should follow the format: `https://{REGION}.ml.cloud.ibm.com`
  watsonx_url = ""

  # Deployment space id is required to create deployment with AI service content.
  space_id = "PLACEHOLDER FOR YOUR SPACE ID"

  # variable, that is populated with last created deployment_id every time when command `watsonx-ai service new` finish successfully
  deployment_id = ""

  # The following parameters, along with the ones defined above, are supported by IBM watsonx.ai Software.
  watsonx_password = ""
  watsonx_username = ""
  watsonx_instance_id = ""

[deployment.online.parameters]

This section is recommended for users of IBM watsonx.ai for IBM Cloud and when some additional parameters need to be passed to the AI service function during deployment creation. When creating a deployment, additional parameters can be passed inside the ONLINE.PARAMETERS object to further reference in the content of the AI service function. The exact set of parameters may depend on the template used.

[deployment.online.parameters]

# Example set of parameters that must be passed during deployment creation of particular template to guarantee its correct functioning
  url = ""  # should follow the format: `https://{REGION}.ml.cloud.ibm.com`
  space_id = "PLACEHOLDER FOR YOUR SPACE ID"
  model_id = "mistralai/mistral-large"  # underlying model for inference

[deployment.software_specification]

During deployment creation, the custom software specification with template package distribution is stored for use when running AI service inference. For more details about software specifications you can find in IBM watsonx.ai Runtime Supported frameworks and software specifications documentation and Customizing deployment runtimes documentation.

[deployment.software_specification]
  # Name for derived software specification. If not provided, default one is used that will be build based on the package name: "{pkg_name}-sw-spec"
  name = ""

  # Whether to overwrite (delete existing and create new with the same name) watsonx derived software specification
  # Default: false
  overwrite = false

  # The base software specification used to deploy the AI service. The template dependencies will be installed based on the packages included in the selected base software specification
  # Default: "runtime-24.1-py3.11"
  base_sw_spec = "runtime-24.1-py3.11"

Sample flow

  1. List available templates

    watsonx-ai template list
    
  2. Create the template in my IDE

    watsonx-ai template new "base/langgraph-react-agent" "apps"
    
  3. Go into template directory

    cd apps/langgraph-react-agent
    
  4. Customize the template code and config.toml to my needs

  5. Test the template code by calling invoke:

    watsonx-ai template invoke "question"
    
  6. Create a service

    watsonx-ai service new
    
  7. Test the service

    watsonx-ai service invoke "question"
    

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ibm_watsonx_ai_cli-0.1.1.tar.gz (23.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ibm_watsonx_ai_cli-0.1.1-py3-none-any.whl (28.5 kB view details)

Uploaded Python 3

File details

Details for the file ibm_watsonx_ai_cli-0.1.1.tar.gz.

File metadata

  • Download URL: ibm_watsonx_ai_cli-0.1.1.tar.gz
  • Upload date:
  • Size: 23.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for ibm_watsonx_ai_cli-0.1.1.tar.gz
Algorithm Hash digest
SHA256 e388162babbc152f2e2544d85c5683fb21f207d72dcee236bec92e6c5315e652
MD5 d605c833174278f84bfbaad0260f0bc0
BLAKE2b-256 8e08ba255e269de542cb31a37cdf6496aca9342276509b5ed609f338fb15e218

See more details on using hashes here.

File details

Details for the file ibm_watsonx_ai_cli-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for ibm_watsonx_ai_cli-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d71b7a16f2723e936fa087f18de2ae286d9b8c3165c3c9dc2f48baa1aaeb58be
MD5 d91d84ca50721e0e8b3cd2c95496ab94
BLAKE2b-256 58ee2d87fa596ad3aa93b2ecc1519ba33173c437da29de5eae8f8e4810b713a2

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page