Commit Graph

176 Commits

Author SHA1 Message Date
1ef1903f6b Major Enhancements (#20)
* Fix program for html websites, need to handle errors for non-local sites though.

* Add message that the main program is starting since node-modules does not show anything.

* Go ahead and give DB a bump.

* Fix warning in DB log and NC not having enough power sometimes.

* Fix errors in DB log.

* This command uses the root account, not nextcloud.

* Add example CRON file.

* Specify that the host network should be used.

* Specify that the host network should be used.

* Recommend daily reset of the photos library.

* Add another package the container is missing.

* Add a backup script for the project directory.

* Fix a typo.

* Improve example file and add the backup job.

* Add an example of pulling the backup file.

* Give the zip a temporary filename while being built.

* Always get the full path, relative path does not work well when not in `.`.

* Remove extra newline.

* Prevent doing large uploads on a micro Nextcloud instance.

* Change how bz2 gets installed.

* More trying to fix the annoying bz2 warning.

* Remove "bad" package.

* Use a temporary filename during transfer.

* Bump CPUs up just a bit more for Nextcloud to avoid sync errors.

* Be more explicit with instructions.
2024-01-30 06:11:32 -07:00
cf0d028a58 Nextcloud Purge Script, Hyperling.com Static Media Volume, Memory Tweaks (#19)
* Fix memory; was accidentally done in `docker-compose.yml`.

* Fix bad path.

* Prevent DB from crashing during `fixes.sh`.

* Bump the DB up a little more.

* Add photos directory.

* Log files as they copy.

* Increase certbot by a little, was maxing near 15MB after an image update.

* Add a HUGE space saver to the cleanup crew.

* Add the beginnings of a purge script. Helps try to bring down the DB size.

* Enhance output.

* Further enhance output.

* Fix loading of ENV.

* Enhance output. Purge file previews.

* Fix extra newline.

* Add sourcing of main ENV, use RM instead of MV to reduce steps.

* Fix rm command.

* Ensure maintenance mode is off when starting.

* Add volume rather than duplicating all media.

* Ignore media.

* Check space before as well.
2024-01-25 02:49:00 +00:00
fa892cb3bd Add Micro Configurations (#18)
* Begin changing files to recommendations rather than actual contents, that way multiple examples can be shown and when they are changed to be the real .yml they are not added to the project.

* Shrink the PHP limits more.

* Convert all configurations to be micro/standard.

* Double check the script supports IPv6. Shrink case statement.

* Fix uncommented nc-oo.

* Shrink NC further.

* Change name of env example.

* Change name of env example.

* Do not provide micro versions of DNS or PhotoPrism.

* Fix error in NC checks, wants at least 512M.

* Shrink more.

* Add a folder to keep static resources.

* Copy static resources into the container. This unfortunately doubles the size right now. Maybe do a volume in the future.

* Bring the description up to date.

* Make the description slightly more agnostic.

* Be more consistent about using variable.
2024-01-24 11:05:44 +00:00
08a4d93282 Clean, Enhance, and Fix (#17)
* Fix program for html websites, need to handle errors for non-local sites though.

* Call cron script and enhance output.

* Abandon unfinished configurations.
2024-01-23 09:46:10 -07:00
f45cc326fc Fixes and Enhancements (#16)
* Add more instructions after successfully creating a new subdomain.

* Update the container name.

* Add a just-in-case step.

* Add an alias and improve comments.

* Fix manage path.

* Add limits but no reservations for PP. Start off somewhat relaxed rather than strict.

* Always restart PP containers.

* Move URL to env file. Do not recommend using HTTPS in the value.

* Format comments.

* Put commands in shells so they cannot exit the full program.

* Updating apps like this did not seem to be working, but also do not want it to work anymore.
2023-10-17 04:35:57 -07:00
eb79978adf Add PhotoPrism (#15)
* Add initial configuration for PhotoPrism. Has not been tested yet, but options have been analyzed and tweaked.

* Begin testing. Fixes. Running pretty well, seems neat! Need to figure out user management other than admin.

* Add output to source so that we know it worked.

* Modify comments to explain a use free-to-win use case.

* Go ahead and give the full path on the success path.
2023-09-15 10:01:25 -07:00
f56b3da23d Manage Script, Resource Limits, OnlyOffice Changes (#14)
* Create explicit file for cron, add two automations from fixes.

* Merge the OnlyOffice project into the Nextcloud project. Enhance comments and changelog. Make the container names consistent.

* Found the link. :)

* Add more variables.

* Add a TBD file for mail server.

* Create new script which will replace most the existing single purpose management scripts.

* Add limit to DNS so that if Internet goes out it does not max system resources.

* Prevent OnlyOffice from getting too hungry.

* Ensure Reverse Proxy always has at least some resources.

* Separate build. Add stats -s and combination option -A.

* Make script config file aware. Add comments.

* Add more comments.

* Fix comments.

* Further determine resource allocations.

* Also avoid checking for cron's call to the program.

* Add clean and log parameters. Some clean up.

* Update setups to have DIR first.

* Remove files taken over by manage script.

* Cleaning comments and output.
2023-09-01 05:50:29 -07:00
fbad19dc51 Finish OnlyOffice Setup (#13)
* Add newlines in output.

* Remove fancy DNS attempts to get NC and OO to talk. Just had to give NC the local IP through the Advanced settings. Yay!!
2023-08-22 04:38:52 +00:00
f205dbfcd5 Add DNS Server, Many Other Fixes/Enhancements (#12)
* Add 443 just in case since docker ps is showing it as active.

* Add two new projects.

* Add pre-testing content for DNS.

* Initial untested stab at the GitLab config.

* This project uses build, image name is not needed.

* Cleanup, untested guess at how to handle the variables in the pipe section.

* Filled out all files for DNS. Ready for testing.

* This seems to work, Ubuntu is hoarding port 53 though even though local services are shut off.

* `dnsmasq` container is testing successfully now.

* Don't allow a run unless the config files exist.

* Correct the crontab entry so that $RANDOM works correctly.

* Certs were not being saved by LetsEncrypt for Nginx correctly. Should be working now.

* Do not allow disabled folders into Git.

* Do not allow disabled folders into Git, 2.

* Do not allow disabled folders into Git, 3.

* Do not allow disabled folders into Git, 4.

* Do not allow disabled folders into Git, 5.

* Do not allow disabled folders into Git, 6.

* Don't add logs from anywhere.

* Add ping and dig to Nextcloud container for troubleshooting.

* Fix tabs.

* Make unfinished suffix consistent.

* Clean whitespace.

* Multiple names for a single IP address.

* Add 2nd example domain from hosts file.

* Add caching program Redis for Nextcloud.

* Add REDIS_HOST variable for automatic setup through config/redis.config.php.

* Upgrade to compose version 3.

* Move OnlyOffice to Nextcloud area.

* Change container name.

* Add container_name to all compose services.

* Shorten names for Nextcloud services.

* Comment possible OO fixes while trying to get container to use DNS.

* Remove OnlyOffice setting tests.

* Do not commit .env files, only their examples.

* Move OnlyOffice to be its own configuration again. Add sourcing of DNS settings so that local traffic routes correctly.

* Fix source file, BASH_SROUCE did not work without the shebang. Also fix bug for when it sees `..` and assumes current directory.

* dns.env file did not work out, env_file: element not being read before dns: element. Using folder-specific .env files instead, seems to be loaded before dns: element. Also move other values to the env files for better password privacy.

* Keep commands for cleaning up environment in one file.

* Update examples.

* Fix cd moving the user to the file's directory.

* Add note for user to set up the env file.

* Replace README files by unhiding the example files.

* Still need to specify the variables in the environment: element.

* Add header variable.

* Place host above database.

* Fix "JWS" typo.

* Do not use the HEADER parameter.

* Add vim to fix packages.

* Forget about the manual DNS servers for a minute, ensure host is set up properly first. Ubuntu is happy but Debian is not.

* Try using the host network explicitly.

* Temporarily give up on having Nextcloud server see local OnlyOffice server. Works when they are different machines but need them together.
2023-08-21 22:07:46 +00:00
43dee35d85 Start Invidious, Add OnlyOffice, Fixes (#11)
* Add directory and a link to the install instructions.

* Fix env file if user is in the current directory.

* Initial work on the Invidious configuration and README.

* Add postgres variables and TBD.

* Disabled the Invidious project, it is a lower priority than OnlyOffice and Mail.

* Allow disabled files to stay in the project, truly only block files with backup in the name.

* Create a file for OnlyOffice.

* Change the restart method to ALWAYS.

* Changed from disabled to TBD.

* Add a note to its README as well.
2023-07-25 22:20:56 +00:00
8602f7ada2 Fix Directory Hardcodes, Documentation Improvements (#10)
* Improve the main crontab example.

* Remove /opt/Docker hardcodes.

* Add periods.

* Improve readability.

* Begin removing hardcoded path from the bin files.

* Update main README to no longer enforce hardcoded path. Other improvements.

* Add the load folder with a README.

* Add load folder and its README.

* Improve reverse proxy text files.

* Switch to tabs.

* Update all scripts for tabs, DOCKER_HOME, and comments.

* Let users know the directory choice is optional.

* Fix environment file.

* Add more details for the reverse proxy load balancing.

* Don't actually listen for postgres.

* Fix comments on source file.

* Be more explicit on the pathing.
2023-07-23 14:51:48 -07:00
e383520ebb Add Dynamic DNS Script (#9)
* Initial commit for Dynamic DNS code. Not in a runnable state but as far as I can get for now.

* Bring shell script for Dynamic DNS to working order. Dry runs are going well. Have not tested against a production environment yet.

* Add instructions for No-IP in case it needs installed later..

* Variablize the full path to the keyfile. Enforce strict permissions on the file.

* Final updates after successful testing.

* Update instructions, add examples.

* Fix usage.

* Remove unnecessary asterisk.
2023-07-23 13:14:47 -07:00
5d9c5e495d Small Reverse Proxy Enhancements (#8)
* Only load certs for domains which are doing a proxy. 301 redirects do not need certs.

* Fix tabs to spaces.

* Add slash to match Hyperling.com script.

* Fix comment capitalization.
2023-07-23 02:32:53 +00:00
4c24c30526 ReverseProxy Fixes, Nextcloud MariaDB Upgrade (#7)
* Working on getting Reverse Proxy certs to work.

* Upgrade mariadb to 10.6.

* Checking if anything has missed a check in.

* Let's Encrypt is working now after moving the location directive to the conf.d files. Unsure why nginx.conf is not passing it along, so added it to the examples too.
2023-07-21 22:23:46 -07:00
3c46dfec01 Fixes for Reverse Proxy Go-Live (#6)
* Add new area for defining upstream systems.

* Example file for demonstration domain.

* Use the new upstream hosts section.

* Do the proxy directives in the main file.

* Commit any final changes.

* Fix example resource name.

* Mention the need to have ports specified in the upstream file, not server block.

* Adjust formatting.
2023-07-09 16:02:47 -07:00
9de4ff19d2 Merge branch 'main' into reverseproxy 2023-07-09 06:40:59 -07:00
e5688f4f3c Remove README files from container. Add comment headers. 2023-07-09 06:36:58 -07:00
db8413a9de Add a TBD for stream{}. 2023-07-09 06:36:37 -07:00
7416971edf Add favicon for example site. 2023-07-08 13:29:19 -07:00
571480b3f3 Add explicit path to conf.d, remove tabs. 2023-07-08 12:51:40 -07:00
d5e090981e Update README now that example exists. 2023-07-08 12:50:37 -07:00
e95464cf7a Remove "you" verbiage. 2023-07-08 12:49:26 -07:00
07dcfa2c16 Add period. 2023-07-08 12:47:26 -07:00
0f2bd38745 Modifying to serve the HTML content. It works, hooray! 2023-07-08 12:43:01 -07:00
46c4164636 Take into account anything with example.com as being an example. 2023-07-08 12:35:12 -07:00
cb51b41fe3 Rename example.com to proxy.example.com. 2023-07-08 12:34:54 -07:00
a122f651ac Add an HTML example. 2023-07-08 12:34:33 -07:00
a5c15a577a Copy the HTML configuration the the container. 2023-07-08 12:28:27 -07:00
f1a9e174a4 Add an HTML section. 2023-07-08 12:27:56 -07:00
62e5cc3ef7 Add a naughty list of things to do. 2023-07-08 12:26:50 -07:00
9208295a42 Fix typo, change comments, playing with headers. 2023-07-08 12:10:37 -07:00
3ea2443da4 Comment the directory which does not exist yet. 2023-07-08 11:57:57 -07:00
a0d3731e15 Add the mail section for later. Confirmed that docker is compiled with the mail modules. 2023-07-08 11:32:22 -07:00
f55880e0df Forward additional headers. 2023-07-08 11:31:37 -07:00
bf2fd2bb28 Add comment sections, use CERT_DIR, add exit 0. 2023-07-08 08:18:14 -07:00
478cce43b5 Create script to get real certificates. Programs are functional but have not tried pointing the production router to the test box yet to see if the challenge will pass. 2023-07-06 07:33:17 -07:00
7be7df9b45 File is no longer necessary due to the README.md in the subproject home. 2023-07-06 06:52:31 -07:00
3b7b848eb4 Fix wording. 2023-07-06 06:52:14 -07:00
95714bc385 Add more notes. 2023-07-06 06:50:58 -07:00
81f8817e96 Remove any existing files before copying the new ones. 2023-07-06 06:50:46 -07:00
cf73304bfe Display the files which have been created. 2023-07-06 06:50:31 -07:00
51e29ae2ab Undo indent, made it into a normal monospaced block. 2023-07-06 06:16:39 -07:00
4257654c03 Test indenting the bottom code blocks as well. 2023-07-06 06:15:45 -07:00
0757cc340c Attempt to fix the numbering. 2023-07-06 06:13:26 -07:00
dbf350607b Add helpful instructions/notes for the Reverse Proxy setup. 2023-07-06 06:10:41 -07:00
cea611c81c Create temporary cert process so that nginx can start. Still need to figure out if/how certbot will attempt to renew domains in conf.d. Lowered the cert days in case it checks that. 2023-07-05 21:17:14 -07:00
38b6eb718f Rename example.conf to be the website name. 2023-07-05 21:06:35 -07:00
bf2bcf78ea Begin adding LetsEncrypt. Project runs successfully but still has a slight chicken and egg issue if certs are not copied from another server. 2023-07-05 20:54:53 -07:00
bf0e25cfb0 Add file with how to copy the config files to the container. 2023-07-05 20:36:58 -07:00
67a1f3cd0c Finish a working example. 2023-07-05 20:02:50 -07:00