2023-05-18 14:48:23 +00:00
# Copyright (c) 2023 Lincoln Stein (https://github.com/lstein) and the InvokeAI Development Team
2023-05-04 05:20:30 +00:00
""" Invokeai configuration system.
Arguments and fields are taken from the pydantic definition of the
model . Defaults can be set by creating a yaml configuration file that
2023-05-17 16:19:19 +00:00
has a top - level key of " InvokeAI " and subheadings for each of the
categories returned by ` invokeai - - help ` . The file looks like this :
2023-05-04 05:20:30 +00:00
[ file : invokeai . yaml ]
2023-05-17 16:19:19 +00:00
InvokeAI :
2023-05-17 23:45:51 +00:00
Web Server :
host : 127.0 .0 .1
2023-08-17 18:32:05 +00:00
port : 9090
2023-05-17 16:19:19 +00:00
allow_origins : [ ]
allow_credentials : true
allow_methods :
- ' * '
allow_headers :
- ' * '
2023-08-17 18:32:05 +00:00
Features :
esrgan : true
internet_available : true
log_tokenization : false
patchmatch : true
ignore_missing_core_models : false
Paths :
autoimport_dir : autoimport
lora_dir : null
embedding_dir : null
controlnet_dir : null
conf_path : configs / models . yaml
models_dir : models
legacy_conf_dir : configs / stable - diffusion
db_dir : databases
outdir : / home / lstein / invokeai - main / outputs
use_memory_db : false
Logging :
log_handlers :
- console
log_format : plain
log_level : info
Model Cache :
ram : 13.5
vram : 0.25
lazy_offload : true
Device :
device : auto
precision : auto
Generation :
sequential_guidance : false
attention_type : xformers
attention_slice_size : auto
force_tiled_decode : false
2023-05-04 05:20:30 +00:00
The default name of the configuration file is ` invokeai . yaml ` , located
2023-05-17 16:19:19 +00:00
in INVOKEAI_ROOT . You can replace supersede this by providing any
OmegaConf dictionary object initialization time :
2023-05-04 05:20:30 +00:00
omegaconf = OmegaConf . load ( ' /tmp/init.yaml ' )
2023-05-26 01:10:00 +00:00
conf = InvokeAIAppConfig ( )
conf . parse_args ( conf = omegaconf )
2023-05-04 05:20:30 +00:00
2023-05-26 01:10:00 +00:00
InvokeAIAppConfig . parse_args ( ) will parse the contents of ` sys . argv `
at initialization time . You may pass a list of strings in the optional
2023-05-04 05:20:30 +00:00
` argv ` argument to use instead of the system argv :
2023-08-17 18:32:05 +00:00
conf . parse_args ( argv = [ ' --log_tokenization ' ] )
2023-05-04 05:20:30 +00:00
2023-05-26 01:10:00 +00:00
It is also possible to set a value at initialization time . However , if
you call parse_args ( ) it may be overwritten .
2023-05-04 05:20:30 +00:00
2023-08-17 18:32:05 +00:00
conf = InvokeAIAppConfig ( log_tokenization = True )
conf . parse_args ( argv = [ ' --no-log_tokenization ' ] )
conf . log_tokenization
2023-05-26 01:10:00 +00:00
# False
To avoid this , use ` get_config ( ) ` to retrieve the application - wide
configuration object . This will retain any properties set at object
creation time :
2023-08-17 18:32:05 +00:00
conf = InvokeAIAppConfig . get_config ( log_tokenization = True )
conf . parse_args ( argv = [ ' --no-log_tokenization ' ] )
conf . log_tokenization
2023-05-26 01:10:00 +00:00
# True
2023-05-04 05:20:30 +00:00
Any setting can be overwritten by setting an environment variable of
2023-05-17 16:19:19 +00:00
form : " INVOKEAI_<setting> " , as in :
2023-05-04 05:20:30 +00:00
2023-05-17 16:19:19 +00:00
export INVOKEAI_port = 8080
2023-05-04 05:20:30 +00:00
Order of precedence ( from highest ) :
1 ) initialization options
2 ) command line options
3 ) environment variable options
4 ) config file options
5 ) pydantic defaults
2023-05-26 01:10:00 +00:00
Typical usage at the top level file :
2023-05-04 05:20:30 +00:00
from invokeai . app . services . config import InvokeAIAppConfig
2023-07-26 10:53:35 +00:00
# get global configuration and print its cache size
2023-05-26 00:41:26 +00:00
conf = InvokeAIAppConfig . get_config ( )
conf . parse_args ( )
2023-08-17 18:32:05 +00:00
print ( conf . ram_cache_size )
2023-05-04 05:20:30 +00:00
2023-05-26 01:10:00 +00:00
Typical usage in a backend module :
from invokeai . app . services . config import InvokeAIAppConfig
2023-07-26 10:53:35 +00:00
# get global configuration and print its cache size value
2023-05-26 01:10:00 +00:00
conf = InvokeAIAppConfig . get_config ( )
2023-08-17 18:32:05 +00:00
print ( conf . ram_cache_size )
2023-05-04 05:20:30 +00:00
Computed properties :
The InvokeAIAppConfig object has a series of properties that
resolve paths relative to the runtime root directory . They each return
a Path object :
root_path - path to InvokeAI root
output_path - path to default outputs directory
model_conf_path - path to models . yaml
conf - alias for the above
embedding_path - path to the embeddings directory
lora_path - path to the LoRA directory
2023-05-17 23:12:01 +00:00
2023-05-04 05:20:30 +00:00
In most cases , you will want to create a single InvokeAIAppConfig
2023-05-26 00:41:26 +00:00
object for the entire application . The InvokeAIAppConfig . get_config ( ) function
2023-05-04 05:20:30 +00:00
does this :
2023-05-26 00:41:26 +00:00
config = InvokeAIAppConfig . get_config ( )
config . parse_args ( ) # read values from the command line/config file
2023-05-04 05:20:30 +00:00
print ( config . root )
2023-05-17 16:19:19 +00:00
# Subclassing
If you wish to create a similar class , please subclass the
` InvokeAISettings ` class and define a Literal field named " type " ,
which is set to the desired top - level name . For example , to create a
" InvokeBatch " configuration , define like this :
class InvokeBatch ( InvokeAISettings ) :
type : Literal [ " InvokeBatch " ] = " InvokeBatch "
node_count : int = Field ( default = 1 , description = " Number of nodes to run on " , category = ' Resources ' )
cpu_count : int = Field ( default = 8 , description = " Number of GPUs to run on per node " , category = ' Resources ' )
This will now read and write from the " InvokeBatch " section of the
config file , look for environment variables named INVOKEBATCH_ * , and
accept the command - line arguments ` - - node_count ` and ` - - cpu_count ` . The
two configs are kept in separate sections of the config file :
# invokeai.yaml
InvokeBatch :
Resources :
node_count : 1
cpu_count : 8
InvokeAI :
Paths :
root : / home / lstein / invokeai - main
conf_path : configs / models . yaml
legacy_conf_dir : configs / stable - diffusion
outdir : outputs
. . .
2023-05-26 01:10:00 +00:00
2023-07-27 14:54:01 +00:00
"""
2023-05-26 00:41:26 +00:00
from __future__ import annotations
2023-05-04 05:20:30 +00:00
import os
2023-08-17 17:47:26 +00:00
from omegaconf import OmegaConf , DictConfig
2023-05-04 05:20:30 +00:00
from pathlib import Path
2023-08-17 17:47:26 +00:00
from pydantic import Field , parse_obj_as
from typing import ClassVar , Dict , List , Literal , Union , Optional , get_type_hints
from . base import InvokeAISettings
2023-05-04 05:20:30 +00:00
INIT_FILE = Path ( " invokeai.yaml " )
2023-06-04 00:24:41 +00:00
DB_FILE = Path ( " invokeai.db " )
2023-05-04 05:20:30 +00:00
LEGACY_INIT_FILE = Path ( " invokeai.init " )
2023-08-02 18:27:13 +00:00
DEFAULT_MAX_VRAM = 0.5
2023-08-02 13:44:06 +00:00
2023-08-02 18:28:19 +00:00
2023-05-04 05:20:30 +00:00
class InvokeAIAppConfig ( InvokeAISettings ) :
2023-07-27 14:54:01 +00:00
"""
2023-05-17 19:22:58 +00:00
Generate images using Stable Diffusion . Use " invokeai " to launch
the command - line client ( recommended for experts only ) , or
" invokeai-web " to launch the web server . Global options
can be changed by editing the file " INVOKEAI_ROOT/invokeai.yaml " or by
setting environment variables INVOKEAI_ < setting > .
2023-07-27 14:54:01 +00:00
"""
2023-05-26 00:41:26 +00:00
singleton_config : ClassVar [ InvokeAIAppConfig ] = None
singleton_init : ClassVar [ Dict ] = None
2023-07-04 21:05:35 +00:00
2023-05-04 05:20:30 +00:00
# fmt: off
2023-05-17 16:19:19 +00:00
type : Literal [ " InvokeAI " ] = " InvokeAI "
2023-08-17 17:47:26 +00:00
# WEB
2023-05-17 19:22:58 +00:00
host : str = Field ( default = " 127.0.0.1 " , description = " IP address to bind to " , category = ' Web Server ' )
port : int = Field ( default = 9090 , description = " Port to bind to " , category = ' Web Server ' )
allow_origins : List [ str ] = Field ( default = [ ] , description = " Allowed CORS origins " , category = ' Web Server ' )
allow_credentials : bool = Field ( default = True , description = " Allow CORS credentials " , category = ' Web Server ' )
allow_methods : List [ str ] = Field ( default = [ " * " ] , description = " Methods allowed for CORS " , category = ' Web Server ' )
allow_headers : List [ str ] = Field ( default = [ " * " ] , description = " Headers allowed for CORS " , category = ' Web Server ' )
2023-08-17 17:47:26 +00:00
# FEATURES
2023-05-17 19:22:58 +00:00
esrgan : bool = Field ( default = True , description = " Enable/disable upscaling code " , category = ' Features ' )
internet_available : bool = Field ( default = True , description = " If true, attempt to download models on the fly; otherwise only use local models " , category = ' Features ' )
log_tokenization : bool = Field ( default = False , description = " Enable logging of parsed prompt tokens. " , category = ' Features ' )
patchmatch : bool = Field ( default = True , description = " Enable/disable patchmatch inpaint code " , category = ' Features ' )
2023-08-17 17:47:26 +00:00
ignore_missing_core_models : bool = Field ( default = False , description = ' Ignore missing models in models/core/convert ' , category = ' Features ' )
2023-05-17 19:22:58 +00:00
2023-08-17 17:47:26 +00:00
# PATHS
2023-08-01 02:27:07 +00:00
root : Path = Field ( default = None , description = ' InvokeAI runtime root directory ' , category = ' Paths ' )
2023-07-20 13:01:49 +00:00
autoimport_dir : Path = Field ( default = ' autoimport ' , description = ' Path to a directory of models files to be imported on startup. ' , category = ' Paths ' )
lora_dir : Path = Field ( default = None , description = ' Path to a directory of LoRA/LyCORIS models to be imported on startup. ' , category = ' Paths ' )
embedding_dir : Path = Field ( default = None , description = ' Path to a directory of Textual Inversion embeddings to be imported on startup. ' , category = ' Paths ' )
controlnet_dir : Path = Field ( default = None , description = ' Path to a directory of ControlNet embeddings to be imported on startup. ' , category = ' Paths ' )
2023-05-04 05:20:30 +00:00
conf_path : Path = Field ( default = ' configs/models.yaml ' , description = ' Path to models definition file ' , category = ' Paths ' )
2023-06-25 22:50:15 +00:00
models_dir : Path = Field ( default = ' models ' , description = ' Path to the models directory ' , category = ' Paths ' )
2023-05-17 19:22:58 +00:00
legacy_conf_dir : Path = Field ( default = ' configs/stable-diffusion ' , description = ' Path to directory of legacy checkpoint config files ' , category = ' Paths ' )
2023-06-04 00:24:41 +00:00
db_dir : Path = Field ( default = ' databases ' , description = ' Path to InvokeAI databases directory ' , category = ' Paths ' )
2023-05-17 19:22:58 +00:00
outdir : Path = Field ( default = ' outputs ' , description = ' Default folder for output images ' , category = ' Paths ' )
2023-05-25 01:53:02 +00:00
use_memory_db : bool = Field ( default = False , description = ' Use in-memory database for storing image metadata ' , category = ' Paths ' )
2023-08-17 17:47:26 +00:00
from_file : Path = Field ( default = None , description = ' Take command input from the indicated file (command-line client only) ' , category = ' Paths ' )
2023-07-04 21:05:35 +00:00
2023-08-17 17:47:26 +00:00
# LOGGING
2023-05-25 03:57:15 +00:00
log_handlers : List [ str ] = Field ( default = [ " console " ] , description = ' Log handler. Valid options are " console " , " file=<path> " , " syslog=path|address:host:port " , " http=<url> " ' , category = " Logging " )
# note - would be better to read the log_format values from logging.py, but this creates circular dependencies issues
2023-08-17 22:45:25 +00:00
log_format : Literal [ ' plain ' , ' color ' , ' syslog ' , ' legacy ' ] = Field ( default = " color " , description = ' Log format. Use " plain " for text-only, " color " for colorized output, " legacy " for 2.3-style logging and " syslog " for syslog-style ' , category = " Logging " )
log_level : Literal [ " debug " , " info " , " warning " , " error " , " critical " ] = Field ( default = " info " , description = " Emit logging messages at this level or higher " , category = " Logging " )
2023-07-08 00:47:29 +00:00
version : bool = Field ( default = False , description = " Show InvokeAI version and exit " , category = " Other " )
2023-08-17 17:47:26 +00:00
# CACHE
2023-08-17 18:20:45 +00:00
ram : Union [ float , Literal [ " auto " ] ] = Field ( default = 6.0 , gt = 0 , description = " Maximum memory amount used by model cache for rapid switching (floating point number or ' auto ' ) " , category = " Model Cache " , )
vram : Union [ float , Literal [ " auto " ] ] = Field ( default = 0.25 , ge = 0 , description = " Amount of VRAM reserved for model storage (floating point number or ' auto ' ) " , category = " Model Cache " , )
lazy_offload : bool = Field ( default = True , description = " Keep models in VRAM until their space is needed " , category = " Model Cache " , )
2023-08-17 17:47:26 +00:00
# DEVICE
device : Literal [ tuple ( [ " auto " , " cpu " , " cuda " , " cuda:1 " , " mps " ] ) ] = Field ( default = " auto " , description = " Generation device " , category = " Device " , )
precision : Literal [ tuple ( [ " auto " , " float16 " , " float32 " , " autocast " ] ) ] = Field ( default = " auto " , description = " Floating point precision " , category = " Device " , )
# GENERATION
sequential_guidance : bool = Field ( default = False , description = " Whether to calculate guidance in serial instead of in parallel, lowering memory requirements " , category = " Generation " , )
attention_type : Literal [ tuple ( [ " auto " , " normal " , " xformers " , " sliced " , " torch-sdp " ] ) ] = Field ( default = " auto " , description = " Attention type " , category = " Generation " , )
2023-08-17 20:11:09 +00:00
attention_slice_size : Literal [ tuple ( [ " auto " , " balanced " , " max " , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 ] ) ] = Field ( default = " auto " , description = ' Slice size, valid when attention_type== " sliced " ' , category = " Generation " , )
2023-08-17 17:47:26 +00:00
force_tiled_decode : bool = Field ( default = False , description = " Whether to enable tiled VAE decode (reduces memory consumption with some performance penalty) " , category = " Generation " , )
2023-08-20 19:57:15 +00:00
2023-08-17 17:47:26 +00:00
# DEPRECATED FIELDS - STILL HERE IN ORDER TO OBTAN VALUES FROM PRE-3.1 CONFIG FILES
always_use_cpu : bool = Field ( default = False , description = " If true, use the CPU for rendering even if a GPU is available. " , category = ' Memory/Performance ' )
free_gpu_mem : Optional [ bool ] = Field ( default = None , description = " If true, purge model from GPU after each generation. " , category = ' Memory/Performance ' )
max_cache_size : Optional [ float ] = Field ( default = None , gt = 0 , description = " Maximum memory amount used by model cache for rapid switching " , category = ' Memory/Performance ' )
max_vram_cache_size : Optional [ float ] = Field ( default = None , ge = 0 , description = " Amount of VRAM reserved for model storage " , category = ' Memory/Performance ' )
xformers_enabled : bool = Field ( default = True , description = " Enable/disable memory-efficient attention " , category = ' Memory/Performance ' )
tiled_decode : bool = Field ( default = False , description = " Whether to enable tiled VAE decode (reduces memory consumption with some performance penalty) " , category = ' Memory/Performance ' )
# See InvokeAIAppConfig subclass below for CACHE and DEVICE categories
2023-05-04 05:20:30 +00:00
# fmt: on
2023-08-07 18:04:53 +00:00
class Config :
validate_assignment = True
2023-05-26 00:41:26 +00:00
def parse_args ( self , argv : List [ str ] = None , conf : DictConfig = None , clobber = False ) :
2023-07-27 14:54:01 +00:00
"""
2023-07-04 21:05:35 +00:00
Update settings with contents of init file , environment , and
2023-05-26 00:41:26 +00:00
command - line settings .
2023-05-04 05:20:30 +00:00
: param conf : alternate Omegaconf dictionary object
: param argv : aternate sys . argv list
2023-05-26 00:41:26 +00:00
: param clobber : ovewrite any initialization parameters passed during initialization
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
# Set the runtime root directory. We parse command-line switches here
# in order to pick up the --root_dir option.
2023-05-26 00:41:26 +00:00
super ( ) . parse_args ( argv )
2023-05-17 16:19:19 +00:00
if conf is None :
2023-05-04 05:20:30 +00:00
try :
conf = OmegaConf . load ( self . root_dir / INIT_FILE )
2023-08-17 22:45:25 +00:00
except Exception :
2023-05-04 05:20:30 +00:00
pass
InvokeAISettings . initconf = conf
2023-07-04 21:05:35 +00:00
2023-05-04 05:20:30 +00:00
# parse args again in order to pick up settings in configuration file
2023-05-26 00:41:26 +00:00
super ( ) . parse_args ( argv )
2023-05-04 05:20:30 +00:00
2023-05-26 00:41:26 +00:00
if self . singleton_init and not clobber :
hints = get_type_hints ( self . __class__ )
for k in self . singleton_init :
setattr ( self , k , parse_obj_as ( hints [ k ] , self . singleton_init [ k ] ) )
2023-05-04 05:20:30 +00:00
2023-05-26 00:41:26 +00:00
@classmethod
def get_config ( cls , * * kwargs ) - > InvokeAIAppConfig :
2023-07-27 14:54:01 +00:00
"""
2023-05-26 00:41:26 +00:00
This returns a singleton InvokeAIAppConfig configuration object .
2023-07-27 14:54:01 +00:00
"""
2023-05-26 00:41:26 +00:00
if (
cls . singleton_config is None
2023-08-17 22:45:25 +00:00
or type ( cls . singleton_config ) is not cls
2023-05-26 00:41:26 +00:00
or ( kwargs and cls . singleton_init != kwargs )
) :
cls . singleton_config = cls ( * * kwargs )
cls . singleton_init = kwargs
return cls . singleton_config
2023-07-04 21:05:35 +00:00
2023-05-04 05:20:30 +00:00
@property
def root_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Path to the runtime root directory
2023-07-27 14:54:01 +00:00
"""
2023-08-01 01:15:44 +00:00
if self . root :
2023-07-30 17:37:18 +00:00
root = Path ( self . root ) . expanduser ( ) . absolute ( )
2023-05-04 05:20:30 +00:00
else :
2023-08-01 02:36:11 +00:00
root = self . find_root ( ) . expanduser ( ) . absolute ( )
2023-08-01 02:27:07 +00:00
self . root = root # insulate ourselves from relative paths that may change
2023-08-01 01:15:44 +00:00
return root
2023-05-04 05:20:30 +00:00
@property
def root_dir ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Alias for above .
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
return self . root_path
def _resolve ( self , partial_path : Path ) - > Path :
return ( self . root_path / partial_path ) . resolve ( )
2023-05-30 17:49:43 +00:00
@property
def init_file_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-30 17:49:43 +00:00
Path to invokeai . yaml
2023-07-27 14:54:01 +00:00
"""
2023-05-30 17:49:43 +00:00
return self . _resolve ( INIT_FILE )
2023-05-04 05:20:30 +00:00
@property
def output_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Path to defaults outputs directory .
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
return self . _resolve ( self . outdir )
@property
2023-06-04 00:24:41 +00:00
def db_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-06-04 00:24:41 +00:00
Path to the invokeai . db file .
2023-07-27 14:54:01 +00:00
"""
2023-06-04 00:24:41 +00:00
return self . _resolve ( self . db_dir ) / DB_FILE
2023-05-04 05:20:30 +00:00
@property
def model_conf_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Path to models configuration file .
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
return self . _resolve ( self . conf_path )
@property
def legacy_conf_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Path to directory of legacy configuration files ( e . g . v1 - inference . yaml )
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
return self . _resolve ( self . legacy_conf_dir )
@property
2023-06-09 03:11:53 +00:00
def models_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Path to the models directory
2023-07-27 14:54:01 +00:00
"""
2023-06-09 03:11:53 +00:00
return self . _resolve ( self . models_dir )
2023-05-30 04:38:37 +00:00
2023-05-04 05:20:30 +00:00
@property
def autoconvert_path ( self ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Path to the directory containing models to be imported automatically at startup .
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
return self . _resolve ( self . autoconvert_dir ) if self . autoconvert_dir else None
# the following methods support legacy calls leftover from the Globals era
@property
def full_precision ( self ) - > bool :
""" Return true if precision set to float32 """
return self . precision == " float32 "
2023-05-16 05:50:01 +00:00
@property
def try_patchmatch ( self ) - > bool :
""" Return true if patchmatch true """
return self . patchmatch
2023-07-26 10:53:35 +00:00
@property
def nsfw_checker ( self ) - > bool :
""" NSFW node is always active and disabled from Web UIe """
return True
@property
def invisible_watermark ( self ) - > bool :
""" invisible watermark node is always active and disabled from Web UIe """
return True
2023-07-27 14:54:01 +00:00
2023-08-17 03:30:00 +00:00
@property
2023-08-17 17:47:26 +00:00
def ram_cache_size ( self ) - > float :
return self . max_cache_size or self . ram
2023-08-17 03:30:00 +00:00
@property
2023-08-17 17:47:26 +00:00
def vram_cache_size ( self ) - > float :
return self . max_vram_cache_size or self . vram
@property
def use_cpu ( self ) - > bool :
return self . always_use_cpu or self . device == " cpu "
@property
def disable_xformers ( self ) - > bool :
"""
Return true if enable_xformers is false ( reversed logic )
and attention type is not set to xformers .
"""
disabled_in_config = not self . xformers_enabled
return disabled_in_config and self . attention_type != " xformers "
2023-05-04 05:20:30 +00:00
@staticmethod
def find_root ( ) - > Path :
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
Choose the runtime root directory when not specified on command line or
init file .
2023-07-27 14:54:01 +00:00
"""
2023-05-04 05:20:30 +00:00
return _find_root ( )
2023-07-27 14:54:01 +00:00
2023-05-26 00:41:26 +00:00
def get_invokeai_config ( * * kwargs ) - > InvokeAIAppConfig :
2023-07-27 14:54:01 +00:00
"""
2023-05-26 00:41:26 +00:00
Legacy function which returns InvokeAIAppConfig . get_config ( )
2023-07-27 14:54:01 +00:00
"""
2023-05-26 00:41:26 +00:00
return InvokeAIAppConfig . get_config ( * * kwargs )
2023-08-17 03:30:00 +00:00
2023-08-17 17:47:26 +00:00
def _find_root ( ) - > Path :
venv = Path ( os . environ . get ( " VIRTUAL_ENV " ) or " . " )
if os . environ . get ( " INVOKEAI_ROOT " ) :
root = Path ( os . environ [ " INVOKEAI_ROOT " ] )
elif any ( [ ( venv . parent / x ) . exists ( ) for x in [ INIT_FILE , LEGACY_INIT_FILE ] ] ) :
root = ( venv . parent ) . resolve ( )
else :
root = Path ( " ~/invokeai " ) . expanduser ( ) . resolve ( )
return root