Skip to main content

Ads for AI applications. Enabling the Freemium model for the AI era.

Project description

Ads4GPTs Langchain Toolkit

This is the LangChain toolkit for Ads4GPTs.

A Python package that integrates Ads4GPTs functionalities into LangChain applications, allowing for seamless retrieval of relevant advertisements based on contextual input.


Table of Contents


Introduction

Ads4GPTs LangChain Integration is a Python package designed to seamlessly incorporate Ads4GPTs functionalities into your LangChain and LangGraph applications. It provides tools and utilities to retrieve contextually relevant advertisements, leveraging the power of LangChain's agentic framework.

Whether you're building a chatbot, a recommendation system, or any application that can benefit from targeted ads, this package offers a robust and production-ready solution.

Show Your Support

If you find our ADS4GPTs project helpful, please give it a star ⭐️

GitHub Stars


Features

  • Easy Integration: Quickly integrate ad retrieval capabilities into your LangChain agents.
  • Contextual Ad Retrieval: Fetch relevant ads based on the provided context to enhance user engagement.
  • Asynchronous Support: Both synchronous and asynchronous operations are supported for flexibility.
  • Robust Error Handling: Comprehensive error handling and logging for reliable production deployments.

Installation

Using pip

You can install the package directly from PyPI:

pip install ads4gpts-langchain

From Source

Alternatively, you can install the package from source:

git clone https://github.com/ADS4GPTs/ads4gpts.git
cd ads4gpts/libs/python-sdk/ads4gpts-langchain
pip install .

Usage

Prerequisites

  • Python 3.11+
  • (Optional) OpenAI Account and API Key
    • In order to use the ads4gpts_agent you
    • Sign up at OpenAI and obtain an API key.
  • Ads4GPTs API Key

Environment Variables

The package requires certain environment variables for API authentication:

  • OPENAI_API_KEY: Your OpenAI API key.
  • ADS4GPTS_API_KEY: Your Ads4GPTs API key.

Set them in your environment:

export OPENAI_API_KEY='your-openai-api-key'
export ADS4GPTS_API_KEY='your-ads4gpts-api-key'

Alternatively, you can pass the API keys directly when initializing classes or set up a .env file.

Initialization

Import the necessary classes and functions in your Python script:

from ads4gpts_langchain import Ads4gptsInlineSponsoredResponsesTool, Ads4gptsSuggestedPromptsTool, Ads4gptsToolkit

Examples

Example 1: Using Ads4GPTsTool Directly

from ads4gpts_langchain import Ads4gptsInlineSponsoredResponsesTool

# Instantiate the tool (API key retrieved from environment variable)
ads_tool = Ads4gptsInlineSponsoredResponsesTool(ads4gpts_api_key="your-ads4gpts-api-key")

# Retrieve ads synchronously
ads = ads_tool._run(
    id="test_id",
    user={"gender": "female", "age_range": "25-34", "persona": "test_persona"},
    ad_recommendation="test_recommendation",
    undesired_ads="test_undesired_ads",
    context="Looking for the latest smartphone deals",
    num_ads=2,
    style="neutral"
)
print(ads)

# Retrieve ads asynchronously
import asyncio

async def fetch_ads():
    ads = await ads_tool._arun(
        id="test_id",
        user={"gender": "female", "age_range": "25-34", "persona": "test_persona"},
        ad_recommendation="test_recommendation",
        undesired_ads="test_undesired_ads",
        context="Best travel packages to Europe",
        num_ads=3,
        style="neutral"
    )
    print(ads)

asyncio.run(fetch_ads())

### Using the Toolkit

from ads4gpts_langchain import Ads4gptsToolkit

# Initialize the toolkit
toolkit = Ads4gptsToolkit(ads4gpts_api_key="your-ads4gpts-api-key")

# Get the list of tools
tools = toolkit.get_tools()

# Use the tool from the toolkit
ads = tools[0]._run(
    id="test_id",
    user={"gender": "female", "age_range": "25-34", "persona": "test_persona"},
    ad_recommendation="test_recommendation",
    undesired_ads="test_undesired_ads",
    context="Healthy recipes and cooking tips",
    num_ads=1,
    style="neutral"
)
print(ads)

Examples for using them in your LangChain and LangGraph application exist in the examples folder of the parent repo.

Contributing

Contributions are welcome! Please follow these steps:

  1. Fork the Repository: Click the "Fork" button at the top right of the repository page.
  2. Clone Your Fork:
git clone git@github.com:ADS4GPTs/ads4gpts.git
  1. Create a Branch:
git checkout -b feature/your-feature-name
  1. Make Changes: Implement your feature or bug fix.
  2. Run Tests: Ensure all tests pass.
pip install pytest pytest-asyncio
python -m unittest discover tests

Formal tests are still under development. 6. Commit Changes:

git commit -am 'Add your commit message here'
  1. Push to Your Fork:
git push origin feature/your-feature-name
  1. Open a Pull Request: Navigate to the original repository and click "New pull request".

License

This project is licensed under the License of the Ads4GPTs repository.

Contact

For issues and feature requests, please use the GitHub issues page.

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

ads4gpts_langchain-0.1.4.tar.gz (11.8 kB view details)

Uploaded Source

Built Distribution

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

ads4gpts_langchain-0.1.4-py3-none-any.whl (11.0 kB view details)

Uploaded Python 3

File details

Details for the file ads4gpts_langchain-0.1.4.tar.gz.

File metadata

  • Download URL: ads4gpts_langchain-0.1.4.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for ads4gpts_langchain-0.1.4.tar.gz
Algorithm Hash digest
SHA256 46668c98dfd26b92f929426c94e66562fa6a80088b9a4b7dc314003327523d03
MD5 b3e3960081a39dba76d63ceb01883b75
BLAKE2b-256 478ff3b554eb6d9c758f6e2221d6bac86e08f178d398960b99f12aca159ec91a

See more details on using hashes here.

File details

Details for the file ads4gpts_langchain-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for ads4gpts_langchain-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 5846d13dfddb3f370709399d5764df37ee9cc8c256e2a220fc60a0f0cff6d411
MD5 8871d18cd9426f00cfe9b1331c99d4d6
BLAKE2b-256 1e8251214c2e9d01c7622c0a03899e8e238393bd2225a17ca2e5c729abe534f9

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