BaragonService API
Listed below are the various endpoints for BaragonService along with example request payloads (where applicable) and responses. All example requests are pointed at the baragon docker host, and all request examples are written in python.
| State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
State
GET /state
Returns the current list of services that Baragon is keeping track of. Returns a collection of BaragonServiceState
objects
Example Request
requests.get("192.168.33.20:8080/baragon/v2/state")
Example Response
[
{
"service":{
"serviceId":"test1",
"owners":["someone@example.com"],
"serviceBasePath":"/test1",
"loadBalancerGroups":["vagrant"],
"options":{
"nginxExtraConfigs":["rewrite ^/test(.*) /test/path$1 last;"]
}
},
"upstreams":[{
"upstream":"example.com:80",
"requestId":"test1",
"rackId":"us_east_1a"
}]
},
{
"service":{
"serviceId":"test2",
"owners":["someone@example.com"],
"serviceBasePath":"/test2",
"loadBalancerGroups":["vagrant"],
"options":{
"nginxExtraConfigs":["rewrite ^/test2(.*) /test2/path$1 last;"]
}
},
"upstreams":[{
"upstream":"something.com:80",
"requestId":"test2",
"rackId":"us_east_1a"
}]
},
]
GET /state/{serviceId}
Returns the details for a specific service ID (BaragonServiceState
object).
Example Request
requests.get("192.168.33.20:8080/baragon/v2/state/test1")
Example Response
{
"service":{
"serviceId":"test1",
"owners":["someone@example.com"],
"serviceBasePath":"/test1",
"loadBalancerGroups":["vagrant"],
"options":{
"nginxExtraConfigs":["rewrite ^/test(.*) /test/path$1 last;"]
}
},
"upstreams":[{
"upstream":"example.com:80",
"requestId":"test1",
"rackId":"us_east_1a"
}]
}
DELETE /state/{serviceId}
Removes the service from the current state and clears any associated base paths. Returns a BaragonServiceState
object of the deleted service.
Example Request
requests.delete("192.168.33.20:8080/baragon/v2/state/test1")
Example Response
{
"service":{
"serviceId":"test1",
"owners":["someone@example.com"],
"serviceBasePath":"/test1",
"loadBalancerGroups":["vagrant"],
"options":{
"nginxExtraConfigs":["rewrite ^/test(.*) /test/path$1 last;"]
}
},
"upstreams":[{
"upstream":"example.com:80",
"requestId":"test1",
"rackId":"us_east_1a"
}]
}
Workers
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
GET /workers
Returns a list of the addresses of the currently active baragon workers.
Example Request
requests.get("192.168.33.20:8080/baragon/v2/workers")
Example Response
["http://192.168.33.20:8080/baragon/v2"]
Status
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
GET /status
Returns the current BaragonService status. (BaragonServiceStatus
object)
Example Request
requests.get("192.168.33.20:8080/baragon/v2/status")
Example Response
{
"leader": true, # Is this BaragonService instance currently the leader?
"pendingRequestCount": 0, # Requests in the queue
"workerLagMs": 1423, # Time since worker last start
"zookeeperState": "CONNECTED", # Zookeeper state
"globalStateNodeSize": 1304 # Size of the /state zk node in bytes (to help avoid hitting the zk limit)
}
Requests
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
GET /request
Get the current pending requests. Returns a list of QueuedRequestId
objects
Example Request
requests.get("192.168.33.20:8080/baragon/v2/request")
Example Response
[
{
"serviceId":"test1", # Service associated with the request
"requestId":"requestId1", # Unique reqeust identifier
"index":5 # (ie,. fifth request Baragon has seen)
}
]
POST /request
Add a request to the queue with the given data. Returns a BaragonResponse
object. A `BaragonResponse can have the following statuses:
WAITING
: waiting for request to be applied on all agentsSUCCESS
: request was successfully applied on all agentsFAILED
: request was not successfully applied on all agents, and was rolled backCANCELING
: request is in the process of being cancelled (rolled back)CANCELED
: request was cancelled (rolled back) on all agentsINVALID_REQUEST_NOOP
: request was invalid and no action was taken on any load balancerUNKNOWN
: unknown.
Example Request
data = {
"loadBalancerRequestId":"requestId", # Unique request id
"loadBalancerService":{
"serviceId":"testService",
"owners":["owner@example.com"],
"serviceBasePath":"/basepath",
"loadBalancerGroups":["vagrant"],
"options":{
"nginxExtraConfigs": [
"rewrite ^/test(.*) /test/v1/$1 last;"
]
}
},
"addUpstreams":[
{"upstream":"example.com:80","requestId":"requestId","rack":"us_east_1a"}
],
"removeUpstreams":[]
}
headers = {'Content-type': 'application/json'}
requests.post("http://192.168.33.20:8080/baragon/v2/request", data=data, headers=headers)
NOTE The options hash can hold any objects you need it to. These values will later be available in the handlebars template under service.options
Example Response
- WAITING
{ "loadBalancerRequestId": "requestId", "loadBalancerState": "WAITING", "message": "Queued as QueuedRequestId{serviceId=testService, requestId=requestId, index=2164}", "agentResponses": { "APPLY": [] } }
- SUCCESS
{ "loadBalancerRequestId": "requestId", "loadBalancerState": "SUCCESS", "message": "APPLY request succeeded! Added upstreams [example.com:80], removed upstreams []", "agentResponses": { "APPLY": [ { "url": "http://192.168.33.22:8081/baragon-agent/v2/request/requestId", "attempt": 0, "statusCode": 200, "content": null, "exception": null } ] } }
GET /request/{requestId}
Returns the status of a particular request via a BaragonResponse
object. This is the same type of response as the initial POST
request to the /request
endpoint. See above for possible statuses
Example Request
requests.get("192.168.33.20:8080/baragon/v2/request/requestId")
Example Response
{
"loadBalancerRequestId": "requestId",
"loadBalancerState": "SUCCESS",
"message": "Queued as QueuedRequestId{serviceId=testService, requestId=requestId, index=2164}",
"agentResponses": {
"APPLY": [
{
"url": "http://192.168.33.22:8081/baragon-agent/v2/request/MDSrequestId",
"attempt": 0,
"statusCode": 200,
"content": null,
"exception": null
}
]
}
}
Auth
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
GET /auth/keys
Returns the current list of auth keys (Must use the master auth key to access this)
Example Request
params = {"authkey":"my-master-key"}
requests.get("192.168.33.20:8080/baragon/v2/auth/keys", params=params)
Example Response
[
{
"value": "my-regular-key",
"owner": "owner@example.com",
"createdAt": 1409435929246,
"expiredAt": null
}
]
DELETE /auth/keys/{key}
Delete {key} from the list of valid auth keys (Must use the master auth key to access this)
Example Request
params = {"authkey":"my-master-key"}
requests.delete("192.168.33.20:8080/baragon/v2/auth/keys/expiringauthkey", params=params)
Example Response
{
"value": "expiringauthkey",
"owner": "owner@example.com",
"createdAt": 1409435929246,
"expiredAt": null
}
POST /auth/keys/{key}
Add a new valid auth key (Must use the master auth key to access this)
Example Request
params = {"authkey":"my-master-key"}
headers = {'Content-type': 'application/json'}
data = {
"value": "newauthkey",
"owner": "owner@example.com"
}
requests.post("192.168.33.20:8080/baragon/v2/auth/keys", data=data, params=params, headers=headers)
Example Response
{
"value": "expiringauthkey",
"owner": "owner@example.com",
"createdAt": 1409435929246,
"expiredAt": null
}
Load Balancer
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
GET /load-balancer
Returns a list of the current load balancer clusters/groups
Example Request
requests.get("192.168.33.20:8080/baragon/v2/load-balancer")
Example Response
[
"vagrant",
"vagrant2"
]
GET /load-balancer/{cluster}
Returns a BaragonGroup object for cluster named cluster
Example Request
requests.get("192.168.33.20:8080/load-balancer/vagrant")
Example Response
{
"name":"vagrant",
"domain":"vagrant.baragon.biz",
"sources":[
"my-test-elb"
]
}
GET /load-balancer/{cluster}/agents
Returns the currently active baragon agents for the specified load balancer cluster
Example Request
requests.get("192.168.33.20:8080/baragon/v2/load-balancer/vagrant/agents")
Example Response
[
{
"baseAgentUri": "http://192.168.33.21:8081/baragon/v2",
"agentId": "192.168.33.21:8081",
"domain": "vagrant.baragon.biz"
}
]
GET /load-balancer/{cluster}/known-agents
Returns all Baragon agents that Baragon service has seen for the specified load balancer cluster
Example Request
requests.get("192.168.33.20:8080/baragon/v2/load-balancer/vagrant/known-agents")
Example Response
[
{
"baseAgentUri": "http://192.168.33.21:8081/baragon/v2",
"agentId": "192.168.33.21:8081",
"domain": "vagrant.baragon.biz",
"lastSeenAt": 1423693860906
}
]
DELETE /load-balancer/{cluster}/known-agents/{agentId}
Remove the specified agent from the list of known agents. This will NOT remove if from the active agents if it is still connected in zookeeper
Example Request
agentId = "192.168.33.21:8081"
requests.delete("192.168.33.20:8080/baragon/v2/load-balancer/vagrant/known-agents/{0}".format(agentId))
GET /load-balancer/{cluster}/base-path/all
Get the list of base paths for the specified cluster
Example Request
requests.get("192.168.33.20:8080/baragon/v2/load-balancer/vagrant/base-path/all")
Example Response
[
"/test1",
"/test2"
]
DELETE /load-balancer/{cluster}/base-path
Remove the lock on a base path for the specified cluster
Example Request
params = {"basePath":"/test"}
requests.delete("192.168.33.20:8080/baragon/v2/load-balancer/vagrant/base-path", params=params)
GET /load-balancer/{cluster}/base-path
Return the service associated with the specified base path
Example Request
params = {"basePath":"/test"}
requests.get("192.168.33.20:8080/baragon/v2/load-balancer/vagrant/base-path", params=params)
Example Response
{
"service":{
"serviceId":"test",
"owners":["someone@example.com"],
"serviceBasePath":"/test",
"loadBalancerGroups":["vagrant"],
"options":{
"nginxExtraConfigs":["rewrite ^/test(.*) /test/path$1 last;"]
}
},
"upstreams":[{
"upstream":"example.com:80",
"requestId":"testrequest",
"rackId":"us_east_1a"
}]
}
POST /load-balancer/{cluster}/sources
Add a traffic source (ie. ELB name). Returns a BaragonGroup object
Example Request
params = {'source':'my-test-elb'}
requests.post("192.168.33.20:8080/load-balancer/vagrant/sources", params=params)
Example Response
{
"name":"vagrant",
"domain":"vagrant.baragon.biz",
"sources":[
"my-test-elb"
]
}
DELETE /load-balancer/{cluster}/sources
Remove a traffic source (ie. ELB name). Optionally returns a BaragonGroup object
Example Request
params = {'source':'my-test-elb'}
requests.delete("192.168.33.20:8080/load-balancer/vagrant/sources", params=params)
Example Response
{
"name":"vagrant",
"domain":"vagrant.baragon.biz",
"sources":[]
}
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |
Agent API
The Baragon Agent API is generally only used by BaragonService to trigger requests, but the status endpoint can be useful for monitoring purposes.
POST /request/{requestId}
Execute a request with the specified requestId
. Request data will be fetched from zookeeper by the agent so only the ID is needed.
Example Request
requests.post("192.168.33.21:8882/baragon-agent/v2/request/test-1")
Example Response
This can return:
200
: Request was applied successfully400
: The request could not be completed due to an error caught by Baragon and the Agent has attempted to revert the changes500
: The request could not be completed due to an unforseen error, the Agent may not have been abel to successfully revert the changes
GET /status
Get the status of the agent, returns a BaragonAgentStatus
object.
Example Request
requests.get("192.168.33.21:8882/baragon-agent/v2/status")
Example Response
{
"group": "vagrant", # load balancer group name from Agent config
"validConfigs": true, # Is the current configuration valid accoridng to the provided checkConfigCommand
"errorMessage": "message", # Current error message returned by the checkConfigCommand if there is one
"leader": true, # Is this agent currently the zk leader among agents in the same loadBalancerGroup
"mostRecentRequestId": "test1", # ID of the last request processed
"zookeeperState": "CONNECTED" # Current zookeeper connection state
}
| Top | State | Workers | Status | Requests | Auth | Load Balancer | Agent API |