Hub API Endpoints
Last updated
Last updated
We have open endpoints that you can use to retrieve information from the Hub as well as perform certain actions such as creating model, dataset or Space repos. We offer a wrapper Python library, huggingface_hub
, that allows easy access to these endpoints. We also provide webhooks to receive real-time incremental info about repos. Enjoy!
The base URL for those endpoints below is https://huggingface.co
. For example, to construct the /api/models
call below, one can call the URL https://huggingface.co/api/models
Want to try out our API? Try it out now on our Playground!
The following endpoints help get information about models, datasets, Spaces, and metrics stored on the Hub.
Get information from all models in the Hub. The response is paginated, use the Link
header to get the next pages. You can specify additional parameters to have more specific results.
search
: Filter based on substrings for repos and their usernames, such as resnet
or microsoft
author
: Filter models by an author or organization, such as huggingface
or microsoft
filter
: Filter based on tags, such as text-classification
or spacy
.
sort
: Property to use when sorting, such as downloads
or author
.
direction
: Direction in which to sort, such as -1
for descending, and anything else for ascending.
limit
: Limit the number of models fetched.
full
: Whether to fetch most model data, such as all tags, the files, etc.
config
: Whether to also fetch the repo config.
Payload:
Copied
This is equivalent to huggingface_hub.list_models()
.
Get all information for a specific model.
This is equivalent to huggingface_hub.model_info(repo_id, revision)
.
Gets all the available model tags hosted in the Hub.
This is equivalent to huggingface_hub.get_model_tags()
.
Get information from all datasets in the Hub. The response is paginated, use the Link
header to get the next pages. You can specify additional parameters to have more specific results.
search
: Filter based on substrings for repos and their usernames, such as pets
or microsoft
author
: Filter datasets by an author or organization, such as huggingface
or microsoft
filter
: Filter based on tags, such as task_categories:text-classification
or languages:en
.
sort
: Property to use when sorting, such as downloads
or author
.
direction
: Direction in which to sort, such as -1
for descending, and anything else for ascending.
limit
: Limit the number of datasets fetched.
full
: Whether to fetch most dataset data, such as all tags, the files, etc.
Payload:
Copied
This is equivalent to huggingface_hub.list_datasets()
.
Get all information for a specific dataset.
full
: Whether to fetch most dataset data, such as all tags, the files, etc.
Payload:
Copied
This is equivalent to huggingface_hub.dataset_info(repo_id, revision)
.
Get the list of auto-converted parquet files.
Get the nth shard of the auto-converted parquet files.
Gets all the available dataset tags hosted in the Hub.
This is equivalent to huggingface_hub.get_dataset_tags()
.
Get information from all Spaces in the Hub. The response is paginated, use the Link
header to get the next pages. You can specify additional parameters to have more specific results.
search
: Filter based on substrings for repos and their usernames, such as resnet
or microsoft
author
: Filter models by an author or organization, such as huggingface
or microsoft
filter
: Filter based on tags, such as text-classification
or spacy
.
sort
: Property to use when sorting, such as downloads
or author
.
direction
: Direction in which to sort, such as -1
for descending, and anything else for ascending.
limit
: Limit the number of models fetched.
full
: Whether to fetch most model data, such as all tags, the files, etc.
Payload:
Copied
This is equivalent to huggingface_hub.list_spaces()
.
Get all information for a specific model.
This is equivalent to huggingface_hub.space_info(repo_id, revision)
.
The following endpoints manage repository settings like creating and deleting a repository.
Create a repository. It’s a model repo by default.
Parameters:
type
: Type of repo (dataset or space; model by default).
name
: Name of repo.
organization
: Name of organization (optional).
private
: Whether the repo is private.
Payload:
Copied
This is equivalent to huggingface_hub.create_repo()
.
Delete a repository. It’s a model repo by default.
Parameters:
type
: Type of repo (dataset or space; model by default).
name
: Name of repo.
organization
: Name of organization (optional).
Payload:
Copied
This is equivalent to huggingface_hub.delete_repo()
.
Update repo visibility.
Payload:
Copied
This is equivalent to huggingface_hub.update_repo_visibility()
.
Move a repository (rename within the same namespace or transfer from user to organization).
Payload:
Copied
This is equivalent to huggingface_hub.move_repo()
.
The following endpoint gets information about a user.
Get username and organizations the user belongs to.
Payload:
Copied
This is equivalent to huggingface_hub.whoami()
.
Use Collections to group repositories from the Hub (Models, Datasets, Spaces and Papers) on a dedicated page.
You can learn more about it in the Collections guide. Collections can also be managed using the Python client (see guide).
Create a new collection on the Hub with a title, a description (optional) and a first item (optional). An item is defined by a type (model
, dataset
, space
or paper
) and an id (repo_id or paper_id on the Hub).
Payload:
Copied
This is equivalent to huggingface_hub.create_collection()
.
Return information about a collection.
This is equivalent to huggingface_hub.get_collection()
.
Update the metadata of a collection on the Hub. You can’t add or modify the items of the collection with this method. All fields of the payload are optional.
Payload:
Copied
This is equivalent to huggingface_hub.update_collection_metadata()
.
Return a collection. This is a non-revertible operation. A deleted collection cannot be restored.
This is equivalent to huggingface_hub.delete_collection()
.
Add an item to a collection. An item is defined by a type (model
, dataset
, space
or paper
) and an id (repo_id or paper_id on the Hub). A note can also be attached to the item (optional).
Payload:
Copied
This is equivalent to huggingface_hub.add_collection_item()
.
Update an item in a collection. You must know the item object id which is different from the repo_id/paper_id provided when adding the item to the collection. The item_id
can be retrieved by fetching the collection.
You can update the note attached to the item or the position of the item in the collection. Both fields are optional.
Copied
This is equivalent to huggingface_hub.update_collection_item()
.
Remove an item from a collection. You must know the item object id which is different from the repo_id/paper_id provided when adding the item to the collection. The item_id
can be retrieved by fetching the collection.
This is equivalent to huggingface_hub.delete_collection_item()
.