Skip to main content

Jentic SDK for the discovery and execution of APIs and workflows

Project description

Jentic SDK

Jentic SDK is a comprehensive library for discovery and execution of APIs and workflows.

The Jentic SDK is backed by the data in the Open Agentic Knowledge (OAK) repository.

Core API & Use Cases

The main entry point is the Jentic class.

LLM Tool Definition & Execution

A typical agent loop with tool use looks like this:

from jentic import Jentic

class MyAgent:
    def __init__(self):
        self.jentic = Jentic()
        self.jentic_tools = self.jentic.generate_llm_tool_definitions("anthropic")

    async def process_message(self, user_message):

        # Pass your tool definitions here, generated by the Jentic SDK.
        response = self.client.messages.create(
            model='claude-3-5-sonnet-latest',  
            messages=messages,
            tools=self.jentic_tools, 
        )
        
        while response.stop_reason == "tool_use":
            tool_use = next(block for block in response.content if block.type == "tool_use")
            tool_name = tool_use.name
            tool_input = tool_use.input

            # Execute the tool
            tool_result = await self.jentic.run_llm_tool(
                tool_name,
                tool_input 
            )

Components

agent_runtime

A library for generating, managing, and executing LLM-compatible tools from Arazzo workflows and OpenAPI operations.

Features:

  • Generate dynamic tool definitions for OpenAI and Anthropic LLMs from project workflows and API operations
  • Execute workflows and operations as tools via a unified interface
  • Provide runtime classes for tool management (AgentToolManager), tool specification (LLMToolSpecManager), and execution (TaskExecutor)
  • Return standardized results for workflow and operation execution

api

A client for the Jentic API Knowledge Hub.

Set JENTIC_API_URL to set the base URL for the API hub client for local testing or testing against the development environment.

Installation

For Development

To install the package in development mode:

# From the current directory
pip install -e .

Then you can import it in your projects:

import jentic

You can also import it to other projects by referencing the package directory by specifying the following in your pyproject.toml:

dependencies = [
    "jentic @ file:///path/to/jentic/sdk"
]

For Production

pip install jentic

Testing

# Run all tests for jentic
pdm run test

Linting & Formatting

# Run all linting for jentic
pdm run lint

License

Proprietary - Jentic

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

jentic-0.7.4.tar.gz (27.8 kB view details)

Uploaded Source

Built Distribution

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

jentic-0.7.4-py3-none-any.whl (22.2 kB view details)

Uploaded Python 3

File details

Details for the file jentic-0.7.4.tar.gz.

File metadata

  • Download URL: jentic-0.7.4.tar.gz
  • Upload date:
  • Size: 27.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for jentic-0.7.4.tar.gz
Algorithm Hash digest
SHA256 9785449c48a65ea7d289f05d3508334f89b0271cf4a8e427880cab7c31070934
MD5 e6988446770e27f466d14b458c80b9de
BLAKE2b-256 b9977b8f5849512bd499f0db849b5cbf05800f751db42382515adfef8d6a826a

See more details on using hashes here.

Provenance

The following attestation bundles were made for jentic-0.7.4.tar.gz:

Publisher: jentic-sdk-pypi.yaml on jentic/jentic-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jentic-0.7.4-py3-none-any.whl.

File metadata

  • Download URL: jentic-0.7.4-py3-none-any.whl
  • Upload date:
  • Size: 22.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for jentic-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 00f0f5390f88b3c10ff53a15b1a5e148f0231eefad6b72e27d86e247f937a2f2
MD5 b075fedcc86e21c9ccadfd93a60b9a39
BLAKE2b-256 5e6589180c334ead91943cae81e4f1e7a02392dd9b6b9ee00708b664d2d4f85b

See more details on using hashes here.

Provenance

The following attestation bundles were made for jentic-0.7.4-py3-none-any.whl:

Publisher: jentic-sdk-pypi.yaml on jentic/jentic-tools

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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