Support for nested stacks directory #687
Open
+104
−69
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
https://github.com/louislam/dockge/blob/master/CONTRIBUTING.md
Tick the checkbox if you understand [x]:
Description
This PR accompanies the discussion in #214.
Currently, dockge assumes all stacks are exactly one level deep in the stacks directory, and the "name" of a project equals the name of the folder containing it. This assumption is not quite right, and leads to weird behavior where dockge can be "tricked" into thinking a random folder is a docker compose project, or will simply not distinguish between two separate projects.
Some examples of where this assumption breaks:
$stacksDir/project/compose-dev.yml
and$stacksDir/project/compose-prod.yml
). If there is also acompose.yml
dockge will assign both projects the name "project" and not distinguish between them.$stacksDir/application1/authentik
and$stacksDir/application2/authentik
). Dockge will assign both projects the nameauthentik
and will not distinguish them.$notStacksDir/application3/authentik
will produce yet another naming conflict).compose-dev.yml
is not in theacceptedComposeFileNames
) dockge will simply not work with this project. This behavior is undocumented.In these cases the user will tell
docker compose
to tag the project with different names. Sodocker compose
will be aware of the difference but dockge will behave strangely. Plus, people with many (say, 20+) projects running on one machine will most certainly want to use some nesting to organize their stacks directory. For these reasons, I think lettingdocker compose
should be the main source of truth.A real example I had while testing this is I had a
server
directory I want to use as mystacksDir
that contains a folder calledauthentik
. This folder is actually a volume mount for my authentik project, and does not contain a config file. The actual authentik stack is running from a different location on my machine. Even thoughdockge
tries to skip folders that don't contain anacceptedComposeFilename
, the name of the folder matches the name of a project that appears in the output ofdocker compose ls
, so dockge thinks it is a project managed by dockge and then says it cannot find the configuration file:This PR treats
docker compose ls
as the main source of truth, and puts the folder scan afterwards as a "nice to have" for discovering unknown projects. And it fixes the issue described above!There are two commits in this PR that cover the two pieces of functionality changed. They can be reviewed separately, and the first half can be merged independently if you don't like the second. This changes some existing functionality, but everything that used to work should work the same as before, if not slightly better.
The first part focuses on the
stacks.ts
logic that assumes a stack "managed by dockge" means it lives in the folder$stacksDir + $projectName
. It asks docker compose for a list of projects and treats all the projects where the config file starts withstacksDir
as being managed by dockge (currentmaster
does a folder search then asksdocker compose
for services not managed by dockge, but they all go into the string map which can cause conflicts).The second part restores dockge's ability to "discover" projects that had never been run through the CLI, by adding the folder search after the call to docker compose. But it makes that search recursive using node FS. In case of a naming conflict between a "known" project and a "discovered" project, it keeps the "known" project but adds some extra logging and makes dockge's behavior extra transparent. Naming conflicts between projects "known" to docker compose will still happen if the user makes an error using docker compose (e.g.. not tagging projects with names), but at least dockge's behavior will match
docker compose
's.Fixes #(issue)
#214
Type of change
Please delete any options that are not relevant.
Checklist
(including JSDoc for methods)
Screenshots (if any)
Please do not use any external image service. Instead, just paste in or drag and drop the image here, and it will be uploaded automatically.