Skip to content

Configuration

githubkit is highly configurable, you can change the default config by passing config options to GitHub:

from githubkit import GitHub

github = GitHub(
    base_url="https://api.github.com/",
    accept_format=None,
    previews=None,
    user_agent="GitHubKit/Python",
    follow_redirects=True,
    timeout=None,
    cache_strategy=None,
    http_cache=True,
    throttler=None,
    auto_retry=True,
    rest_api_validate_body=True,
)

Or, you can pass the config object directly (not recommended):

import httpx
from githubkit import GitHub, Config
from githubkit.retry import RETRY_DEFAULT
from githubkit.cache import DEFAULT_CACHE_STRATEGY

config = Config(
    base_url="https://api.github.com/",
    accept="application/vnd.github+json",
    user_agent="GitHubKit/Python",
    follow_redirects=True,
    timeout=httpx.Timeout(None),
    cache_strategy=DEFAULT_CACHE_STRATEGY,
    http_cache=True,
    throttler=None,
    auto_retry=RETRY_DEFAULT,
    rest_api_validate_body=True,
)

github = GitHub(config=config)

Options

base_url

The base_url option is used to set the base URL of the GitHub API. If you are using GitHub Enterprise Server, you need to include the /api/v3/ path in the base URL.

accept_format, previews

The accept_format and previews are used to set the default Accept header. By default, githubkit uses application/vnd.github+json. You can find more details in GitHub API docs.

The accept_format option could be set to PARAM+json, such as raw+json.

The previews option could be set to a list of preview features, such as ["starfox"]. You can find the preview feature names in the GitHub API docs. Note that you do not need to include the -preview suffix in the preview feature name.

user_agent

The user_agent option is used to set the User-Agent header. By default, githubkit uses GitHubKit/Python.

follow_redirects

The follow_redirects option is used to enable or disable the HTTP redirect following feature. By default, githubkit follows the redirects.

timeout

The timeout option is used to set the request timeout. You can pass a float, None or httpx.Timeout to this field. By default, the requests will never timeout. See Timeout for more information.

cache_strategy

The cache_strategy option defines how to cache the tokens or http responses. You can provide a githubkit built-in cache strategy or a custom one that implements the BaseCacheStrategy interface. By default, githubkit uses the MemCacheStrategy to cache the data in memory.

Available built-in cache strategies:

  • MemCacheStrategy: Cache the data in memory.

    Normally, you do not need to specifically use this cache strategy. It is used by default.

    from githubkit.cache import DEFAULT_CACHE_STRATEGY, MemCacheStrategy
    
    # Use the default cache strategy
    github = GitHub(cache_strategy=DEFAULT_CACHE_STRATEGY)
    # Or you can initialize another MemCacheStrategy instance
    # this will create a new cache instance and not share the cache with the global one
    github = GitHub(cache_strategy=MemCacheStrategy())
    
  • RedisCacheStrategy: Cache the data in Redis (Sync only).

    To cache the data in Redis (Sync only), you need to provide a redis client to the RedisCacheStrategy. For example:

    from redis import Redis
    
    github = GitHub(
        cache_strategy=RedisCacheStrategy(
            client=Redis(host="localhost", port=6379)
        )
    )
    

    Note that using this sync only cache strategy will cause the GitHub instance to be sync only.

  • AsyncRedisCacheStrategy: Cache the data in Redis (Async only).

    To cache the data in Redis (Async only), you need to provide an async redis client to the AsyncRedisCacheStrategy. For example:

    from redis.asyncio import Redis
    
    github = GitHub(
        cache_strategy=AsyncRedisCacheStrategy(
            client=Redis(host="localhost", port=6379)
        )
    )
    

    Note that using this async only cache strategy will cause the GitHub instance to be async only.

http_cache

The http_cache option enables the http caching feature powered by Hishel for HTTPX. GitHub API limits the number of requests that you can make within a specific amount of time. This feature is useful to reduce the number of requests to GitHub API and avoid hitting the rate limit.

throttler

The throttler option is used to control the request concurrency to avoid hitting the rate limit. You can provide a githubkit built-in throttler or a custom one that implements the BaseThrottler interface. By default, githubkit uses the LocalThrottler to control the request concurrency.

Available built-in throttlers:

  • LocalThrottler: Control the request concurrency in the local process / event loop.

    from githubkit.throttling import LocalThrottler
    
    github = GitHub(throttler=LocalThrottler(100))
    

auto_retry

The auto_retry option enables request retrying when rate limit exceeded and server error encountered. See Auto Retry for more infomation.

rest_api_validate_body

The rest_api_validate_body option is used to enable or disable the rest API request body validation. By default, githubkit validates the input data against the GitHub API schema. If you do not want to validate the input data, you can set this option to False.