Skip to main content

A Python Client SDK for the Linkup API

Project description

🚀 Linkup Python SDK

PyPI version License: MIT PyPI - Downloads Discord

A Python SDK for the Linkup API, allowing easy integration with Linkup's services in any Python application. 🐍

Checkout the official API documentation and SDK documentation for additional details on how to benefit from Linkup services to the full extent. 📝

🌟 Features

  • Simple and intuitive API client.
  • 🔍 Supports Linkup search, fetch, research, and task workflows.
  • Support synchronous and asynchronous calls.
  • 🔒 Handle authentication and request management.
  • 💳 Built-in x402 payment protocol support for on-chain payments.

📦 Installation

Simply install the Linkup Python SDK as any Python package, for instance using pip:

pip install linkup-sdk

To use the x402 payment protocol (on-chain payments via EVM), install the optional x402 extras:

pip install linkup-sdk[x402]

🛠️ Usage

Setting Up Your Environment

  1. 🔑 Obtain an API Key:

    Sign up on Linkup to get your API key.

  2. ⚙️ Set-up the API Key:

    Option 1: Export the LINKUP_API_KEY environment variable in your shell before using the Python SDK.

    export LINKUP_API_KEY=<your-linkup-api-key>
    

    Option 2: Set the LINKUP_API_KEY environment variable directly within Python, using for instance os.environ or python-dotenv with a .env file (python-dotenv needs to be installed separately in this case), before creating the Linkup Client.

    import os
    import linkup
    
    os.environ["LINKUP_API_KEY"] = "<your-linkup-api-key>"
    # or dotenv.load_dotenv()
    client = linkup.Client()
    ...
    

    Option 3: Pass the Linkup API key to the Linkup Client when creating it.

    import linkup
    
    client = linkup.Client(api_key="<your-linkup-api-key>")
    ...
    

📋 Examples

📝 Search

The search function can be used to performs web searches. It supports three different complexity modes, through the depth parameter:

  • "fast" (beta), for sub-second responses to simple, focused queries (must be keyword-based)
  • "standard", for single-iteration agentic search that can interpret the query, run parallel sub-searches, and scrape one URL while remaining fast
  • "deep", for slower, more agentic and complex responses, suited to more complex queries (e.g. "What is the company profile of LangChain accross the last few years, and how does it compare to its concurrents?")

The search function also supports three output types, through the output_type parameter:

  • with "searchResults", the search will return a list of relevant documents
  • with "sourcedAnswer", the search will return a concise answer with sources
  • with "structured", the search will return a structured output according to a user-defined object schema
import linkup

client = linkup.Client()  # API key can be read from the environment variable or passed as an argument
search_response: linkup.SourcedAnswer = client.search(
    query="What are the 3 major events in the life of Abraham Lincoln?",
    depth="deep",  # "fast" (beta), "standard", or "deep"
    output_type="sourcedAnswer",  # "searchResults" or "sourcedAnswer" or "structured"
    structured_output_schema=None,  # must be filled if output_type is "structured"
)
print(search_response.model_dump())

Which prints:

{
  answer="The three major events in the life of Abraham Lincoln are: 1. ...",
  sources=[
    {
      "name": "HISTORY",
      "url": "https://www.history.com/topics/us-presidents/abraham-lincoln",
      "snippet": "Abraham Lincoln - Facts & Summary - HISTORY ...",
      "favicon": "https://www.history.com/favicon.ico",
    },
    ...
  ]
}

Check the code or the official documentation for the detailed list of available parameters.

🪝 Fetch

The fetch function can be used to retrieve the content of a given web page in a cleaned up markdown format.

You can use the render_js flag to execute the JavaScript code of the page before returning the content, and ask to include_raw_html to the response if you feel like it.

import linkup

client = linkup.Client()  # API key can be read from the environment variable or passed as an argument
fetch_response: linkup.FetchResponse = client.fetch(
    url="https://docs.linkup.so",
    render_js=False,
    include_raw_html=True,
)
print(fetch_response.model_dump())

Which prints:

{
  markdown="Get started for free, no credit card required...",
  raw_html="<!DOCTYPE html><html lang=\"en\"><head>...</head><body>...</body></html>"
}

Check the code or the official documentation for the detailed list of available parameters.

🧠 Research

The research function creates an asynchronous research task. You can then use get_research or list_research to inspect it later.

import linkup

client = linkup.Client()
research_task: linkup.ResearchTask = client.research(
    query="What changed in the AI browser market this quarter?",
    output_type="sourcedAnswer",
)
print(research_task.id)

🗂️ Tasks

The create_tasks function lets you submit mixed search, fetch, and research jobs in a single batch, then inspect them through get_task or list_tasks.

import linkup

client = linkup.Client()
tasks = client.create_tasks(
    [
        linkup.SearchTaskInput(
            query="Linkup latest product updates",
            depth="deep",
            output_type="sourcedAnswer",
        ),
        linkup.FetchTaskInput(
            url="https://docs.linkup.so",
        ),
    ]
)
print([task.id for task in tasks])

⌛ Asynchronous Calls

All the Linkup main functions come with an asynchronous counterpart, with the same behavior and the same name prefixed by async_ (e.g. async_search for search). This should be favored in production use cases to avoid blocking the main thread while waiting for the Linkup API to respond. This makes possible to call the Linkup API several times concurrently for instance.

import asyncio

import linkup

async def main() -> None:
    client = linkup.Client()  # API key can be read from the environment variable or passed as an argument
    search_response: linkup.SourcedAnswer = await client.async_search(
        query="What are the 3 major events in the life of Abraham Lincoln?",
        depth="deep",  # "fast" (beta), "standard", or "deep"
        output_type="sourcedAnswer",  # "searchResults" or "sourcedAnswer" or "structured"
        structured_output_schema=None,  # must be filled if output_type is "structured"
    )
    print(search_response.model_dump())

asyncio.run(main())

Which prints:

{
  answer="The three major events in the life of Abraham Lincoln are: 1. ...",
  sources=[
    {
      "name": "HISTORY",
      "url": "https://www.history.com/topics/us-presidents/abraham-lincoln",
      "snippet": "Abraham Lincoln - Facts & Summary - HISTORY ..."
      "favicon": "https://www.history.com/favicon.ico",
    },
    ...
  ]
}

💳 x402 Payment Protocol

The SDK supports the x402 payment protocol, allowing clients to automatically handle HTTP 402 responses by signing and retrying requests with on-chain payments via EVM-compatible networks (currently Base). This can be used as an alternative to API key authentication.

Create an eth_account LocalAccount compatible with Base (Ethereum):

from eth_account import Account

account = Account.from_key("<YOUR WALLET PRIVATE KEY>")
from eth_account import Account

Account.enable_unaudited_hdwallet_features()
account = Account.from_mnemonic("<YOUR MNEMONIC PHRASE>")

Then pass it to create_x402_signer and use the Linkup client:

import linkup
from linkup.x402 import create_x402_signer

signer = create_x402_signer(account)
client = linkup.Client(x402_signer=signer)

result = client.search(
    query="What is x402?",
    depth="standard",
    output_type="sourcedAnswer",
)
print(result.answer)

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

linkup_sdk-0.18.3.tar.gz (196.4 kB view details)

Uploaded Source

Built Distribution

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

linkup_sdk-0.18.3-py3-none-any.whl (20.9 kB view details)

Uploaded Python 3

File details

Details for the file linkup_sdk-0.18.3.tar.gz.

File metadata

  • Download URL: linkup_sdk-0.18.3.tar.gz
  • Upload date:
  • Size: 196.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for linkup_sdk-0.18.3.tar.gz
Algorithm Hash digest
SHA256 92e5736ebdc9bb9a646e6e64cc4cddcc3c7825f35f299fbd0c884a0aa45968ac
MD5 b7d541f5e9a461b7dccbc3772234c7c9
BLAKE2b-256 b09758856521ae7396e4f5e913e8c5bec62303c458e129514ab2d8591c3f75aa

See more details on using hashes here.

Provenance

The following attestation bundles were made for linkup_sdk-0.18.3.tar.gz:

Publisher: release.yml on LinkupPlatform/linkup-python-sdk

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

File details

Details for the file linkup_sdk-0.18.3-py3-none-any.whl.

File metadata

  • Download URL: linkup_sdk-0.18.3-py3-none-any.whl
  • Upload date:
  • Size: 20.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for linkup_sdk-0.18.3-py3-none-any.whl
Algorithm Hash digest
SHA256 a42d54087bd727a5bb74fea5a1b425c01dc2bdf547226714061edb21a922b692
MD5 47e5d9dcf7a195501aeb92debbbcc4c9
BLAKE2b-256 8ee2b280fc0f79417dac15f766613d820d94b77b8f27dafacc1d8adc969c1f26

See more details on using hashes here.

Provenance

The following attestation bundles were made for linkup_sdk-0.18.3-py3-none-any.whl:

Publisher: release.yml on LinkupPlatform/linkup-python-sdk

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