Cloudron as an app inside of Cloudron
-
@girish said in Cloudron as an app inside of Cloudron:
@Lonk Are you already using the hotfix script? https://git.cloudron.io/cloudron/box/#development This is what we use for development.
This looks like a godsend. I just have to figure out how to format hot fixes and use this CLI tool to apply them to my virtual machine Cloudron. Thank you for showing me this!
Also, I saw in that description in your link: “front-end code click here” and it was 404 .
But using this hot fix tool I might be able to contribute to dashboard easier (like the drop down box to choose the vpnclient to connect to).
-
@Lonk said in Cloudron as an app inside of Cloudron:
Also, I saw in that description in your link: “front-end code click here” and it was 404 .
Are you logged into GitLab? I feel like I have solved this permission/visibility issue in GitLab like a million times. I am not sure what GitLab is doing but that setting gets reset of something after each update
-
@girish I clicked on the "click here" link which lead to this:
https://git.cloudron.io/cloudron/dashboard
It asked me to log in, which I did (as Lonk), and it lead to a 404. So I tried clicking it again thinking it could have been a login redirection issue and I'm fully logged in now, and it still says 404.
-
If you want to try and get this going, here are a few rough steps.
- Install sysbox from Nestybox and validate you can spin up containers with sysbox-runc
- Get a small Ubuntu 18.04 image running inside
- Validate networking in and out for basic services
- Install the inner Cloudron and see how to set up DNS and ports so it works for the inner and outter Cloudrons separately.
- Document the kinks
Once this is running, you'll have a base container system image which is special and can run as an App.
It may be useful to set up guacamole as remote desktop access.
Feel free to chime in and add to my list.
-
@girish said in Cloudron as an app inside of Cloudron:
@Lonk It's a separate repo and a separate tool - https://git.cloudron.io/cloudron/cloudron-machine . If you clone and do "npm link . ", it is available in your PATH.
Joel$ cloudron-machine Usage: [options] [command] Options: -V, --version output the version number -h, --help output usage information Commands: hotfix [options] Hotfix Cloudron with latest code ssh [options] [cmds...] Get a remote SSH connection
Ah, I understand, you should fix that in the npm repository description cause I was so confused for a second. Thank you very much for taking the time to write out instructions in how to get the actual tool. ️
But both the commands hotfix and ssh error out instead of displaying manuals. Are there manuals to those commands? Or maybe an example of a hotfix option and ssh option (using fake data of course)?
-
I've only ever logged in via password but I have to use files for the ssh I give it I think. And I must have to be in the root of the cloudron
box
I'm hotfixing:SSH_PASSPHRASE=sshkeypassword cloudron-machine hotfix --cloudron my.example.com --release 6.0.0 --ssh-key keyname
-
@girish I've re-installed Cloudron. I'm assuming I run this
cloudron-machine
hot fix CLI before I set anything up because it goes in via SSH and does it's thing?I just can't tell the syntax and what
hotfix
is in the syntax? Is it a directory of all the changedyellowtent
files in which case it overwrites them? Should I start the folder structure at/yellowtent/
or/box/
? -
The hotfix command currently is really only used and thus tailored to @girish and my use-case. It used to be part of the normal cli tooling, but since it requires a specific folder setup of box and dashboard repo we removed it from there.
In order to make it useful for more people, I think we have to rework that quite a bit.
-
@nebulon said in Cloudron as an app inside of Cloudron:
It used to be part of the normal cli tooling
Yeah, it's still documented in the npm repo as
cloudron machine
for the normal CLI.But it would really help me with updates and applying my hot fixes (one in development made by @girish that's already in
master
but not released, and the other my VPN Client hot fixes until @girish is ready to work with me to integrate them into core in 2021).Basically, @nebulon, is there anyway I can use this tool? @girish acted as if it was the perfect tool to use in my case. Because every update I have to SSH into the server and
nano ../home/yellowtent/box/src/docker.js
along with 3 other files to keep testing my app every time you guys update (it's treacherous, you can't even select text innano
every change has to be manually redone). Soooo, is it possible for me to use this tool to do that?Also, @girish told me I should have permission to see the dashboard repo (the VPN client needs a dropbox in every app's dashboard config to choose which VPN Client to connect to) but it returns a 404 even when logged in (which @girish said was a bug a few posts above this one).
I figured the CLI required an exact folder format. I was guessing the entire installation of Cloudron
/yellowtent/box/
pulled from the server. I then make my hot fixes (including girish's--no-push
hot fix frommaster
). And the hotfix tool took the SSH credentials and diddiffs
to compare and overwrite as needed.Am I close? This tool is very undocumented but girish made it sound like it was needed for me (probably felt bad I was using
nano
viassh
). -
Edit: Disclaimer - I don't want to waste anyone's time so in the end I will RE if need be, but I think my question should require a quick copy paste or two of the directory it needs and the syntax you use. But if that's too much, I'll RE, I don't want to bother you guys. I'm also trying to work on being more concise in written commnication and this decidedly wasn't.
@girish Well, yes, I understand that the tool is ssh-ing into the VPS for the file changes (but didn't know it only restarted box, meaning I can do this at anytime, I've been waiting on setup depending on your response in this thread).
It's just, I don't know from what directory does
cloudron-machine hotfix
hotfix. @nebulon mentioned I neededdashboard
access for it to even work which you'd mentioned with me being logged intogitlab
I should have access to (but it 404s). So, don't get me wrong, I'll RE the crap out of this entire program, I'm just trying not to do so if what nebulon says is true and I don't have access to a vital part of using the tool. I ideally wanted an example (like a copy and paste of the way you use it in the command line, but with fake data ofc). But, I understand if you don't have time for that.You're making it sound like RE-ing wouldn't be a waste of my time then? Cause if I want to build apps and always make sure they work on the bleeding edge of your code, this would make it a lot easier to do so and I'm willing to RE. So, basically, I'm only asking your opinion on if what @nebulon sounded like he was implying that it would be impossible to use tool you recommended me due to currently only having limited access on gitlab (and the file structure necessary that
cloudron-machine
takes requires dashboard access as he said). Or do you think I could RE myself around that issue? Cause I haven't figured out the file directory yet but I also haven't included dashboard so maybe that's why. -
@Lonk Yes, the tool requires dashboard code access to work.
I have made https://git.cloudron.io/cloudron/dashboard/ public for now. I will debug why the internal setting does not work in GitLab when I find the time. Curiously, it works for some users..
For the hotfix itself, the directory structure is that the repos are checked out in same directory. Like if you have a folder "foo", then the repos are in foo/dashboard and foo/box . Then you cd into
foo/box
and then run the hotfix tool. That should really be it.If you want to install a specific release, you have to check out the same tag on both the repos and run hotfix tool again. Also, there is no way to "revert" back to older release in Cloudron, you have to start afresh. We always do rolling updates.
-
@girish said in Cloudron as an app inside of Cloudron:
@Lonk Yes, the tool requires dashboard code access to work.
I have made https://git.cloudron.io/cloudron/dashboard/ public for now. I will debug why the internal setting does not work in GitLab when I find the time. Curiously, it works for some users..
For the hotfix itself, the directory structure is that the repos are checked out in same directory. Like if you have a folder "foo", then the repos are in foo/dashboard and foo/box . Then you cd into
foo/box
and then run the hotfix tool. That should really be it.If you want to install a specific release, you have to check out the same tag on both the repos and run hotfix tool again. Also, there is no way to "revert" back to older release in Cloudron, you have to start afresh. We always do rolling updates.
Omg, you're the best - that was exactly what I needed. Thank you for taking the time to write out, and explain that to me. I'm sorry if I'm a burden sometimes with my verbose questions. Just know I'm grateful for your help! I honestly think this will help me always keep up to date that my current / future apps so that my apps always support the latest Cloudron changes. Sorta like testing on beta before master releases to make sure there are no bugs (once I build out a build process to have my development server always be running on master using this tool).
Anyway, let me know when you want to test "Gitlap Repo Permissions" with my account and
dashboard
"permissions" since we at least both know that my account specifically gets the 404. Maybe that's related to why my account is able to create new repos but unable to import a project from Github (where the current code for the OpenVPN Client is). I'll transfer it at some point, but I couldn't afford the fancy Git Desktop app (that supported any repo) and "GitHub Desktop" is free, so I've just been using that. But I will transfer it over by hand at some point. Likely, after 6.0 comes out when you have time to go over thebox changes
. -
@girish I almost got this working, had to work through some issues being on OS X but the tool fully works. Pretty cool.
But, quick question, this
hotfix
tool expects either a compiled or uncompiled version ofdashboard
and I'm not sure which path is correct: if it's compiled into box the path is/dashboard/dist/dashboard_files
, if it's uncompiled outside ofbox
it's just/dashboard/dashboard_files
.Do you know happen to know off the top of your head?