From b1718c2bbed40dc3cc1b16da991dfe02899a2aa6 Mon Sep 17 00:00:00 2001 From: thefosk Date: Wed, 11 Mar 2015 21:31:21 -0700 Subject: [PATCH 1/5] closes #71 --- bin/kong | 54 ++++++++++++++++++++----- kong.yml | 3 ++ spec/integration/server/server_spec.lua | 9 +++++ spec/spec_helpers.lua | 4 +- 4 files changed, 60 insertions(+), 10 deletions(-) diff --git a/bin/kong b/bin/kong index 580c2f724eef..e7e644c325d9 100755 --- a/bin/kong +++ b/bin/kong @@ -5,8 +5,20 @@ SCRIPT_DIR="$( cd "$( dirname "$0" )" && pwd )" export KONG_HOME="$(echo $SCRIPT_DIR | sed -e 's/\/[^\/]*$//')" # Properties -export KONG_CONF=$KONG_HOME/kong.yml -NGINX_TMP=$KONG_HOME/nginx_tmp +if [ -f /etc/kong.yml ]; then + export KONG_CONF=/etc/kong.yml + printf "Giving priority to configuration stored at "$KONG_CONF" - To override use -c option\n" +else + export KONG_CONF=$KONG_HOME/kong.yml +fi + +nginx_output=$(lua -e "print(require('yaml').load(require('kong.tools.utils').read_file('$KONG_CONF')).output)") +if [ "$nginx_output" == "nil" ]; then + export NGINX_TMP=$KONG_HOME/nginx_tmp +else + export NGINX_TMP=$nginx_output +fi + PID=$NGINX_TMP/nginx.pid ###################### @@ -48,27 +60,48 @@ function show_help { \trestart restart Kong \t it is equivalent to executing 'stop' and 'start' in succession \tmigrate performs a database migration, execute this operation carefully +\tversion output version informations and exit \n" } function show_version { - printf "Kong Version 0.1\n" + printf "Kong version: 0.0.1beta-1\n" } -function start { +function print_start_error { printf "Starting Kong" + printf "$(tput setaf 1) [$1]\n$(tput sgr 0)" +} + +function start { + if [ -f $PID ]; then + if ps -p $(cat $PID) > /dev/null + then + print_start_error "ALREADY RUNNING" + exit 1 + fi + fi + + printf "Kong (configuration at "$KONG_CONF" output at "$NGINX_TMP")\n" + + mkdir -p $NGINX_TMP/logs &> /dev/null + if [ $? -ne 0 ]; then + printf "Cannot operate on $NGINX_TMP - Make sure you have the right permissions.\n\n" + print_start_error "ERROR" + exit 1 + fi - mkdir -p $NGINX_TMP/logs touch $NGINX_TMP/logs/error.log touch $NGINX_TMP/logs/access.log $KONG_HOME/scripts/config.lua -c $KONG_CONF -o $NGINX_TMP nginx nginx -p $NGINX_TMP -c $NGINX_TMP/nginx.conf if [ $? -eq 0 ]; then + printf "Starting Kong" printf "$(tput setaf 2) [OK]\n$(tput sgr 0)" else - printf "$(tput setaf 1) [ERROR]\n$(tput sgr 0)" - printf "\nYou can check what error has been returned by looking at the error log file" + printf "\nYou can get more information about this error by checking the error log file.\n\n" + print_start_error "ERROR" exit 1 fi } @@ -136,11 +169,14 @@ case "$@" in stop) stop ;; + restart) + restart + ;; migrate) migrate ;; - restart) - restart + version) + show_version ;; *) show_help diff --git a/kong.yml b/kong.yml index 77f2de4312e6..bf5b81e72a67 100644 --- a/kong.yml +++ b/kong.yml @@ -4,6 +4,9 @@ plugins_available: - ratelimiting - networklog +# Uncomment the following line to setup a custom output directory +output: /var/log/kong2 + # Specify the DAO to use database: cassandra diff --git a/spec/integration/server/server_spec.lua b/spec/integration/server/server_spec.lua index 569aa265d11f..c930284055ef 100644 --- a/spec/integration/server/server_spec.lua +++ b/spec/integration/server/server_spec.lua @@ -1,6 +1,8 @@ local yaml = require "yaml" local utils = require "kong.tools.utils" local spec_helper = require "spec.spec_helpers" +local constants = require "kong.constants" +local stringy = require "stringy" local TEST_CONF = "kong_TEST.yml" local SERVER_CONF = "kong_TEST_SERVER.yml" @@ -20,6 +22,13 @@ end describe("#server-cli", function() + describe("CLI", function() + it("should return the right version", function() + local result, exit_code = spec_helper.os_execute(spec_helper.KONG_BIN.." -v") + assert.are.same("Kong version: "..constants.VERSION, stringy.strip(result)) + end) + end) + describe("Plugins Check", function() setup(function() diff --git a/spec/spec_helpers.lua b/spec/spec_helpers.lua index 09799ffabd53..14841cc74b22 100644 --- a/spec/spec_helpers.lua +++ b/spec/spec_helpers.lua @@ -13,7 +13,9 @@ local configuration, dao_factory = utils.load_configuration_and_dao(TEST_CONF_FI local migrations = Migrations(dao_factory) local faker = Faker(dao_factory) -local _M = {} +local _M = { + KONG_BIN = KONG_BIN +} _M.CONF_FILE = TEST_CONF_FILE _M.PROXY_URL = PROXY_URL From 25ba99420f7f0a232dde0057e030ec4b77ce4c79 Mon Sep 17 00:00:00 2001 From: thefosk Date: Wed, 11 Mar 2015 21:33:47 -0700 Subject: [PATCH 2/5] better comments --- bin/kong | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/bin/kong b/bin/kong index e7e644c325d9..6cecd6b1bd21 100755 --- a/bin/kong +++ b/bin/kong @@ -4,7 +4,7 @@ SCRIPT_DIR="$( cd "$( dirname "$0" )" && pwd )" export KONG_HOME="$(echo $SCRIPT_DIR | sed -e 's/\/[^\/]*$//')" -# Properties +# Setting configuration path if [ -f /etc/kong.yml ]; then export KONG_CONF=/etc/kong.yml printf "Giving priority to configuration stored at "$KONG_CONF" - To override use -c option\n" @@ -12,6 +12,7 @@ else export KONG_CONF=$KONG_HOME/kong.yml fi +# Setting nginx output path nginx_output=$(lua -e "print(require('yaml').load(require('kong.tools.utils').read_file('$KONG_CONF')).output)") if [ "$nginx_output" == "nil" ]; then export NGINX_TMP=$KONG_HOME/nginx_tmp @@ -44,6 +45,11 @@ function real_path_func { fi } +function print_start_error { + printf "Starting Kong" + printf "$(tput setaf 1) [$1]\n$(tput sgr 0)" +} + ############## # Operations # ############## @@ -68,11 +74,6 @@ function show_version { printf "Kong version: 0.0.1beta-1\n" } -function print_start_error { - printf "Starting Kong" - printf "$(tput setaf 1) [$1]\n$(tput sgr 0)" -} - function start { if [ -f $PID ]; then if ps -p $(cat $PID) > /dev/null From 076511eb6fdc2317dc4dcf40c883cdcf8fde59a3 Mon Sep 17 00:00:00 2001 From: thefosk Date: Wed, 11 Mar 2015 21:38:16 -0700 Subject: [PATCH 3/5] Setting commented output to /var/log/kong --- kong.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/kong.yml b/kong.yml index bf5b81e72a67..8302b963a336 100644 --- a/kong.yml +++ b/kong.yml @@ -5,7 +5,7 @@ plugins_available: - networklog # Uncomment the following line to setup a custom output directory -output: /var/log/kong2 +# output: /var/log/kong # Specify the DAO to use database: cassandra From f3a9a1754859a4a0c5d54b3aea9f31ced1f1858d Mon Sep 17 00:00:00 2001 From: thefosk Date: Wed, 11 Mar 2015 21:40:21 -0700 Subject: [PATCH 4/5] documentation for output --- site/app/_includes/pages/docs.md | 1 + 1 file changed, 1 insertion(+) diff --git a/site/app/_includes/pages/docs.md b/site/app/_includes/pages/docs.md index f63efb3836d7..9df85cf2b4bb 100644 --- a/site/app/_includes/pages/docs.md +++ b/site/app/_includes/pages/docs.md @@ -246,6 +246,7 @@ nginx: | Here is a detailed description for each entry: * `plugins_available` describes an array of plugins that are available and can be used by the server. You can use only the plugins that are being specified here. +* `output` optionally sets the output directory of the Kong working dir and its logs. If not set the Kong installation directory will be used instead. * `database` is the database Kong is going to use. It's `cassandra` by default and it's the only one supported at the moment. * `databases_available` describes the configuration to use when connecting to the database. * `send_anonymous_reports` tells if the system is allowed to send anonymous error logs to a remote logging server in order to allow the maintainers of Kong to fix potential bugs and errors. From 09fd0ff20f3cc554f8b465859861a695782e47c4 Mon Sep 17 00:00:00 2001 From: thefosk Date: Wed, 11 Mar 2015 21:40:53 -0700 Subject: [PATCH 5/5] dir becomes directory --- site/app/_includes/pages/docs.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/site/app/_includes/pages/docs.md b/site/app/_includes/pages/docs.md index 9df85cf2b4bb..b2c97be42253 100644 --- a/site/app/_includes/pages/docs.md +++ b/site/app/_includes/pages/docs.md @@ -246,7 +246,7 @@ nginx: | Here is a detailed description for each entry: * `plugins_available` describes an array of plugins that are available and can be used by the server. You can use only the plugins that are being specified here. -* `output` optionally sets the output directory of the Kong working dir and its logs. If not set the Kong installation directory will be used instead. +* `output` optionally sets the output directory of the Kong working directory and its logs. If not set the Kong installation directory will be used instead. * `database` is the database Kong is going to use. It's `cassandra` by default and it's the only one supported at the moment. * `databases_available` describes the configuration to use when connecting to the database. * `send_anonymous_reports` tells if the system is allowed to send anonymous error logs to a remote logging server in order to allow the maintainers of Kong to fix potential bugs and errors.