Skip to main content

Gemini helper wrappers for Sigil Python SDK

Project description

Sigil Python Provider Helper: Gemini

sigil-sdk-gemini provides strict Gemini Models wrappers and mappers for Sigil.

Installation

pip install sigil-sdk sigil-sdk-gemini google-genai

Public API

  • Wrappers:
    • models.generate_content(...)
    • models.generate_content_async(...)
    • models.generate_content_stream(...)
    • models.generate_content_stream_async(...)
    • models.embed_content(...)
    • models.embed_content_async(...)
  • Mappers:
    • models.from_request_response(...)
    • models.from_stream(...)
    • models.embedding_from_response(...)

Wrapper Mode (Sync)

from google.genai import types as genai_types
from sigil_sdk import Client, ClientConfig
from sigil_sdk_gemini import GeminiOptions, models

client = Client(ClientConfig())

model = "gemini-2.5-pro"
contents = [genai_types.Content(role="user", parts=[genai_types.Part(text="Hello")])]
config = genai_types.GenerateContentConfig(max_output_tokens=256)

response = models.generate_content(
    client,
    model,
    contents,
    config,
    lambda req_model, req_contents, req_config: gemini_client.models.generate_content(
        model=req_model,
        contents=req_contents,
        config=req_config,
    ),
    GeminiOptions(conversation_id="conv-1", agent_name="assistant", agent_version="1.0.0"),
)

Wrapper Mode (Stream)

from sigil_sdk_gemini import GeminiStreamSummary, models

summary = models.generate_content_stream(
    client,
    model,
    contents,
    config,
    lambda req_model, req_contents, req_config: GeminiStreamSummary(
        responses=list(gemini_client.models.generate_content_stream(
            model=req_model,
            contents=req_contents,
            config=req_config,
        ))
    ),
)

Mapper Mode

generation = models.from_request_response(model, contents, config, response)
stream_generation = models.from_stream(model, contents, config, summary)

Embedding example

embedding_response = models.embed_content(
    client,
    "gemini-embedding-001",
    contents,
    None,
    lambda req_model, req_contents, req_config: gemini_client.models.embed_content(
        model=req_model,
        contents=req_contents,
        config=req_config,
    ),
)

Raw Provider Artifacts (Opt-In)

options = GeminiOptions(raw_artifacts=True)

Raw artifacts are default OFF and should only be enabled for diagnostics.

Provider metadata mapping

Gemini-specific fields are mapped as follows:

  • usage.thoughts_token_count -> normalized usage.reasoning_tokens
  • usage.tool_use_prompt_token_count -> metadata sigil.gen_ai.usage.tool_use_prompt_tokens
  • config.thinking_config.thinking_budget -> metadata sigil.gen_ai.request.thinking.budget_tokens
  • config.thinking_config.thinking_level -> metadata sigil.gen_ai.request.thinking.level

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

sigil_sdk_gemini-0.1.5.tar.gz (11.1 kB view details)

Uploaded Source

Built Distribution

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

sigil_sdk_gemini-0.1.5-py3-none-any.whl (8.5 kB view details)

Uploaded Python 3

File details

Details for the file sigil_sdk_gemini-0.1.5.tar.gz.

File metadata

  • Download URL: sigil_sdk_gemini-0.1.5.tar.gz
  • Upload date:
  • Size: 11.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for sigil_sdk_gemini-0.1.5.tar.gz
Algorithm Hash digest
SHA256 eca20b49a6f2e74239fbcc5f83d95caa9105af509baff80d2e019b0991b1c222
MD5 29b2b0735184fd046fee2826a7f1de0a
BLAKE2b-256 4676ff02bdd2b874325ee47558925df97d638c927fc41c19aec68ce842de5941

See more details on using hashes here.

Provenance

The following attestation bundles were made for sigil_sdk_gemini-0.1.5.tar.gz:

Publisher: python-sdks-publish.yml on grafana/sigil-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 sigil_sdk_gemini-0.1.5-py3-none-any.whl.

File metadata

File hashes

Hashes for sigil_sdk_gemini-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 8b34bbbad95eb2f6c2ac40fc12b15bed07a46b696e2f23bd88f73d1e4dfec711
MD5 c33160137e0da54d3ce9677e79f188ac
BLAKE2b-256 edb3e64e02d9b5100911cca73042c093ec6f88e91e8f1d356f9412a7a98016cb

See more details on using hashes here.

Provenance

The following attestation bundles were made for sigil_sdk_gemini-0.1.5-py3-none-any.whl:

Publisher: python-sdks-publish.yml on grafana/sigil-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