- [Installation] (#user-content-installation)
- [Run it in the browser] (#user-content-run-it-in-the-browser)
- [API Endpoints] (#user-content-api-endpoints)
- [Usage] (#user-content-usage)
- [Unit Testing] (#user-content-unit-testing)
- [Workflow] (#user-content-workflow)
- [Deployment] (#user-content-deployment)
- [Version Bumping] (#user-content-version-bumping)
Open your terminal if you're on a Unix or Linus machine if you've not done so already after doing the ``` git pull ``` request.
Install all the **dependancies** and **dev dependancies** for the app with the all important **npm install**: ```bash
$ cd URL_Shortener/ $ npm install
</br>
To get the node.js server up and running just navigate into the root directory ` URL_Shortener/ ` and enter:
```bash
$ cd URL_Shortener/
$ npm start
By default the port is set to 3000, you should also see ``` Server running on port 3000 ``` stated in the terminal
after you have the server running, if you don't see that, then something failed and the server should be re-started or you may have forgotten to run the ``` $ npm install ``` command.
To stop the server press: ``` control + ^C ```
\*\* **Remember, you'll have to stop the server and re-run the** ``` $ node src/server.js ``` **command every time you want to check file changes in the bowser** \*\*
If you have nodemon installed, npm i -g nodemon
, you can simply use:
$ cd URL_Shortener/
$ nodemon server.js
Using nodemon
will do a live reload for you every time you save a file in the project... most of the time.
If you do have to manually reload the server just use the $ rs
command to 'restart server'. It's kinda awesome.
In the root directory there is an env.dist
file, URL_Shortener/env.dist
. This file contains the environmental variables used in the app. The variables are:
PORT=3000
DB_NAME=
DB_USER=
DB_PW=
DB_HOST=
DB_SCHEMA=
DB_PORT=
** IMPORTANT **
This file is for distribution only and should be renamed to .env
for the app to run.
Hold on! You're not done yet, you have to fill in your database credentials to connect to your database. If you don't have a database already created make sure to do that first before trying to run this app or it will crash if there's no database to connect to.
This API utilizes a RDBMS. At this time this API has only been tested with MySQL and mariaDB. *[RDBMS]: Relational Database Management System
To install MariaDB on:
- [OSX follow these instructions] (https://mariadb.com/kb/en/mariadb/building-mariadb-on-mac-os-x-using-homebrew/)
- [Windows 10 follow these instructions] (https://mariadb.com/kb/en/mariadb/installing-mariadb-msi-packages-on-windows/)
- [Linux follow these instructions] (https://downloads.mariadb.org/mariadb/repositories/#mirror=limestone)
To install MySQL on:
- [OSX follow these instructions] (https://dev.mysql.com/doc/refman/5.6/en/osx-installation-pkg.html)
- [Windows 10 follow these instructions] (https://dev.mysql.com/doc/refman/5.5/en/windows-installation.html)
- [Linux follow these instructions] (http://dev.mysql.com/doc/refman/5.7/en/linux-installation.html)
After filling in your credentials in the newly renamed .env
file start up your database.
$ cd URL_Shortener/
$ mysql.server start
To stop the database server:
$ cd URL_Shortener/
$ mysql.server stop
Keep in mind that your database should NOT be running on the same port as the API.
This API ships with an example site on how the API can be implemented. It is set up to preform full CRUD using AJAX calls. Just type localhost:3000
in the browser URL after you get the server.js running and you can start going bananas!
After you have the app up and running there are 6 endpoints for the API. The first 3 endpoints require an AJAX call. The 4th is a API status checkup and can be used with an AJAX call if you need to watch for status changes for the API's stability. The 5th is a 301 redirect, no AJAX call needed for this endpoint. The 6th endpoint is used to display all record pairs in the database.
- /v1/shorten-url
-
Creates a short link.
-
This uses the POST method to receive the original URL and set a relationship to the new maumasi.fy short link.
-
This endpoint expects JSON:
{
'originalURL': ['submitted URL']
}
- This will generate a new short link or return an existing short link if the exact URL submitted happens to be in the database already.
- The root URL destination will be pinged. If it fails it will logged it in the console. If it passes it will return the following JSON:
{
'originalURL' : ['URL submitted'],
'maumasi_fied_link' : ['generated short link']
}
- /v1/update-url
-
Updates a short link.
-
This uses the POST method to receive the new URL and set a relationship to the maumasi.fy short link to be reassigned that should be submitted with the new URL.
-
This endpoint expects JSON:
{
'maumasiFyKey': ['your full short link'],
'updatelURL': ['a new URL for this short link']
}
-
This reassigns the short link to a new URL destination.
-
Returns JSON:
{
'originalURL' : ['new URL submited'],
'maumasi_fied_link' : ['short link submitted with new URL']
}
- Important: Some browsers like Chrome will cache URLs and will refer to their own cache history to remember where the short link's last destination was. So, after updating your short link you may have to clear your browser's cache/history for the new short link's destination to take place.
- /v1/remove-url
-
Deletes a short link and it's assigned URL from the database.
-
This uses the POST method to completely remove the short link and it's assigned URL from the database.
-
This endpoint expects JSON:
{
'maumasiFyKey': ['your full short link']
}
- /v1/status
-
Check the status of the API.
-
This uses the GET method.
-
This is used to check the status of the API if you need to do some debugging.
-
Returns JSON:
{
'stable' : [boolean]
}
- /:shortKey
-
Redirects to stored URL when a short link is used.
-
This uses the GET method to redirect the route to the assigned URL in the database using a 301 redirect.
-
The ' :shortKey ' is the key assigned to the stored URL in the database.
-
This is handled by the API, no AJAX call is needed for this endpoint.
- /v1/all-urls
-
Returns an array of all record pairs as one object per pair.
-
This uses the GET method.
-
Return example:
[
{ id: 34,
maumasiFyKey: '3GFom0',
createdAt: Mon Oct 03 2016 06:25:32 GMT-0400,
updatedAt: Mon Oct 03 2016 06:25:32 GMT-0400,
originalURL_ID: 34,
originalURL: {
id: 34,
originalURL: 'https://www.google.com/search?q=sfb%20fgsb&rct=j',
createdAt: Sun Oct 02 2016 20:55:42 GMT-0400,
updatedAt: Sun Oct 02 2016 20:55:42 GMT-0400
}
}
]
This AJAX call was made with jQuery
var $newUrl = $('.newUrl');
var $oldUrl = $('.oldUrl');
var $submit = $('.btn-submit');
var $url = $('input#url');
$submit.on('click', function() {
var formData = {
originalURL: $url.val()
}
// AJAX call to our API
$.ajax({
type: 'POST',
url: 'http://localhost:3000/v1/shorten-url',
data: formData,
success: function(newData) {
// show user their new maumasi.fy link
$oldUrl.html('This URL: ' + newData.originalUrl);
$newUrl.html('truned into this URL : ' + newData.maumasi_fied_link);
$url.val('');
console.log(newData);
},
});
});
You can also do some unit testing using mocha
.
If you did the npm install
then it's already in the app, but you'll still need to install it globally on your machine to use it.
If unit testing is something you like and you don't have mocha
installed then just run the following command in the terminal:
$ cd URL_Shortener/
$ npm i -g mocha
That's it, now just call mocha
just inside the URL_Shortener directory:
$ cd URL_Shortener/
$ mocha
Using this command mocha
will look for the ' test ' directory and run any scripts in there.
Keep in mind that this uses port 3000 and will show a failed test if you try to use it at the same time the app is running on port 3000
To run unit tests in DEBUG mode all you have to do is to define DEBUG as true before running mocha
, like so:
$ cd URL_Shortener/
$ DEBUG=true mocha
Now you will get a robust output log of all major functions, models, and API route endpoints involved in any particular unit test being executed.
At this time Unit Tests are run against all 6 API endpoints, all services under the serviceRepo directory, and all database CRUD models.
Feel free to add your own unit tests!!
This section is meant for contributors.
This project utilizes Git for version control. All instructions in this sections is in reference to git
. If you don't have git installed on your machine follow the instructions [here to get git
up and running] (https://www.atlassian.com/git/tutorials/install-git)
The master branch is the main branch to contribute code but not the branch used for releasing production code. The production branch is called release. From the release branch we'll push out to a staging server as the last filter to catch any mistakes and then promote to a production server.
- The release branch should not be edited directly
- New features should be built on a feature branch and tested before merged into the master branch
- Tag new releases using semantic versioning. Example:
1.1.2
correlates to MAJOR.MINOR.PATCH
The tool gulp is used to automate a few of the most common git tasks. Instead of changing the version
of the API in the URL_Shortener/package.json
gulp is programed to auto bump the specified version position. Additionally gulp will automatically stage all changes made, commit all changes and push everything up to the origin
remote as long as that branch exists on the origin
's side of the remote. There are 3 gulp commands for making these version changes and git automation:
# makes a 'patch' version bump and automates git commands to push to origin
# v1.0.0 becomes v1.0.1
$ gulp patch
# makes a 'minor' version bump and automates git commands to push to origin
# v1.0.0 becomes v1.1.0
$ gulp minor
# makes a 'major' version bump and automates git commands to push to origin
# v1.0.0 becomes v2.0.0
$ gulp major
Patch concerns fixes only. Lower level patches such as mis-spelled words can be edited on the master branch. If many patch fixes are being made to the code functionality such as changing variable naming conventions then a feature brach should be created for that patch and that branch should be named after that patch such as patch_1.1.2. Follow the instructions below to create a feature branch for such a patch.
Create a new feature branch called patch_1.1.2:
$ cd URL_Shortener/
$ git checkout -b patch_1.1.2
$ git add .
$ git commit -m "new feautre branch"
$ git push -u origin patch_1.1.2
This will create the feature branch in the GitHub Repo as well as your local machine.
Inside this new branch you can make any changes you need to. Before trying to merge
your patch to the master branch run the unit tests to make sure you're not committing broken code to the master branch.
$ cd URL_Shortener/
$ mocha
Only after all tests come back as 'passing' then you can merge the feature branch to the master branch.
$ cd URL_Shortener/
$ gulp push
$ git checkout master
$ git merge patch_1.1.2
$ gulp --patch
Alternatively, if you to have a more verbose commit message you can follow these commands:
$ cd URL_Shortener/
$ git add .
$ git commit -m "version stable. A brief description of what this patch fixed."
$ git push
$ git checkout master
$ git merge patch_1.1.2
$ git add .
$ git commit -m "merged the feature branch patch_1.1.2 to the master branch"
$ git push origin master
Now that the newly patched version of this project is on GitHub you should tag a new release named after the new version, v1.1.2. If you don't know how to create a new release [click here and follow GitHub's instructions] (https://help.github.com/articles/creating-releases/).
Adding a new feature to the API would be considered a minor version update. A new feature branch should be made for new features. To do this would be the same as the instructions as for making a patch feature branch except the name of the branch should be semantic to what the new feature is or does.
Create a new feature branch for the new feature:
$ cd URL_Shortener/
$ git checkout -b makeItRain
You should see a returned log containing:
Switched to a new branch 'makeItRain'
Inside this new branch you can start building the new makeItRain functionality, but first you should build a unit test(s) for makeItRain. Before trying to merge
your patch to the master branch run the unit tests to make sure you're not committing broken code to the master branch.
$ cd URL_Shortener/
$ mocha
Only after all tests come back as 'passing' then you can merge the feature branch to the master branch.
$ cd URL_Shortener/
$ gulp push
$ git checkout master
$ git merge makeItRain
$ gulp --minor
A major version increase happens when the a change in the source code is not backwards compatible to previous versions. The instructions for this workflow is the same as for new feature minor version updates except to version bump up to a major version position the commands would look like this:
$ cd URL_Shortener/
$ gulp --major
- [Create a test for the master branch on Codeship] (https://codeship.com)
- [Set environment variables] (https://documentation.codeship.com/continuous-integration/set-environment-variables/)
- Setup test commands:
*Setup Commands* ```bash
nvm install 6.7.0 nvm use 6.7.0 npm install npm install -g mocha
</br>
*Configur Test Pipelines*
```bash
npm test
- [Create a pipeline] (https://devcenter.heroku.com/articles/pipelines)
- [Use clearDB as the API database by creating adding it as an add-on] (https://devcenter.heroku.com/articles/cleardb)
- [Set environment variables] (https://devcenter.heroku.com/articles/config-vars)
- [Connect GitHub to Heroku] (https://devcenter.heroku.com/articles/github-integration)
- Check the box labled 'Wait for CI to pass before deploy'
After creating a test on Codeship for the master branch you can move on to run the test by making a push to the master branch.
$ cd URL_Shortener/
$ git checkout master
$ git add .
$ git commit -m "version stable. some changes that were made"
$ git push -u origin master
When adding clearDB as an add-on use the URI information as the environment variables. [Click here] (https://devcenter.heroku.com/articles/connecting-to-relational-databases-on-heroku-with-java) to see how to break apart a URI to find the database credentials.
Anytime the release branch is pushed up to GitHub, the staging server on Heroku will rebuild as long as the master branch passed all the Codeship tests based on the latest master branch code. If all is well then the staging server can 'promote' the release branch code to the production server. To match the release branch to the master branch just merge master into release:
$ cd URL_Shortener/
$ git checkout release
$ git pull
$ git merge master
$ git push -u origin release
Note: To avoid merge conflicts the release branch should never be edited directly as stated above under Guidelines in this section.
The staging server is used as the last filter before code is pushed over to the production server. Here we can see how the API runs on the planned server environment as well as testing functionality, looking for mis-spelled words, check that the API AJAX calls are working as expected.
For the production server a different clearDB instance should be used as an add-on than the one used on the staging server. Make sure to use the production server's clearDB credentials in the environmental variables instead of the staging server's credentials.
Important: An extra environment variable should be added to the list for the prodution server:
NODE_ENV=production
After the staging server 'promotes' code over to the production server it should also be checked to make sure everything is working. Remember, this server is live and can be found by the public so it should be exactly the way you intended it to be.