Google Gemini API plugin for the cjm-transcription-plugin-system library - provides speech-to-text transcription with configurable model selection and parameter control.
Project description
cjm-transcription-plugin-gemini
Install
pip install cjm_transcription_plugin_gemini
Project Structure
nbs/
├── meta.ipynb # Metadata introspection for the Gemini plugin used by cjm-ctl to generate the registration manifest.
└── plugin.ipynb # Plugin implementation for Google Gemini API transcription
Total: 2 notebooks across 1 directory
Module Dependencies
graph LR
meta[meta<br/>Metadata]
plugin[plugin<br/>Gemini Plugin]
plugin --> meta
1 cross-module dependencies detected
CLI Reference
No CLI commands found in this project.
Module Overview
Detailed documentation for each module in the project:
Metadata (meta.ipynb)
Metadata introspection for the Gemini plugin used by cjm-ctl to generate the registration manifest.
Import
from cjm_transcription_plugin_gemini.meta import (
get_plugin_metadata
)
Functions
def get_plugin_metadata() -> Dict[str, Any]: # Plugin metadata for manifest generation
"""Return metadata required to register this plugin with the PluginManager."""
# Calculate default DB path relative to the environment
base_path = os.path.dirname(os.path.dirname(sys.executable))
data_dir = os.path.join(base_path, "data")
db_path = os.path.join(data_dir, "gemini_transcriptions.db")
# Ensure data directory exists
os.makedirs(data_dir, exist_ok=True)
return {
"name": "cjm-transcription-plugin-gemini",
"Return metadata required to register this plugin with the PluginManager."
Gemini Plugin (plugin.ipynb)
Plugin implementation for Google Gemini API transcription
Import
from cjm_transcription_plugin_gemini.plugin import (
GeminiPluginConfig,
GeminiPlugin
)
Functions
@patch
def _get_api_key(
self:GeminiPlugin
) -> str: # The API key string
"Get API key from config or environment."
@patch
def _refresh_available_models(
self:GeminiPlugin
) -> List[str]: # List of available model names
"Fetch and filter available models from Gemini API."
@patch
def _update_max_tokens_for_model(
self:GeminiPlugin,
model_name: str # Model name to update tokens for
) -> None
"Update max_output_tokens config based on the model's token limit."
@patch
def update_config(
self:GeminiPlugin,
config: Union[Dict[str, Any], GeminiPluginConfig] # New configuration values
) -> None
"Update plugin configuration, adjusting max_tokens if model changes."
@patch
def _prepare_audio(
self:GeminiPlugin,
audio: Union[AudioData, str, Path] # Audio data object or path to audio file
) -> Tuple[Path, bool]: # Tuple of (processed audio path, whether temp file was created)
"Prepare audio file for upload."
@patch
def _upload_audio_file(
self:GeminiPlugin,
audio_path: Path # Path to audio file to upload
) -> Any: # Uploaded file object
"Upload audio file to Gemini API."
@patch
def _delete_uploaded_file(
self:GeminiPlugin,
file_name: str # Name of file to delete
) -> None
"Delete an uploaded file from Gemini API."
@patch
def get_available_models(
self:GeminiPlugin
) -> List[str]: # List of available model names
"Get list of available audio-capable models."
@patch
def get_model_info(
self:GeminiPlugin,
model_name: Optional[str] = None # Model name to get info for, defaults to current model
) -> Dict[str, Any]: # Dict with model information
"Get information about a specific model including token limits."
@patch
def supports_streaming(
self:GeminiPlugin
) -> bool: # True if streaming is supported
"Check if this plugin supports streaming transcription."
@patch
def execute_stream(
self:GeminiPlugin,
audio: Union[AudioData, str, Path], # Audio data object or path to audio file
**kwargs # Additional arguments to override config
) -> Generator[str, None, TranscriptionResult]: # Yields text chunks, returns final result
"Stream transcription results chunk by chunk."
Classes
@dataclass
class GeminiPluginConfig:
"Configuration for Gemini transcription plugin."
model: str = field(...)
api_key: Optional[str] = field(...)
prompt: str = field(...)
temperature: float = field(...)
top_p: float = field(...)
max_output_tokens: int = field(...)
seed: Optional[int] = field(...)
response_mime_type: str = field(...)
downsample_audio: bool = field(...)
downsample_rate: int = field(...)
downsample_channels: int = field(...)
safety_settings: str = field(...)
auto_refresh_models: bool = field(...)
model_filter: List[str] = field(...)
use_file_upload: bool = field(...)
use_streaming: bool = field(...)
delete_uploaded_files: bool = field(...)
class GeminiPlugin:
def __init__(self):
"""Initialize the Gemini plugin with default configuration."""
self.logger = logging.getLogger(f"{__name__}.{type(self).__name__}")
self.config: GeminiPluginConfig = None
"Google Gemini API transcription plugin."
def __init__(self):
"""Initialize the Gemini plugin with default configuration."""
self.logger = logging.getLogger(f"{__name__}.{type(self).__name__}")
self.config: GeminiPluginConfig = None
"Initialize the Gemini plugin with default configuration."
def name(self) -> str: # Plugin name identifier
"""Return the plugin name identifier."""
return "gemini"
@property
def version(self) -> str: # Plugin version string
"Return the plugin name identifier."
def version(self) -> str: # Plugin version string
"""Return the plugin version string."""
return "1.0.0"
@property
def supported_formats(self) -> List[str]: # List of supported audio formats
"Return the plugin version string."
def supported_formats(self) -> List[str]: # List of supported audio formats
"""Return list of supported audio file formats."""
return ["wav", "mp3", "aiff", "aac", "ogg", "flac"]
def get_current_config(self) -> Dict[str, Any]: # Current configuration as dictionary
"Return list of supported audio file formats."
def get_current_config(self) -> Dict[str, Any]: # Current configuration as dictionary
"""Return current configuration state."""
if not self.config
"Return current configuration state."
def get_config_schema(self) -> Dict[str, Any]: # JSON Schema for configuration
"""Return JSON Schema for UI generation."""
return dataclass_to_jsonschema(GeminiPluginConfig)
@staticmethod
def get_config_dataclass() -> GeminiPluginConfig: # Configuration dataclass
"Return JSON Schema for UI generation."
def get_config_dataclass() -> GeminiPluginConfig: # Configuration dataclass
"""Return dataclass describing the plugin's configuration options."""
return GeminiPluginConfig
def initialize(
self,
config: Optional[Any] = None # Configuration dataclass, dict, or None
) -> None
"Return dataclass describing the plugin's configuration options."
def initialize(
self,
config: Optional[Any] = None # Configuration dataclass, dict, or None
) -> None
"Initialize or re-configure the plugin (idempotent)."
def execute(
self,
audio: Union[AudioData, str, Path], # Audio data object or path to audio file
**kwargs # Additional arguments to override config
) -> TranscriptionResult: # Transcription result object
"Transcribe audio using Gemini."
def is_available(self) -> bool: # True if the Gemini API is available
"""Check if Gemini API is available."""
return GEMINI_AVAILABLE
def cleanup(
self
) -> None
"Check if Gemini API is available."
def cleanup(
self
) -> None
"Clean up resources."
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cjm_transcription_plugin_gemini-0.0.11.tar.gz.
File metadata
- Download URL: cjm_transcription_plugin_gemini-0.0.11.tar.gz
- Upload date:
- Size: 19.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b52b7b13df8a9a4ef7ac8eaba7ec0f069de1921c3c834756e0b3d2dd70a404d0
|
|
| MD5 |
8b5f3a952cfb065468c21ab180895824
|
|
| BLAKE2b-256 |
e33cb64403e97d8d4ba01695ecfc803a4f3c90a880957d7d491a71c71af897e0
|
File details
Details for the file cjm_transcription_plugin_gemini-0.0.11-py3-none-any.whl.
File metadata
- Download URL: cjm_transcription_plugin_gemini-0.0.11-py3-none-any.whl
- Upload date:
- Size: 18.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
17e5fba24fc5f009c389c7f4a6d7de08ea292803f2612f73e7dd2362d59e3059
|
|
| MD5 |
9b0aa529a20f690577b2f78344541583
|
|
| BLAKE2b-256 |
df3d51be17a58c7efd6977b46ddf9b12dfeb7cbd215a489c52f5ff6f15827ef3
|