Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

make install assumes output goes to a user home-folder. Should not assume anything #209

Closed
etamminga opened this issue Nov 15, 2023 · 3 comments
Labels
bug Something isn't working

Comments

@etamminga
Copy link

What happened

make install with the following .config file:

BASE_USER="admin"
CROWSNEST_USTREAMER_REPO_SHIP="https://github.com/pikvm/ustreamer.git"
CROWSNEST_USTREAMER_REPO_BRANCH="master"
CROWSNEST_CAMERA_STREAMER_REPO_SHIP="https://github.com/ayufan/camera-streamer.git"
CROWSNEST_CAMERA_STREAMER_REPO_BRANCH="master"
CROWSNEST_CONFIG_PATH="/opt/klipper/printer_data/config"
CROWSNEST_LOG_PATH="/opt/klipper/printer_data/logs"
CROWSNEST_ENV_PATH="/opt/klipper/printer_data/systemd"
CROWSNEST_ADD_CROWSNEST_MOONRAKER="0"

tools/libs/core.sh in function install_env_file() assumes the username $(BASE_USER) must exist in the env file. If it does not exists, it returns an error. My CROWSNET_ENV_PATH does not contain the name of the user.

Better would be to test for the %CONFPATH% keyword to exist. If it exists, return an error.

What did you expect to happen

Install in my specified folder

How to reproduce

Create mentioned .config file and do a make install

Additional information

No response

@etamminga etamminga added the bug Something isn't working label Nov 15, 2023
@mryel00
Copy link
Member

mryel00 commented Nov 16, 2023

You are right but this whole tools/.config option was designed around multi-instance Klipper+Moonraker setups. There was never an intention of setting anything outside the home directory of your user.
Currently the implementation only limits the config file to be inside the home directory of BASE_USER. As a linux file is normally readable by default by anyone, there shouldn't be any problems. So I will change that with the next update.

You and everyone else have to understand that we don't support any setup that are outside the "normal" setup for Moonraker and Klipper. If you get any problems editing your config or that the log file doesn't get written to or anything similar, we won't support you on that, as this is out of the scope of the intended purpose of Crowsnest.

So I will "fix" this bug as it doesn't make sense for the overall implementation but with every problem following that you will be on your own.

The fix will be that we check on CROWSNEST_CONFIG_PATH as in every other part of that installation. That parameter will be inserted for %CONFPATH%. So checking for %CONFPATH% doesn't make any sense and would lead to the same error you already got.

@etamminga
Copy link
Author

Thank you!

It's not my intention to force any support. Just mentioning an item that could be better implemented. I (We) don't know any of the design principles. So just reporting what I find.
Found this during development of an ansible role to install klipper for my personal setup. (for when the Pi SD fails again on me)

@mryel00
Copy link
Member

mryel00 commented Nov 16, 2023

It's not my intention to force any support. Just mentioning an item that could be better implemented. I (We) don't know any of the design principles. So just reporting what I find.

I'm glad for that, don't get me wrong😄
I just wanted to clearly state this at some point, not that someone else comes across this and thinks we would now do support on setups like that.

Thank you again for the heads up on that implementation detail.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

2 participants