Add the Flags to Doku

master
kreativmonkey 8 years ago
parent 1a1ae9ca74
commit c0765a1e48

@ -1,5 +1,5 @@
# Sgot # Sgot
Sgot is a lightwaight, self-hostable open-source link shortening web application with a Restful API. It allows you to host your own URL shortener to gain control over you data. Shrt is inspired by [Polr](https://polr.me/index.php), a php based url shortener. Sgot is a lightwaight, self-hostable open-source link shortening web application with a Restful API. It allows you to host your own URL shortener to gain control over you data. Shrt is inspired by [Polr](https://polr.me/index.php), a php based url shortener.
## Features ## Features
@ -11,6 +11,20 @@ Sgot is a lightwaight, self-hostable open-source link shortening web application
- [ ] Delete URL - [ ] Delete URL
- [ ] Login - [ ] Login
## Installation
Clone the Repository and build the Application by using `go build .`
Start Sgot by the following commant `./sgot &`
| Flag | Usage | Default |
| -------- | -------------------------------------- | ------------------------------------ |
| -host | setup the host to listen on | localhost |
| -port | Setup the port to listen on | 6889 |
| -apikey | Define the key to connect with the API | "thisIsNotASecretTokenNow" |
| -db-file | Setup the DB file to use | ./sgot.db |
| -title | Service title | Sgot |
| -domain | Domain for the redirection link | The domain your service is available |
## API ## API
To authenticate a user to Polr, you will need to provide an API key along with each request to the Polr API, as a GET or POST parameter. (e.g ``?key=API_KEY_HERE``) To authenticate a user to Polr, you will need to provide an API key along with each request to the Polr API, as a GET or POST parameter. (e.g ``?key=API_KEY_HERE``)
@ -27,7 +41,7 @@ Short an URL
``` ```
GET: http://example.com/api/action/shorten?key=API_KEY_HERE&url=http://example.de/shortening/main?q=5x GET: http://example.com/api/action/shorten?key=API_KEY_HERE&url=http://example.de/shortening/main?q=5x
Response: Response:
{ "action": "shorten", { "action": "shorten",
"result": "https://example.com/5kq" } "result": "https://example.com/5kq" }
``` ```
@ -43,19 +57,19 @@ Lookup for existing URL
``` ```
GET: http://example.com/api/action/lookup?key=API_KEY_HERE&url_ending=5kq GET: http://example.com/api/action/lookup?key=API_KEY_HERE&url_ending=5kq
Response: Response:
{ "action":"lookup", { "action":"lookup",
"result": { "result": {
"long_url": "http://example.de/shortening/main?q=5x", "long_url": "http://example.de/shortening/main?q=5x",
"created_at": "2017-05-12 22:48:40.997520107 +0200 CEST", "created_at": "2017-05-12 22:48:40.997520107 +0200 CEST",
"clicks":"0" "clicks":"0"
} }
} }
``` ```
## ToDo ## ToDo
* Add more Statistik details like the clicks from Country and Referer. * Add more Statistik details like the clicks from Country and Referer.
* Implements the correct HTTP Error Codes * Implements the correct HTTP Error Codes
* Add config File * Add config File
* Secure the API with API Key [optional] * Secure the API with API Key [optional]

@ -13,7 +13,6 @@ func DefaultConfig() Config {
Host: "localhost", Host: "localhost",
Port: "6889", Port: "6889",
Title: "Sgot", Title: "Sgot",
CheckDomain: false,
} }
} }
@ -55,7 +54,6 @@ func readConfig(f *flag.FlagSet, args []string) (*Config, error){
f.StringVar(&config.DB, "db-file", config.DB, "The db file to use") f.StringVar(&config.DB, "db-file", config.DB, "The db file to use")
f.StringVar(&config.Domain, "domain", config.Domain, "The domain for redirect links") f.StringVar(&config.Domain, "domain", config.Domain, "The domain for redirect links")
f.StringVar(&config.Title, "title", config.Title, "The title on the Front") f.StringVar(&config.Title, "title", config.Title, "The title on the Front")
f.BoolVar(&config.CheckDomain, "check-domain", config.CheckDomain, "Do you want to check Domain? Default:")
// Arguments variables // Arguments variables
err = f.Parse(args) err = f.Parse(args)

Loading…
Cancel
Save