/git-autocommit

Primary LanguageShellGNU General Public License v3.0GPL-3.0

git-autocommit

A bash script to automate pushing changes to github

Image

It Employs inotifywait (a Linux System Call from the inotify family) to recursively watch a directory for changes. Triggers Commands to push changes when they are detected.

This script can be easily modified for any VCS / Cloud provider which provides command-line interface.

Supporting Medium Article : https://medium.com/@apsychogirl/the-crio-bootcamp-2aa2f4016e28?sk=b8202f2abaa29201e0eebe342cefa101

Before Using :

  1. Make sure git or whatever VCS you're using is configured properly (SSH keys) and you already have cloned the target repo to your local machine.
  2. Make sure you have inotify-tools installed. (if not, Ubuntu users can type : sudo apt-get install inotify-tools) for other Distros : https://github.com/inotify-tools/inotify-tools/wiki
  3. Make sure you have the correct path of the cloned repo in the script.

Using the script :

  • Use ./watch.sh to run it in the foreground
  • Use ./watch.sh & to run it in the background

How to stop the script from running in the background

  • If you run the script using ./watch.sh, it will terminate as soon as one presses Ctrl+C or Exits the Terminal Session.

  • If you run the script in the background (which is convinient) using ./watch.sh &

    The Ampersand sign (&) makes it or any process for that matter, to run in the background

    Once you're done using the script, it becomes tricky to stop the script. One way is to restart the machine which is easy but not convinient.

    Here is the smart method :

    Use ps aux | grep "watch.sh", find the PID of the script and then killing it using kill PID_of_watch.sh

    After that you'll have to run ps aux | grep "inotify", find the PID of inotify and then killing it using kill PID_of_inotify

Important Links for reference :

  1. To add ssh-keys : https://docs.github.com/en/enterprise/2.18/user/github/authenticating-to-github/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent#generating-a-new-ssh-key

  2. Installing inotify-tools and more info : https://github.com/inotify-tools/inotify-tools/wiki

  3. Whats is /dev/null : https://linuxhint.com/what_is_dev_null/

  4. More about the kill command : http://linuxcommand.org/lc3_man_pages/kill1.html (one could go through man kill alternatively)

  5. More about the inotifywait call : https://man7.org/linux/man-pages/man1/inotifywait.1.html (one could go through man inotifywait instead if inotify-tools are installed)

Pull Requests and issues are Welcome !

For any queries feel free reach out : meghajais.mj@gmail.com

One small Caveat

You can't upload files whose induvidual size is larger than 50 MB. You can upload as many files as needed with smaller induvidual size. For larger files, https://git-lfs.github.com/ is recommended