Monday? What is Monday you are asking? Monday is a package of scripts in order to push and pull from a cental storage location. A little background. I have always used GitHub repo's as a central means of storing anything that I wanted to share among my other computers. No More! I had extra computer hardware laying around to setup a simple server to recieve ssh communication (port 22), and created these scripts to mimic the workings of git pull and git push. Now all you have to do is type push "file or directory" or pull "file or directory. Simple huh?
The two main scripts are the push and pull. I have heavily documented the scripts and have added a usage that will aid in your ability to use these scripts affectively. Trust me, they are not black magic... or maybe they are? Anywho, there is a little bit of setup that you will have to do, both on your client and server pc. I have tried my hardest to make this process easy with the setup.sh script. There still is a little of manual setup for the server that you will have to do but other than that follow the prompt. I would not recommend closing the terminal or control C'ing the script, I've tried my best to add error handling and cleanup, and would hate for you to have to comb through all the script to see what broke.
A couple last little details to mention before I go. First, I am no daily scripter, so if you see anything that could be done differently, then by all means I'll take any comments or PR's. Second, it would be super helpful if you setup your ssh keys before trying to get this package to work between your client and server. There are two password entries needed for each script, and ten for the tests. So, all that typing can get rather annoying. Lastly, I hope you enjoy my package of scripts here, and that you contribute if you find a better way of doing things. Thanks~!
Just follow the upcoming sections they should make startup very clear.
Since these are bash scripts, please make sure to always check any scripts that you are going to run on your system! Also every machine is setup differently and I would hate for these scripts to overwrite any precious keys or any other information. So please, make sure to understand how these scripts are working and what they are doing. There is enough documentation in the files to make the learning transition faster.
The only prerequisites is that you need to use the Bash shell on your system in order to be able to use the scripts. I have not supported the other shells yet and have only gotten this package to work with Bash. Lastly, your clients and server have to be some type of Linux Distro and they do not have to be of the same distro.
Just run the setup.sh script in the package directory. There will be stuff that you have to do manually on your server for this package to work as anticipated and thats just editing the ssh config file. Just follow the setup.sh prompt. If you would like to develop the code then run the setup script like so: ./setup.sh -develop. This will setup a directory in your home directory called .monday and you should be able to see where everything is at from there.
You would think that there should be no problems with having an updated version of Bash on your system and you would be wrong. Here is a list of things that you will have to do in order for getitng these scripts to work on Mac.
- Install Brew: /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
- Install Bash: brew install bash
- Change the /etc/shells: sudo nano /etc/shells and change the /bin/bash to /usr/local/bin/bash
- Logout and back in.
- Then do echo $BASH_VERSION and it should read like 5.0.0, if you do which or bash --version it will keep reading from /bin/bash because of your path. You can update your path if you want to change this.
- When you install these scripts then you will need to read the .bash_profile and change the bash "script" alias to /usr/local/bin/bash "script" so that it is pointing at the new bash version.
- Merry Christmas
There is a test script included into the source for checking if your installation is working or if any changes that you have implemented are working. You will have to run it in the following manner: "source ./test.sh". Now I don't know if every shell supports the command "source" so again these scripts will only work in bash as of right now. Add more tests if you see anything that I am missing.
Every script that you are able to run in this package has a -h or --help feature that will give you a usage that should be more helpful with all the avalable arguments that eah script can take.
Like I've said in the previous sections I hope that people get to use these scripts and contribute. Before submitting a PR, I've written a script call credential scan to remove any credentials that you could be stored in the scripts. There is a specific thing that the script is looking for so don't go stashing your IP address or Username anywhere else than needed. This will save a lot of hassel.. trust me, so run the script.
I choose a lazy person to do a hard job. Because a lazy person will find an easy way to do it.
- Bill Gates