Toggle Huggingface Hub and Cloud.ru Repo
Project description
Switch-Hub
switch-hub — это удобная утилита для переключения между разными источниками моделей и датасетов: Hugging Face Hub,
Cloud.ru Repo. Она позволяет прозрачно работать с моделями и датасетами в разных экосистемах, не изменяя привычный
интерфейс.
Основные возможности
- Лёгкое переключение между хранилищами: Hugging Face Hub, Cloud.ru Repo.
- Минимальные изменения в коде — привычный интерфейс transformers, datasets, diffusers ....
- Гибкость для CI/CD, исследований и продакшена.
Установка
pip install switch-hub
Пример использования
from transformers import AutoModel
from switch_hub import HubSwitcher
switcher = HubSwitcher()
# Переключаемся на Hugging Face Hub
switcher.switch_to_hf()
model = AutoModel.from_pretrained('dmitryradionov/some-model')
# Переключаемся на Repo Cloud.ru и пушим модель туда
switcher.switch_to_rh()
model.push_to_hub('70e5f7a7-f6a7-4fd7-a8ea-e288150b6fb8/some-model')
# Загружаем модель из Cloud.ru Repo
model_mr = AutoModel.from_pretrained('70e5f7a7-f6a7-4fd7-a8ea-e288150b6fb8/some-model')
# Снова переключаемся на Hugging Face Hub и пушим модель назад
switcher.switch_to_hf()
model_mr.push_to_hub("dmitryradionov/some-model")
Работа с аутентификацией и токенами
Для работы с приватными и большинством публичных репозиториев, потребуется токен доступа:
- Hugging Face Hub:
HF_TOKEN - Cloud.ru Repo:
RH_TOKEN(обязателен всегда)
Как передавать токены
1. Через переменные окружения или .env файл
Рекомендуется для локальной разработки и CI/CD:
Пример .env:
HF_TOKEN=hf_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
RH_TOKEN=rh_yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy
2. Явно в конструктор HubSwitcher
from switch_hub import HubSwitcher
switcher = HubSwitcher(
hf_token="hf_xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",
rh_token="rh_yyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyyy"
)
Важно:
- RH_TOKEN обязателен для Cloud.ru Repo всегда
- HF_TOKEN обязателен только для приватных репозиториев Hugging Face, но рекомендуется указывать всегда, чтобы избежать лимитов и быть готовым к работе с приватным контентом Hugging Face
- Никогда не публикуйте свои токены в открытых источниках — используйте секреты сборки и переменные окружения
Описание ключевых методов
reset()
Восстанавливает все переменные окружения и внутренние настройки, которые были изменены при переключении между хабами.
Используйте этот метод, если нужно вручную откатить все изменения состояния, внесённые switcher'ом, например после
завершения операций с приватным registry.
Пример:
switcher.switch_to_rh()
# ... работа с приватным хабом ...
switcher.reset() # Возвращение к исходным параметрам окружения
context(mode)
Контекстный менеджер для временного переключения хаба.
После выхода из блока with окружение автоматически восстанавливается к исходному.
Пример:
from switch_hub import HubSwitcher
switcher = HubSwitcher()
with switcher.context('rh'):
# В этом блоке все операции проходят через Cloud.ru Repo
model = AutoModel.from_pretrained('cloudru_id/some-model')
# ... другие операции ...
# После выхода из блока — автоматически восстановлен Hugging Face/прежний хаб
# mode: может быть 'hf' (Hugging Face Hub) или 'rh' (Cloud.ru Repo)
Кейсы использования
- Исследование новых моделей: переключайтесь между публичными репозиториями и приватным registry.
- Экспорт и импорт моделей между облаком и Hugging Face.
- Автоматизация CI/CD пайплайнов для MLOps.
P.S. Эти способы аутентификации работают для моделей, датасетов, diffusers и других библиотек, поддерживаемых
switch-hub.
Рекомендуется всегда указывать RH_TOKEN и HF_TOKEN через переменные окружения или секреты инфраструктуры для
максимальной гибкости и безопасности.
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
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 switch_hub-0.0.3.tar.gz.
File metadata
- Download URL: switch_hub-0.0.3.tar.gz
- Upload date:
- Size: 10.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eb6f79b4cb94b21d144c24d2a08d4018c124b8333a1a0f468cc55927d47eed92
|
|
| MD5 |
7d378476e9a44b873e9721f98790c58f
|
|
| BLAKE2b-256 |
8b016c951c21f154ee8a5dfe20f8ea624ba91ea1969a0e1f1062b9e9c0b17118
|
Provenance
The following attestation bundles were made for switch_hub-0.0.3.tar.gz:
Publisher:
python-publish.yml on Gravi7ON/switch-hub
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
switch_hub-0.0.3.tar.gz -
Subject digest:
eb6f79b4cb94b21d144c24d2a08d4018c124b8333a1a0f468cc55927d47eed92 - Sigstore transparency entry: 277424345
- Sigstore integration time:
-
Permalink:
Gravi7ON/switch-hub@cfbe0d7f8bcb93b05d3021682d69c7241a75be43 -
Branch / Tag:
refs/tags/v0.0.3 - Owner: https://github.com/Gravi7ON
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@cfbe0d7f8bcb93b05d3021682d69c7241a75be43 -
Trigger Event:
release
-
Statement type:
File details
Details for the file switch_hub-0.0.3-py3-none-any.whl.
File metadata
- Download URL: switch_hub-0.0.3-py3-none-any.whl
- Upload date:
- Size: 8.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c0404e5a2c412419c01020251443868a821f65718cd2ee3ca033ad4dd73bcc71
|
|
| MD5 |
e594571d5506076999ef191c8888645c
|
|
| BLAKE2b-256 |
57dc0085208c7a58f0c34b95bf7bd02f99ebe8c1f979c37baa02b20423ace5d0
|
Provenance
The following attestation bundles were made for switch_hub-0.0.3-py3-none-any.whl:
Publisher:
python-publish.yml on Gravi7ON/switch-hub
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
switch_hub-0.0.3-py3-none-any.whl -
Subject digest:
c0404e5a2c412419c01020251443868a821f65718cd2ee3ca033ad4dd73bcc71 - Sigstore transparency entry: 277424363
- Sigstore integration time:
-
Permalink:
Gravi7ON/switch-hub@cfbe0d7f8bcb93b05d3021682d69c7241a75be43 -
Branch / Tag:
refs/tags/v0.0.3 - Owner: https://github.com/Gravi7ON
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-publish.yml@cfbe0d7f8bcb93b05d3021682d69c7241a75be43 -
Trigger Event:
release
-
Statement type: