README
github-cube
This CLI allows you to perform Git and Github tasks straight form the terminal and it allows you to deploy your code directly to your webserver.
Installation
Install the package globally with npm with the command:
npm i github-cube -g
Dependencies
Git and Node.js must be installed to run this package.
Usage
After you installed the package globally you can run the CLI by just enter ghc
in your terminal. This will give you an overview of the available actions.
You can also provide arguments to access the functions directly.
The following functions are at the moment available:
Init
This will create an empty Git repository.
Create gitignore file
This command will give you recursivley all the files in your directroy. You will be promtes to choose all the files you want to add to the gitignore file.
Add
You have the option to add all files or you can choose from all the files in your directory which ones you want to add.
Status
With this command you'll get an overview over all change in your directories. You can see the following categories:
- 🟡 Untracked
- 🟠Conflicted
- 🔵 Created
- 🔴 Deleted:
- 🟣 Modified
- ⚪ Renamed
- 🟢 Staged
Commit
WIth the commit command you can choose between predefined categories for a standardized commit-system. You can choose between these categories:
- Feature
- Fix
- Docs
- Style
- Refactor
- Performance
- Test
- Build
Push
It will propt you all your remotes from which you can choose to which remote you want to push your changes.
Add remote
Let's you add a remote to your git repository
Add live-remote
Let's you add a live remote to push your repository to your webserver via SSH.
Remove remote
Let's you remove already created removes
Deploy
It's acutally the same as push, but it will only show you the remotes that contains an SSH address. Use the function Add Live Remote to define a remote which points to your server. To learn how to configure your server to make the deploy function work, read aboout the dependencies for deploy function
Authentification
For some functions, GitHub must identify you in order to provide the functionallities to clone or create projects from GitHub. In order to do so, this package uses a personal access token.
The first time you use a function like clone or create repository the terminal will prompt you a message and it will ask you for your username and your personal access token.
You can create a personal access token by following the manual from GitHub.
Your credentials will be safed locally and it will not be uploaded at any time. If you want to change the credentials once you set them up, you can find and edit them in the directory /lib/userdata.json
.
Dependencies for deploy function
Before you use and follow this function, let me tell you that this script is written by a fool. If you are not familar with SSH, Ngnix or Apache do not blindly use this script, because it has the potencial to overwrite data on your server. You will follow this manual on your own responsibility.
In order to use the deploy function, you need:
- access to a webserver (Ngnix or Apache will work)
- an adminuser or an user with read and write permissions for the 'www' or 'html' (depending on your webserver)
- Optional but not required is to use an SSH key to login to the server without the need to provide the password for the server
Login to your webserver and create anfolder called ${domain-name}.git and create a bare git repository inside it with the following command:
git init --bare
If you use an Nginx webserver you probably want to initialize the git repository in the directory
/usr/share/nginx/repositories/${domain-name}.git/
and if you are using an apache webserver you probably want to create the repository inside/var/repositories/${domain-name}.git/
In the created repository cd into the folder
/hooks
and create a the filepost-receive
.# for Nginx cd /usr/share/nginx/repositories/${domain-name}.git/hooks touch post-receive # for Apache cd /var/www/repositories/${domain-name}.git/hooks touch post-receive
In the newly created
post-receive
file, declare the script as bash script and set the path of the Git repository and the path of the public html folder like in the snippet below:#!/bin/sh # for Nginx git --work-tree=/usr/share/nginx/html/ --git-dir=/usr/share/nginx/repositories/${domain-name}.git checkout -f master # for Apache git --work-tree=/var/www/ --git-dir=/var/repositories/${domain-name}.git/ checkout -f master
The snippets below can be used as an example, but it can be that your server is configured differently and that you have to adjust the paths.
Make sure that the file
post-receive
is executable by the command:chmod +x post-receive
Make a Live-Remote and provide the username and the host or IP address to the function.
Use the function Deploy to push your repository to the server. That's it, if you have done everything correctly, your repository will now be deployed!