Allow custom ports
- 
No, I want a more usable generic container to use apps within Cloudron that have not been packaged yet. These can also be the aforementioned app backups one can import. It's also not helpful to have to modify the system nginx config for proxy port changes, so there needs to be a way for that to work from the LAMP app container itself. 
- 
This all sounds to me like having a custom app package is the way forward, if those apps anyways run their own webserver and expose that port, it should be a rather simple Dockerfile and CloudronManifest with a start.sh just running that? @nebulon Absolutely not. This is the difference between forcing a relatively difficult custom package with... 1 ...all the other dreaded required things one must do, which includes cloudron-cli, build service, container registry/repo, including a separate host for running cloudron-cli from, etc. ... (it's a bit ridiculous that one can't do this all from a single self-hosted place, like the build service container all in a single cloudron system app! Shame) 2 ...as opposed to allowing for using the LAMP app (or another specific app designed for this) to wget a release archive and run it, potentially adjusting some env vars and port, to have a running app quickly with minimal requirements. Users have a hard time with 1, and a lot less with 2. Users are not devs, and you want to be nice to the users and encourage them to look into a gentle onramp to making a custom package eventually, and this currently does not exist.. I hope you understand where this is going and how it complements the idea of saving such app backups, making it even easier for users to import a working app from scenario 2. 
- 
I understand if building an app image is only for devs and sysadmins, as it does require some terminal use and also docker running locally at least (the build services is not required at all). In fact all is required is the cloudron cli and a docker image id (which does not need to be built for Cloudron either). But to take a step back, it does sound like you are looking for a generic app package, which is like a vm runtime to run any process/script/... which is uploaded into /app/data/. So just like the lamp app only for other stacks with all possible addons enabled. LAMP is only here since it has such a long legacy in linux servers, but really for other stacks it makes so much more sense to write aCloudronManifest.jsonand a simpleDockerimagealongside to get all the benefits. I feel like there may be some options to streamline that flow instead of just trying to provide some generic and very hard to update/maintain app package from our side.
- 
I understand if building an app image is only for devs and sysadmins, as it does require some terminal use and also docker running locally at least (the build services is not required at all). In fact all is required is the cloudron cli and a docker image id (which does not need to be built for Cloudron either). But to take a step back, it does sound like you are looking for a generic app package, which is like a vm runtime to run any process/script/... which is uploaded into /app/data/. So just like the lamp app only for other stacks with all possible addons enabled. LAMP is only here since it has such a long legacy in linux servers, but really for other stacks it makes so much more sense to write aCloudronManifest.jsonand a simpleDockerimagealongside to get all the benefits. I feel like there may be some options to streamline that flow instead of just trying to provide some generic and very hard to update/maintain app package from our side.@nebulon said in Allow custom ports: it does sound like you are looking for a generic app package, which is like a vm runtime to run any process/script/... which is uploaded into /app/data/. This could be interpreted very broadly, therefore that's not the ask, however that is the end goal if you'd rather solve for that and include the ask in the OP. Many ways to approach that, which we've covered previously with simple sysbox integration which enhances docker capabilities 10-fold with a single parameter on container launch, and a LEMP or even more generic stack container Cloudron app, all of which make the app backups import/export more functional and open up a new realm of not-yet-packaged app snapshots for more users. 
- 
 R robi marked this topic as a question on R robi marked this topic as a question on
- 
@robi Use case is clear. The manifest is currently quite static because the design goal is for pre-packaged apps where databases, ports, addons, dependencies, backups are known in advance. Having things optional and dynamic requires fundamental changes and it's a non-trivial change. Anything is possible of course, so if many want this, we have to look into it. 
- 
@robi Use case is clear. The manifest is currently quite static because the design goal is for pre-packaged apps where databases, ports, addons, dependencies, backups are known in advance. Having things optional and dynamic requires fundamental changes and it's a non-trivial change. Anything is possible of course, so if many want this, we have to look into it. @girish This is not about the manifest or port config there. As stated in the OP, this is about the ability to modify the LAMP container based apache2 defined port in /etc/apache2, which is read-only and cannot be overridden with the config file in /app/data/apache. This should be a simple change with an update to the LAMP package. How do we do that? P.S. I can make a separate Feature Request, if you wish, for the ability to better control the Nginx proxy port config for Cloudron apps, which would be a larger platform change (which still would not impact the app manifest). 
- 
@girish This is not about the manifest or port config there. As stated in the OP, this is about the ability to modify the LAMP container based apache2 defined port in /etc/apache2, which is read-only and cannot be overridden with the config file in /app/data/apache. This should be a simple change with an update to the LAMP package. How do we do that? P.S. I can make a separate Feature Request, if you wish, for the ability to better control the Nginx proxy port config for Cloudron apps, which would be a larger platform change (which still would not impact the app manifest). 
- 
@robi said in Allow custom ports: This should be a simple change with an update to the LAMP package. It's not a simple change. The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic. @girish said in Allow custom ports: The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic. Isn't the manifest info for the Cloudron side of things? Container and proxy config, etc. Separate from the ability to manually reconfigure apache after the default install? 
- 
@girish said in Allow custom ports: On a side note, you can also just configure apache to proxy_pass to your app's port. Hmm, a double proxy, good idea to test! @robi we use such a thing in some apps like espocrm - https://git.cloudron.io/cloudron/espocrm-app/-/blob/master/apache/espocrm.conf?ref_type=heads#L20 . Many apps have nginx doing proxy pass in the container as well (taiga, pixelfed, onlyoffice, immich, sogo, jitsi etc). 
- 
@girish said in Allow custom ports: The http port number that apache exposes is coded in the manifest. This requires the manifest to by dynamic. Isn't the manifest info for the Cloudron side of things? Container and proxy config, etc. Separate from the ability to manually reconfigure apache after the default install? @robi said in Allow custom ports: Separate from the ability to manually reconfigure apache after the default install? The container exposes a port, 80 in this case. This 80 is hardcoded as httpPortin the manifest.Thinking more, maybe what you mean is: disable apache altogether, I will run something else on port 80. If this is the case, you are right that manifest does not need to be changed. I don't think we will support this though. It's not a normal flow to install LAMP and then disable apache as first step and run something else. This works for your specific situation only because you don't want a database or expose another port. What if I want postgres? Java? At this point, you will install everything into a data directory and run it from there. This is really not in the spirit of Cloudron. 
- 
 J james has marked this topic as solved on J james has marked this topic as solved on
 

