-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add show_stdout flag set huggingface environment variables from within facehuggershield
- Loading branch information
Showing
4 changed files
with
348 additions
and
4 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
from . import huggingface |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
58 changes: 58 additions & 0 deletions
58
src/facehuggershield/huggingface/set_environment_variables.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
import os | ||
from .settings import ( | ||
HF_HUB_DISABLE_TELEMETRY, | ||
HF_HOME, | ||
HF_ENDPOINT, | ||
HF_INFERENCE_ENDPOINT, | ||
HF_HUB_DOWNLOAD_TIMEOUT, | ||
HF_HUB_ETAG_TIMEOUT, | ||
HF_HUB_DISABLE_PROGRESS_BARS, | ||
HF_HUB_DISABLE_SYMLINKS_WARNING, | ||
HF_HUB_DISABLE_EXPERIMENTAL_WARNING, | ||
HF_ASSETS_CACHE, | ||
HF_TOKEN, | ||
HF_HUB_VERBOSITY, | ||
HF_HUB_LOCAL_DIR_AUTO_SYMLINK_THRESHOLD, | ||
HF_HUB_DISABLE_IMPLICIT_TOKEN, | ||
HF_ALLOW_DOWNLOADS, | ||
HF_DATASETS_OFFLINE, | ||
TRANSFORMERS_OFFLINE, | ||
DIFFUSERS_VERBOSITY, | ||
HF_HUB_OFFLINE | ||
) | ||
|
||
|
||
def set_huggingface_environment_variables( | ||
allow_downloads: bool = None, | ||
allow_remote_inference: bool = None | ||
): | ||
""" | ||
Set the environment variables for the Hugging Face Hub. | ||
:param allow_downloads: | ||
:param allow_remote_inference: | ||
:return: | ||
""" | ||
print("Setting Hugging Face environment variables") | ||
allow_downloads = HF_ALLOW_DOWNLOADS if allow_downloads is None else allow_downloads | ||
|
||
if allow_downloads: | ||
os.environ["HF_ALLOW_DOWNLOADS"] = "1" | ||
|
||
os.environ["HF_HUB_DISABLE_TELEMETRY"] = HF_HUB_DISABLE_TELEMETRY | ||
os.environ["HF_HUB_OFFLINE"] = HF_HUB_OFFLINE | ||
os.environ["HF_HOME"] = HF_HOME | ||
os.environ["HF_ENDPOINT"] = HF_ENDPOINT | ||
os.environ["HF_INFERENCE_ENDPOINT"] = HF_INFERENCE_ENDPOINT | ||
os.environ["HF_HUB_DISABLE_PROGRESS_BARS"] = HF_HUB_DISABLE_PROGRESS_BARS | ||
os.environ["HF_HUB_DISABLE_SYMLINKS_WARNING"] = HF_HUB_DISABLE_SYMLINKS_WARNING | ||
os.environ["HF_HUB_DISABLE_EXPERIMENTAL_WARNING"] = HF_HUB_DISABLE_EXPERIMENTAL_WARNING | ||
os.environ["HF_ASSETS_CACHE"] = HF_ASSETS_CACHE | ||
os.environ["HF_TOKEN"] = HF_TOKEN | ||
os.environ["HF_HUB_VERBOSITY"] = HF_HUB_VERBOSITY | ||
os.environ["HF_HUB_LOCAL_DIR_AUTO_SYMLINK_THRESHOLD"] = HF_HUB_LOCAL_DIR_AUTO_SYMLINK_THRESHOLD | ||
os.environ["HF_HUB_DOWNLOAD_TIMEOUT"] = HF_HUB_DOWNLOAD_TIMEOUT | ||
os.environ["HF_HUB_ETAG_TIMEOUT"] = HF_HUB_ETAG_TIMEOUT | ||
os.environ["HF_HUB_DISABLE_IMPLICIT_TOKEN"] = HF_HUB_DISABLE_IMPLICIT_TOKEN | ||
os.environ["HF_DATASETS_OFFLINE"] = HF_DATASETS_OFFLINE | ||
os.environ["TRANSFORMERS_OFFLINE"] = TRANSFORMERS_OFFLINE | ||
os.environ["DIFFUSERS_VERBOSITY"] = DIFFUSERS_VERBOSITY |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,268 @@ | ||
""" | ||
==================================================================== | ||
-------------------------------------------------------------------- | ||
HUGGINGFACE ENVIRONMENT VARIABLES WARNING | ||
-------------------------------------------------------------------- | ||
==================================================================== | ||
==================================================================== | ||
-------------------------------------------------------------------- | ||
HUGGINGFACE.CO IS A WEBSITE THAT HOSTS AI MODELS AND ALLOWS PEOPLE | ||
TO CREATE SERVERS THAT CAN USE THESE MODELS. SOME OF THE DEFAULT | ||
SETTINGS PRESENT A SECURITY RISK. HUGGINGFACE.CO LIBRARIES SHOULD | ||
FIX THEIR DEFAULT SETTINGS AND REMOVE THE ABILITY TO DOWNLOAD AND | ||
EXECUTE CODE. CAREFULLY READ THE FOLLOWING SETTINGS AND COMMENTS | ||
BEFORE YOU CHANGE ANYTHING. DO NOT CHANGE ANYTHING UNLESS YOU KNOW | ||
WHAT YOU ARE DOING. | ||
-------------------------------------------------------------------- | ||
==================================================================== | ||
""" | ||
|
||
|
||
""" | ||
Environment variables for huggingface libraries | ||
The following environment variables control huggingface libraries. | ||
DO NOT CHANGE THESE VARIABLES UNLESS YOU KNOW WHAT YOU ARE DOING! | ||
For implementation, see the function | ||
airunner.src.utils.security.set_huggingface_environment_variables | ||
-------------------------------------------------------------------- | ||
We leave this implementation in the codebase however we have | ||
also taken steps to disable this functionality by preventing | ||
the application from accessing the internet as well as preventing | ||
huggingface libraries from performing write operations to the | ||
cache folder. | ||
See README.md for more information. | ||
""" | ||
|
||
#################################################################### | ||
# This is the default mode to prevent HF from accessing the internet | ||
# Only change this to False if you want to create an application | ||
# that is never allowed to access the internet. | ||
# In the core AI Runner application, this flag is referenced in ONE | ||
# file and is used to allow the model downloader | ||
# (in the setup wizard) as well as the model manager to download | ||
# models from huggingface and Civitai. | ||
#################################################################### | ||
HF_ALLOW_DOWNLOADS = True # This is an AI Runner specific variable | ||
|
||
#################################################################### | ||
# HF_HUB_DISABLE_TELEMETRY is used to disable telemetry for | ||
# huggingface models. Never enable telemetry. Setting this to "0" | ||
# will send telemetry to huggingface. Huggingface libraries should | ||
# NOT have the ability to send telemetry. | ||
#################################################################### | ||
HF_HUB_DISABLE_TELEMETRY = "1" # Never change this variable | ||
|
||
#################################################################### | ||
# HF_HUB_OFFLINE | ||
# 1 == Disable internet access. | ||
# Internet access will only be used when downloading models with the | ||
# model manager or setup wizard. | ||
#################################################################### | ||
HF_HUB_OFFLINE = "1" | ||
|
||
#################################################################### | ||
# HF_CACHE_DIR is the directory where huggingface models are stored. | ||
# Default value is "~/.cache/huggingface" but we have changed it to | ||
# "~/.airunner/huggingface" | ||
# It is safe to change this to a different directory. It can also | ||
# be changed in the GUI. | ||
# If you would like to use the default directory (in order to use | ||
# your existing cache), set it to "~/.cache/huggingface" | ||
#################################################################### | ||
HF_CACHE_DIR = "~/.airunner/huggingface" | ||
|
||
#################################################################### | ||
# HF_HOME is the directory where huggingface models are stored. | ||
# We set this to HF_CACHE_DIR | ||
#################################################################### | ||
HF_HOME = HF_CACHE_DIR | ||
|
||
#################################################################### | ||
# HF_ASSETS_CACHE is the directory where huggingface assets are | ||
# stored. Default value is "$HF_HOME/assets" | ||
# Here we hard code it to the same directory as HF_HOME | ||
#################################################################### | ||
HF_ASSETS_CACHE = HF_CACHE_DIR | ||
|
||
#################################################################### | ||
# HF_ENDPOINT is the huggingface endpoint. | ||
# Default value is "https://huggingface.co" but we have changed it | ||
# to "https://huggingface.co" | ||
# in order to force prevention of ineternet access. | ||
#################################################################### | ||
HF_ENDPOINT = "" | ||
|
||
#################################################################### | ||
# HF_INFERENCE_ENDPOINT is the huggingface inference endpoint. | ||
# Default value is "https://api-inference.huggingface.com" but we | ||
# have changed it to "" | ||
# in order to force prevention of internet access. This ensures | ||
# that no inadvertent data | ||
# transmissions occur, maintaining privacy and security by avoiding | ||
# external API calls. | ||
#################################################################### | ||
HF_INFERENCE_ENDPOINT = "" | ||
|
||
#################################################################### | ||
# HF_HUB_DISABLE_PROGRESS_BARS is used to disable progress bars for | ||
# huggingface models. | ||
# Default value is "0", we have kept this to show when models are | ||
# being downloaded | ||
# in the terminal. This transparency is useful for monitoring | ||
# download progress and debugging, | ||
# but can be disabled to reduce terminal clutter if preferred. | ||
#################################################################### | ||
HF_HUB_DISABLE_PROGRESS_BARS = "0" | ||
|
||
#################################################################### | ||
# HF_HUB_DISABLE_SYMLINKS_WARNING is used to suppress warnings | ||
# related to symlink creation. | ||
# Default value is "0". Keeping this setting as default aids in | ||
# debugging file system issues, | ||
# especially on Windows where symlink creation might require | ||
# elevated permissions. | ||
#################################################################### | ||
HF_HUB_DISABLE_SYMLINKS_WARNING = "0" | ||
|
||
#################################################################### | ||
# HF_HUB_DISABLE_EXPERIMENTAL_WARNING is used to disable warnings | ||
# for experimental features. | ||
# Default value is "0". By not changing this, users are kept | ||
# informed about the potential | ||
# instability of experimental features, enhancing awareness and | ||
# preventive caution. | ||
#################################################################### | ||
HF_HUB_DISABLE_EXPERIMENTAL_WARNING = "0" | ||
|
||
#################################################################### | ||
# HF_TOKEN is used for authentication. By setting this to an empty | ||
# string "", | ||
# we ensure that no credentials are stored or used inadvertently, | ||
# enhancing security by preventing unauthorized access to private | ||
# repositories or features. | ||
#################################################################### | ||
HF_TOKEN = "" | ||
|
||
#################################################################### | ||
# HF_HUB_VERBOSITY is set to "error" to minimize logging output. | ||
# This setting reduces the | ||
# risk of sensitive information being logged accidentally, thereby | ||
# enhancing privacy and security. | ||
#################################################################### | ||
HF_HUB_VERBOSITY = "error" | ||
|
||
#################################################################### | ||
# HF_HUB_LOCAL_DIR_AUTO_SYMLINK_THRESHOLD is set to "0" to disable | ||
# the use of symlinks. | ||
# This can prevent symlink attacks and avoids complications on | ||
# systems where symlinks | ||
# are not well-supported, enhancing file system security. | ||
#################################################################### | ||
HF_HUB_LOCAL_DIR_AUTO_SYMLINK_THRESHOLD = "0" | ||
|
||
#################################################################### | ||
# HF_HUB_DOWNLOAD_TIMEOUT and HF_HUB_ETAG_TIMEOUT are set to "30" | ||
# seconds to balance between | ||
# usability and security. Increased timeouts reduce the risk of | ||
# interruptions during data | ||
# transfers which could leave files in an insecure state. | ||
#################################################################### | ||
HF_HUB_DOWNLOAD_TIMEOUT = "30" | ||
HF_HUB_ETAG_TIMEOUT = "30" | ||
|
||
#################################################################### | ||
# HF_HUB_DISABLE_IMPLICIT_TOKEN is set to "1" to avoid automatically | ||
# sending authentication tokens | ||
# with each request. This prevents potential leaks of credentials | ||
# and ensures that tokens are | ||
# only sent when explicitly required by the user, thereby | ||
# enhancing security. | ||
#################################################################### | ||
HF_HUB_DISABLE_IMPLICIT_TOKEN = "1" | ||
|
||
#################################################################### | ||
# HF_DATASETS_OFFLINE and TRANSFORMERS_OFFLINE are set to "1" to | ||
# ensure that all operations | ||
# with datasets and transformers are conducted offline. | ||
# This eliminates any reliance on | ||
# external networks, which maximizes security by preventing | ||
# exposure to network-based threats. | ||
#################################################################### | ||
HF_DATASETS_OFFLINE = "1" | ||
TRANSFORMERS_OFFLINE = "1" | ||
|
||
#################################################################### | ||
# DIFFUSERS_VERBOSITY is set to "error" to keep the logging level | ||
# minimal for the diffusers | ||
# library, consistent with the setting for other Hugging Face tools. | ||
# This consistency helps in | ||
# maintaining a secure and quiet operational environment. | ||
#################################################################### | ||
DIFFUSERS_VERBOSITY = "error" | ||
|
||
#################################################################### | ||
# Prevents remote code from being downloaded from huggingface and | ||
# executed on the host machine. | ||
# Huge security risk if set to True. Huggingface Transformers | ||
# library should not have this capability - no library should. | ||
# Note that this is not an environment variable and is passed into | ||
# functions which download models and code. | ||
# For example, the stabilityai zeyphr library has a flag to | ||
# trust remote code. | ||
# Allegedly, this is safe, but I do not trust it. | ||
# This flag has been left in the code in case a developer | ||
# automatically sets it to true in one of the functions | ||
# and for research purposes. Never set this to True unless you are | ||
# researching. | ||
#################################################################### | ||
TRUST_REMOTE_CODE = "False" | ||
|
||
#################################################################### | ||
# DEFAULT_HF_HUB_OFFLINE is set to "0" to allow for online access | ||
# do not change this value, we will switch to it when | ||
# we want to allow online access (when using download features) | ||
#################################################################### | ||
DEFAULT_HF_HUB_OFFLINE = "0" | ||
|
||
#################################################################### | ||
# DEFAULT_HF_DATASETS_OFFLINE = "0" to allow for online access | ||
# do not change this value, we will switch to it when | ||
# we want to allow online access (when using download features) | ||
#################################################################### | ||
DEFAULT_HF_DATASETS_OFFLINE = "0" | ||
|
||
################################################################### | ||
# TRANSFORMERS_OFFLINE is set to "0" to allow for online access | ||
# do not change this value, we will switch to it when | ||
# we want to allow online access (when using download features) | ||
#################################################################### | ||
DEFAULT_TRANSFORMERS_OFFLINE = "0" | ||
|
||
#################################################################### | ||
# DEFAULT_HF_ENDPOINT is the default huggingface endpoint. | ||
# Default value is "https://huggingface.co" | ||
# This is used when the HF_HUB_OFFLINE is set to "0" | ||
# and online access is allowed. | ||
# You may change this value if you want to use a different endpoint. | ||
#################################################################### | ||
DEFAULT_HF_ENDPOINT = "https://huggingface.co" | ||
|
||
#################################################################### | ||
# DEFAULT_HF_INFERENCE_ENDPOINT is the default huggingface inference | ||
# endpoint. | ||
# Default value is "https://api-inference.huggingface.com" | ||
# This is used when the HF_HUB_OFFLINE is set to "0" | ||
# and online access is allowed. | ||
# You may change this value if you want to use a different endpoint. | ||
# This variable is currently unused by AI Runner. | ||
#################################################################### | ||
DEFAULT_HF_INFERENCE_ENDPOINT = ( | ||
"https://api-inference.huggingface.com" | ||
) |