Lincoln Stein
cee159dfa3
Merge branch 'main' into bugfix/prevent-cli-crash
2023-04-09 12:08:09 -04:00
psychedelicious
4463124bdd
feat(nodes): mark ImageField properties required, add docs
2023-04-09 22:53:17 +10:00
psychedelicious
34402cc46a
feat(nodes): add list_images endpoint
...
- add `list_images` endpoint at `GET api/v1/images`
- extend `ImageStorageBase` with `list()` method, implemented it for `DiskImageStorage`
- add `ImageReponse` class to for image responses, which includes urls, metadata
- add `ImageMetadata` class (basically a stub at the moment)
- uploaded images now named `"{uuid}_{timestamp}.png"`
- add `models` modules. besides separating concerns more clearly, this helps to mitigate circular dependencies
- improve thumbnail handling
2023-04-09 13:48:44 +10:00
Kent Keirsey
54d9833db0
Else.
2023-04-08 12:08:51 -04:00
Kent Keirsey
5fe8cb56fc
Correct response note
2023-04-08 12:08:51 -04:00
Kent Keirsey
7919d81fb1
Update to address feedback
2023-04-08 12:08:51 -04:00
Kent Keirsey
9d80b28a4f
Begin Convert Work
2023-04-08 12:08:51 -04:00
Kent Keirsey
1fcd91bcc5
Add/Update and Delete Models
2023-04-08 12:08:51 -04:00
blessedcoolant
e456e2e63a
fix typo ( #3147 )
...
fix typo.
reference:
21f79e5919/invokeai/configs/INITIAL_MODELS.yaml (L21-L25)
2023-04-08 20:25:31 +12:00
c67e708d
ee41b99049
Update 050_INSTALLING_MODELS.md
...
fix typo
2023-04-08 17:02:47 +09:00
psychedelicious
111d674e71
fix(nodes): use correct torch device in NoiseInvocation
2023-04-08 12:32:03 +10:00
Lincoln Stein
8f048cfbd9
Add python-multipart, which is needed by nodes ( #3141 )
...
I'm not quite sure why this isn't being installed by fastapi's
dependencies, but running without it installed yields:
```
root@gnubert:/srv/ssdtank/docker/invokeai/git/InvokeAI# docker run --gpus all -p 9989:9090 -v /srv/ssdtank/docker/invokeai/data:/data -v /srv/ssdtank/docker/invokeai/git/InvokeAI/static/dream_web/:/static/dream_web --rm -ti -u root --entrypoint /bin/bash ghcr.io/cmsj/invokeai-nodes@sha256:426ebc414936cb67e02f5f64d963196500a77b2f485df8122a2d462797293938
root@7a77b56a5771:/usr/src# /invoke-new.py --web
Form data requires "python-multipart" to be installed.
You can install "python-multipart" with:
pip install python-multipart
╭─────────────────────────────── Traceback (most recent call last) ────────────────────────────────╮
│ /invoke-new.py:22 in <module> │
│ │
│ 19 │
│ 20 │
│ 21 if __name__ == '__main__': │
│ ❱ 22 │ main() │
│ 23 │
│ │
│ /invoke-new.py:13 in main │
│ │
│ 10 │ os.chdir(os.path.abspath(os.path.join(os.path.dirname(__file__), ".."))) │
│ 11 │ │
│ 12 │ if '--web' in sys.argv: │
│ ❱ 13 │ │ from invokeai.app.api_app import invoke_api │
│ 14 │ │ invoke_api() │
│ 15 │ else: │
│ 16 │ │ # TODO: Parse some top-level args here. │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/invokeai/app/api_app.py:17 in <module> │
│ │
│ 14 │
│ 15 from ..backend import Args │
│ 16 from .api.dependencies import ApiDependencies │
│ ❱ 17 from .api.routers import images, sessions, models │
│ 18 from .api.sockets import SocketIO │
│ 19 from .invocations import * │
│ 20 from .invocations.baseinvocation import BaseInvocation │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/invokeai/app/api/routers/images.py:45 in <module> │
│ │
│ 42 │ │ 404: {"description": "Session not found"}, │
│ 43 │ }, │
│ 44 ) │
│ ❱ 45 async def upload_image(file: UploadFile, request: Request): │
│ 46 │ if not file.content_type.startswith("image"): │
│ 47 │ │ return Response(status_code=415) │
│ 48 │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/fastapi/routing.py:630 in decorator │
│ │
│ 627 │ │ ), │
│ 628 │ ) -> Callable[[DecoratedCallable], DecoratedCallable]: │
│ 629 │ │ def decorator(func: DecoratedCallable) -> DecoratedCallable: │
│ ❱ 630 │ │ │ self.add_api_route( │
│ 631 │ │ │ │ path, │
│ 632 │ │ │ │ func, │
│ 633 │ │ │ │ response_model=response_model, │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/fastapi/routing.py:569 in add_api_route │
│ │
│ 566 │ │ current_generate_unique_id = get_value_or_default( │
│ 567 │ │ │ generate_unique_id_function, self.generate_unique_id_function │
│ 568 │ │ ) │
│ ❱ 569 │ │ route = route_class( │
│ 570 │ │ │ self.prefix + path, │
│ 571 │ │ │ endpoint=endpoint, │
│ 572 │ │ │ response_model=response_model, │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/fastapi/routing.py:444 in __init__ │
│ │
│ 441 │ │ │ │ 0, │
│ 442 │ │ │ │ get_parameterless_sub_dependant(depends=depends, path=self.path_format), │
│ 443 │ │ │ ) │
│ ❱ 444 │ │ self.body_field = get_body_field(dependant=self.dependant, name=self.unique_id) │
│ 445 │ │ self.app = request_response(self.get_route_handler()) │
│ 446 │ │
│ 447 │ def get_route_handler(self) -> Callable[[Request], Coroutine[Any, Any, Response]]: │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/fastapi/dependencies/utils.py:756 in │
│ get_body_field │
│ │
│ 753 │ │ alias="body", │
│ 754 │ │ field_info=BodyFieldInfo(**BodyFieldInfo_kwargs), │
│ 755 │ ) │
│ ❱ 756 │ check_file_field(final_field) │
│ 757 │ return final_field │
│ 758 │
│ │
│ /usr/src/InvokeAI/lib/python3.10/site-packages/fastapi/dependencies/utils.py:111 in │
│ check_file_field │
│ │
│ 108 │ │ │ │ raise RuntimeError(multipart_incorrect_install_error) from None │
│ 109 │ │ except ImportError: │
│ 110 │ │ │ logger.error(multipart_not_installed_error) │
│ ❱ 111 │ │ │ raise RuntimeError(multipart_not_installed_error) from None │
│ 112 │
│ 113 │
│ 114 def get_param_sub_dependant( │
╰──────────────────────────────────────────────────────────────────────────────────────────────────╯
RuntimeError: Form data requires "python-multipart" to be installed.
You can install "python-multipart" with:
pip install python-multipart
```
2023-04-07 19:17:37 -04:00
Lincoln Stein
cd1b350dae
Merge branch 'main' into bugfix/release-updater
2023-04-07 18:56:21 -04:00
Lincoln Stein
8334757af9
Merge branch 'main' into bugfix/prevent-cli-crash
2023-04-07 18:55:54 -04:00
Chris Jones
7103ac6a32
Add python-multipart, which is needed by nodes
2023-04-07 19:43:42 +01:00
blessedcoolant
f6b131e706
remove vestiges of non-functional autoimport code for legacy checkpoints ( #3076 )
...
- the functionality to automatically import and run legacy checkpoint
files in a designated folder has been removed from the backend but there
are vestiges of the code remaining in the frontend that are causing
crashes.
- This fixes the problem.
- Closes #3075
2023-04-08 02:21:23 +12:00
Lincoln Stein
d1b2b99226
Merge branch 'main' into bugfix/remove-autoimport-dead-code
2023-04-07 09:59:58 -04:00
psychedelicious
e356f2511b
chore: configure stale bot
2023-04-07 20:45:08 +10:00
Lincoln Stein
e5f8b22a43
add a new method to model_manager that retrieves individual pipeline components ( #3120 )
...
This PR introduces a new set of ModelManager methods that enables you to
retrieve the individual parts of a stable diffusion pipeline model,
including the vae, text_encoder, unet, tokenizer, etc.
To use:
```
from invokeai.backend import ModelManager
manager = ModelManager('/path/to/models.yaml')
# get the VAE
vae = manager.get_model_vae('stable-diffusion-1.5')
# get the unet
unet = manager.get_model_unet('stable-diffusion-1.5')
# get the tokenizer
tokenizer = manager.get_model_tokenizer('stable-diffusion-1.5')
# etc etc
feature_extractor = manager.get_model_feature_extractor('stable-diffusion-1.5')
scheduler = manager.get_model_scheduler('stable-diffusion-1.5')
text_encoder = manager.get_model_text_encoder('stable-diffusion-1.5')
# if no model provided, then defaults to the one currently in GPU, if any
vae = manager.get_model_vae()
```
2023-04-07 01:39:57 -04:00
blessedcoolant
45b84fb4bb
Merge branch 'main' into bugfix/remove-autoimport-dead-code
2023-04-07 17:07:25 +12:00
Lincoln Stein
f022c89249
Merge branch 'main' into feat/return-submodels
2023-04-06 22:03:31 -04:00
Lincoln Stein
ab05144716
Change where !replay looks for its infile ( #3129 )
...
!fetch puts its output file into the output directory; it may be
beneficial to have !replay look in the output directory as well.
2023-04-06 22:02:06 -04:00
Lincoln Stein
aeb4914e67
Merge branch 'main' into replay-file_path
2023-04-06 21:45:23 -04:00
blessedcoolant
76bcd4d44f
Fix typo ( #3133 )
...
'hotdot' to 'hotdog'; the world's least important PR :)
2023-04-07 12:38:05 +12:00
Steven Frank
50f5e1bc83
Fix typo
...
'hotdot' to 'hotdog'; the world's least important PR :)
2023-04-06 16:47:57 -07:00
Lincoln Stein
4c339dd4b0
refactor get_submodels() into individual methods
2023-04-06 17:08:23 -04:00
Lincoln Stein
bc2b9500e3
Merge branch 'main' into bugfix/prevent-cli-crash
2023-04-06 15:38:46 -04:00
Lincoln Stein
32857d81c5
prevent legacy CLI crash caused by removal of convert option
...
- Compensatory change to the CLI that prevents it from crashing
when it tries to import a model.
- Bug introduced when the "convert" option removed from the model
manager.
2023-04-06 15:36:05 -04:00
Thomas
7268131f57
change where !replay looks for its infile
...
!fetch puts its output file into the output directory; it may be beneficial to have !replay look in the output directory as well.
2023-04-06 08:14:11 -04:00
Kyle Schouviller
85b020f76c
[nodes] Add latent nodes, storage, and fix iteration bugs ( #3091 )
...
* Add latents nodes.
* Fix iteration expansion.
* Add collection generator nodes, math nodes.
* Add noise node.
* Add some graph debug commands to the CLI.
* Fix negative id linking in CLI.
* Fix a CLI bug with multiple links per node.
2023-04-06 04:06:05 +00:00
Kyle Schouviller
a7833cc9a9
[api] Add models router and list model API.
2023-04-05 23:59:07 -04:00
Lincoln Stein
28f75d80d5
Merge branch 'main' into bugfix/release-updater
2023-04-05 18:25:33 -04:00
Matthias Wild
919294e977
fix build-container.yml ( #3117 )
...
Add permission go write packages to GITHUB_TOKEN
2023-04-06 00:25:00 +02:00
Lincoln Stein
b917ffa4d7
Merge branch 'main' into bugfix/release-updater
2023-04-05 17:37:27 -04:00
Lincoln Stein
d44151d6ff
add a new method to model_manager that retrieves individual pipeline parts
...
- New method is ModelManager.get_sub_model(model_name:str,model_part:SDModelComponent)
To use:
```
from invokeai.backend import ModelManager, SDModelComponent as sdmc
manager = ModelManager('/path/to/models.yaml')
vae = manager.get_sub_model('stable-diffusion-1.5', sdmc.vae)
```
2023-04-05 17:25:42 -04:00
mauwii
7640acfb1f
update build-container.yml
...
- add packages write permission
2023-04-05 15:44:26 +02:00
psychedelicious
aed9ecef2a
feat(nodes): add thumbnail generation to DiskImageStorage
2023-04-05 08:22:23 +10:00
Lincoln Stein
18cddd7972
Right link on pytorch installer for linux rocm ( #3084 )
...
Right link on pytorch installer for linux rocm
2023-04-04 17:40:42 -04:00
Lincoln Stein
e6b25f4ae3
Merge branch 'main' into patch-1
2023-04-04 17:40:12 -04:00
Lincoln Stein
d1c0050e65
fix(nodes): fix typo in list_sessions
handler ( #3109 )
...
The typo accidentally did not affect functionality; when `query==""`, it
`search()`ed but found everything due to empty query, then paginated
results, so it worked the same as `list()`.
Still fix it
2023-04-03 21:24:48 -04:00
psychedelicious
ecdfa136a0
fix(nodes): fix typo in list_sessions
handler
2023-04-04 00:34:32 +10:00
blessedcoolant
5cd513ee63
[deps] bump compel version to fix crash on invalid (auto111) syntax ( #3107 )
...
currently if users input eg `happy (camper:0.3)` it gets parsed
incorrectly, which causes crashes if it's in the negative prompt. bump
to compel 1.0.5 fixes the parser to avoid this (note the weight is
parsed as plain text, it's not converted to proper invoke syntax)
2023-04-04 02:30:17 +12:00
blessedcoolant
ab45086546
Merge branch 'main' into deps_bump_compel
2023-04-04 02:05:40 +12:00
psychedelicious
77ba7359f4
fix(nodes): commit changes to db
2023-04-03 19:09:49 +10:00
Damian Stewart
8cbe2e14d9
bump compel version to fix on invalid (auto111) syntax
2023-04-03 10:37:01 +02:00
Lincoln Stein
f682fb8040
fix invokeai-update script
...
- This commit fixes the update script to work again, as well as fixing
the ambiguity between updating to a tag and updating to a branch.
2023-04-02 11:08:12 -04:00
creachec
ee86eedf01
Right link on pytorch installer for linux rocm
...
Right link on pytorch installer for linux rocm
2023-03-31 17:22:00 -03:00
Lincoln Stein
1f89cf3343
remove vestiges of non-functional autoimport code for legacy checkpoints
...
- Closes #3075
2023-03-31 04:27:03 -04:00
Lincoln Stein
c4e6511a59
Add support for yet another TI embedding format (main version) ( #3050 )
...
- This PR adds support for embedding files that contain a single key
"emb_params". The only example I know of this format is the
"EasyNegative" embedding on HuggingFace, but there are certainly others.
- This PR also adds support for loading embedding files that have been
saved in safetensors format.
- It also cleans up the code so that the logic of probing for and
selecting the right format parser is clear.
- This is the same as #3045 , which is on the 2.3 branch.
2023-03-31 03:57:57 -04:00
Lincoln Stein
44843be4c8
Merge branch 'main' into enhance/support-another-embedding-format-main
2023-03-30 23:16:52 -04:00