Add debug switch and API endpoint to stop server when in debug mode.
This commit is contained in:
parent
06b8914e7b
commit
3e8bbb1676
@ -4,6 +4,7 @@
|
||||
"properties": {
|
||||
"artifactsRepo": { "type": "string" },
|
||||
"authSecret": { "type": "string" },
|
||||
"debug": { "type": "bool" },
|
||||
"pwdCost": { "type": "integer" },
|
||||
"projects": {
|
||||
"title": "ProjectsList",
|
||||
|
@ -34,6 +34,7 @@ type
|
||||
StrawBossConfig* = object
|
||||
artifactsRepo*: string
|
||||
authSecret*: string
|
||||
debug*: bool
|
||||
projects*: seq[ProjectDef]
|
||||
pwdCost*: int8
|
||||
users*: seq[UserRef]
|
||||
@ -98,6 +99,7 @@ proc loadStrawBossConfig*(cfgFile: string): StrawBossConfig =
|
||||
result = StrawBossConfig(
|
||||
artifactsRepo: jsonCfg.getIfExists("artifactsRepo").getStr("artifacts"),
|
||||
authSecret: jsonCfg.getOrFail("authSecret", "strawboss config").getStr,
|
||||
debug: jsonCfg.getIfExists("debug").getBVal(false),
|
||||
pwdCost: int8(jsonCfg.getOrFail("pwdCost", "strawboss config").getNum),
|
||||
projects: projectDefs,
|
||||
users: users)
|
||||
|
@ -1,4 +1,4 @@
|
||||
import asyncdispatch, bcrypt, jester, json, jwt, osproc, sequtils, tempfile,
|
||||
import asyncdispatch, bcrypt, jester, json, jwt, os, osproc, sequtils, tempfile,
|
||||
times, unittest
|
||||
|
||||
import ./configuration, ./core, private/util
|
||||
@ -111,6 +111,7 @@ template requireAuth() =
|
||||
|
||||
proc start*(givenCfg: StrawBossConfig): void =
|
||||
|
||||
let stopFuture = newFuture[void]()
|
||||
var workers: seq[Worker] = @[]
|
||||
|
||||
routes:
|
||||
@ -136,4 +137,10 @@ proc start*(givenCfg: StrawBossConfig): void =
|
||||
buildRef: if @"buildRef" != "": @"buildRef" else: nil,
|
||||
forceRebuild: false))) # TODO support this with optional query params
|
||||
|
||||
runForever()
|
||||
post "/service/debug/stop":
|
||||
if not givenCfg.debug: resp(Http404, makeJsonResp(Http404), "application/json")
|
||||
else:
|
||||
callSoon(proc(): void = complete(stopFuture))
|
||||
resp($(%*"shutting down"), "application/json")
|
||||
|
||||
waitFor(stopFuture)
|
||||
|
@ -1,6 +1,7 @@
|
||||
{
|
||||
"artifactsRepo": "artifacts",
|
||||
"authSecret": "change me",
|
||||
"debug": true,
|
||||
"users": [
|
||||
{ "name": "bob@builder.com", "hashedPwd": "testvalue" },
|
||||
{ "name": "sam@sousa.com", "hashedPwd": "testvalue" }
|
||||
|
@ -1,5 +1,6 @@
|
||||
{
|
||||
"artifactsRepo": "artifacts",
|
||||
"debug": true,
|
||||
"users": [],
|
||||
"authSecret": "change me",
|
||||
"pwdCost": 11,
|
||||
|
Loading…
x
Reference in New Issue
Block a user