Added Agent API and Agent WebUI
This commit is contained in:
parent
5676828093
commit
02e29301aa
31
barbican.py
31
barbican.py
@ -20,8 +20,8 @@ from flask.ext import login, wtf
|
|||||||
from flask.ext.login import login_user
|
from flask.ext.login import login_user
|
||||||
from barbican_api import api
|
from barbican_api import api
|
||||||
from database import db_session, init_db
|
from database import db_session, init_db
|
||||||
from models import User, Tenant, Key, Policy, Event
|
from models import User, Tenant, Key, Policy, Event, Agent, Tag
|
||||||
|
import re
|
||||||
|
|
||||||
app = Flask(__name__)
|
app = Flask(__name__)
|
||||||
app.secret_key = '79f9823f1f0---DEVELOPMENT---c46cebdd1c8f3d0742e02'
|
app.secret_key = '79f9823f1f0---DEVELOPMENT---c46cebdd1c8f3d0742e02'
|
||||||
@ -33,6 +33,8 @@ admin.add_view(ModelView(Tenant, db_session))
|
|||||||
admin.add_view(ModelView(Key, db_session))
|
admin.add_view(ModelView(Key, db_session))
|
||||||
admin.add_view(ModelView(Policy, db_session))
|
admin.add_view(ModelView(Policy, db_session))
|
||||||
admin.add_view(ModelView(Event, db_session))
|
admin.add_view(ModelView(Event, db_session))
|
||||||
|
admin.add_view(ModelView(Agent,db_session))
|
||||||
|
admin.add_view(ModelView(Tag, db_session))
|
||||||
|
|
||||||
login_manager = login.LoginManager()
|
login_manager = login.LoginManager()
|
||||||
login_manager.init_app(app)
|
login_manager.init_app(app)
|
||||||
@ -45,9 +47,34 @@ def hello():
|
|||||||
return render_template("index.html")
|
return render_template("index.html")
|
||||||
|
|
||||||
@app.route("/events")
|
@app.route("/events")
|
||||||
|
@login.login_required
|
||||||
def events():
|
def events():
|
||||||
return render_template("events.html")
|
return render_template("events.html")
|
||||||
|
|
||||||
|
@app.route("/agents", methods=["GET", "POST"])
|
||||||
|
@login.login_required
|
||||||
|
def agents():
|
||||||
|
if request.method == 'POST':
|
||||||
|
# need to update all agents since it is possible to disable pairing for them all
|
||||||
|
all_datas = request.form
|
||||||
|
ids=[]
|
||||||
|
for k in all_datas:
|
||||||
|
m = re.match('check(\d+)', k)
|
||||||
|
if m is not None:
|
||||||
|
id = m.group(1)
|
||||||
|
ids.append(int(id))
|
||||||
|
|
||||||
|
agents = Agent.query.order_by(Agent.id)
|
||||||
|
for agent in agents.all():
|
||||||
|
if agent.id in ids:
|
||||||
|
agent.paired = True
|
||||||
|
else:
|
||||||
|
agent.paried = False
|
||||||
|
db_session.commit()
|
||||||
|
|
||||||
|
return render_template("agents.html")
|
||||||
|
else:
|
||||||
|
return render_template("agents.html")
|
||||||
|
|
||||||
#
|
#
|
||||||
# Login forms
|
# Login forms
|
||||||
|
@ -15,7 +15,7 @@ import uuid
|
|||||||
import datetime
|
import datetime
|
||||||
from dateutil.parser import parse
|
from dateutil.parser import parse
|
||||||
from flask import Blueprint, request, jsonify, Response, json, Markup
|
from flask import Blueprint, request, jsonify, Response, json, Markup
|
||||||
from models import Event, Tenant, Key, Agent, Policy
|
from models import Event, Tenant, Key, Agent, Policy, Tag
|
||||||
from database import db_session
|
from database import db_session
|
||||||
|
|
||||||
|
|
||||||
@ -79,7 +79,14 @@ def policies(tenant_id):
|
|||||||
def agents(tenant_id):
|
def agents(tenant_id):
|
||||||
if request.method == 'POST':
|
if request.method == 'POST':
|
||||||
tenant = Tenant.query.get(tenant_id)
|
tenant = Tenant.query.get(tenant_id)
|
||||||
agent = Agent(tenant=tenant, uuid=request.json['uuid'])
|
agent = Agent(tenant=tenant, uuid=request.json['uuid'], hostname=request.json['hostname'],
|
||||||
|
os_version=request.json['os_version'], agent_version=request.json['agent_version'])
|
||||||
|
tags = []
|
||||||
|
for t in request.json['tags']:
|
||||||
|
tag = Tag(name=t["name"], value=t["value"])
|
||||||
|
tags.append(tag)
|
||||||
|
|
||||||
|
agent.tags.extend(tags)
|
||||||
db_session.add(agent)
|
db_session.add(agent)
|
||||||
db_session.commit()
|
db_session.commit()
|
||||||
return jsonify(agent.as_dict())
|
return jsonify(agent.as_dict())
|
||||||
@ -131,6 +138,32 @@ def alllogs(timestamp=None):
|
|||||||
}'''
|
}'''
|
||||||
return Response(json_str, mimetype='application/json')
|
return Response(json_str, mimetype='application/json')
|
||||||
|
|
||||||
|
@api.route('/allagents/', methods=['GET'])
|
||||||
|
def allagents(timestamp=None):
|
||||||
|
agents = Agent.query.order_by(Agent.id)
|
||||||
|
json_str = '''{
|
||||||
|
"aaData":[
|
||||||
|
'''
|
||||||
|
for agent in agents.all():
|
||||||
|
tags = Tag.query.filter(Tag.agent_id==agent.id).all()
|
||||||
|
tag_json='{'
|
||||||
|
for tag in tags:
|
||||||
|
tag_json += "'%s':'%s'," % (tag.name, tag.value)
|
||||||
|
tag_json = tag_json[:-1]
|
||||||
|
tag_json += '}'
|
||||||
|
|
||||||
|
if agent.paired == True:
|
||||||
|
paired_checkbox = "<input type='checkbox' name='check%d' value='%d' checked>" % (agent.id, agent.id)
|
||||||
|
else:
|
||||||
|
paired_checkbox = "<input type='checkbox' name='check%d' value='%d'>" % (agent.id, agent.id)
|
||||||
|
json_str += '''["%s","%s","%s","%s","%s","%s", "%s", "%s"
|
||||||
|
],''' % (agent.id,agent.uuid, agent.tenant_id, agent.hostname, agent.os_version, agent.agent_version, tag_json, paired_checkbox)
|
||||||
|
json_str = json_str[:-1]
|
||||||
|
json_str += ''']
|
||||||
|
}'''
|
||||||
|
return Response(json_str, mimetype='application/json')
|
||||||
|
|
||||||
|
|
||||||
class DateTimeJsonEncoder(json.JSONEncoder):
|
class DateTimeJsonEncoder(json.JSONEncoder):
|
||||||
def default(self, obj):
|
def default(self, obj):
|
||||||
if isinstance(obj, datetime.datetime):
|
if isinstance(obj, datetime.datetime):
|
||||||
|
@ -16,7 +16,7 @@ import uuid
|
|||||||
import datetime
|
import datetime
|
||||||
import requests
|
import requests
|
||||||
import json
|
import json
|
||||||
from models import Event, Tenant, Key, Agent, Policy
|
from models import Event, Tenant, Key, Agent, Policy, Tag
|
||||||
|
|
||||||
|
|
||||||
class BarbicanAPITesting:
|
class BarbicanAPITesting:
|
||||||
@ -27,10 +27,28 @@ class BarbicanAPITesting:
|
|||||||
|
|
||||||
new_uuid = uuid.uuid4()
|
new_uuid = uuid.uuid4()
|
||||||
self.agent_id = new_uuid
|
self.agent_id = new_uuid
|
||||||
pay_load = {"uuid": str(new_uuid)}
|
payload = '''
|
||||||
|
{
|
||||||
|
"agent_version": "v1.1",
|
||||||
|
"hostname": "barbican.example.com",
|
||||||
|
"os_version": "windows8",
|
||||||
|
"tags": [
|
||||||
|
{
|
||||||
|
"name": "tag1",
|
||||||
|
"value": "value1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "tag2",
|
||||||
|
"value": "value2"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"tenant_id": %d,
|
||||||
|
"uuid": "%s"
|
||||||
|
}
|
||||||
|
''' % (tenant_id, new_uuid)
|
||||||
the_url = self.url + str(tenant_id) + "/agents/"
|
the_url = self.url + str(tenant_id) + "/agents/"
|
||||||
headers = {'content-type': 'application/json'}
|
headers = {'content-type': 'application/json'}
|
||||||
response = requests.post(the_url,data=json.dumps(pay_load), headers=headers)
|
response = requests.post(the_url,data=payload, headers=headers)
|
||||||
try:
|
try:
|
||||||
the_uuid = response.json["uuid"]
|
the_uuid = response.json["uuid"]
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
@ -118,15 +136,23 @@ class BarbicanAPITesting:
|
|||||||
response = requests.post(the_url)
|
response = requests.post(the_url)
|
||||||
return response.text
|
return response.text
|
||||||
|
|
||||||
|
tag1 = Tag("tag1", "value1")
|
||||||
|
tag2 = Tag("tag2", "value2")
|
||||||
|
|
||||||
|
'''tenant = Tenant(id=10)
|
||||||
|
agent = Agent(tenant, uuid=None, hostname='barbican.example.com', os_version='windows8', agent_version='v1.1')
|
||||||
|
agent.tags = [tag1, tag2]
|
||||||
|
#print tenant.as_dict()
|
||||||
|
print agent.as_dict()
|
||||||
|
'''
|
||||||
test1 = BarbicanAPITesting()
|
test1 = BarbicanAPITesting()
|
||||||
print test1.get_tenant(123)
|
print test1.get_tenant(123)
|
||||||
print test1.get_tenant(1234)
|
print test1.get_tenant(1234)
|
||||||
print test1.create_tenant(123456)
|
print test1.create_tenant(123456)
|
||||||
print test1.create_tenant(2349)
|
print test1.create_tenant(2349)
|
||||||
print test1.add_agent(1234)
|
print test1.add_agent(123)
|
||||||
test1.get_agents(1234)
|
print test1.get_agents(123)
|
||||||
|
'''
|
||||||
print test1.add_policy("Before start up", 1234)
|
print test1.add_policy("Before start up", 1234)
|
||||||
print test1.get_policy(1234)
|
print test1.get_policy(1234)
|
||||||
|
|
||||||
@ -138,3 +164,4 @@ for k in range(1,50):
|
|||||||
print test1.add_log(1234)
|
print test1.add_log(1234)
|
||||||
print test1.get_log(123)
|
print test1.get_log(123)
|
||||||
print test1.get_alllogs()
|
print test1.get_alllogs()
|
||||||
|
'''
|
17
examples/agent.json
Normal file
17
examples/agent.json
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"agent_version": "v1.1",
|
||||||
|
"hostname": "barbican.example.com",
|
||||||
|
"os_version": "windows8",
|
||||||
|
"tags": [
|
||||||
|
{
|
||||||
|
"name": "tag1",
|
||||||
|
"value": "value1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "tag2",
|
||||||
|
"value": "value2"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"tenant_id": 10,
|
||||||
|
"uuid": "7ead7502-53a4-4607-ae37-1b9af34460d8"
|
||||||
|
}
|
48
models.py
48
models.py
@ -118,24 +118,44 @@ class Agent(Base):
|
|||||||
__tablename__ = 'agents'
|
__tablename__ = 'agents'
|
||||||
id = Column(Integer, primary_key=True)
|
id = Column(Integer, primary_key=True)
|
||||||
uuid = Column(String(36), unique=True)
|
uuid = Column(String(36), unique=True)
|
||||||
|
hostname = Column(String(128))
|
||||||
|
os_version = Column(String(128))
|
||||||
|
agent_version = Column(String(33))
|
||||||
|
paired = Column(Boolean)
|
||||||
|
|
||||||
tenant_id = Column(Integer, ForeignKey('tenants.id'))
|
tenant_id = Column(Integer, ForeignKey('tenants.id'))
|
||||||
tenant = relationship("Tenant", backref=backref('agents', order_by=id))
|
tenant = relationship("Tenant", backref=backref('agents', order_by=id))
|
||||||
|
|
||||||
def __init__(self, tenant=None, uuid=None):
|
def __init__(self, tenant=None, uuid=None, hostname=None, os_version=None, agent_version=None, paired=None):
|
||||||
self.tenant = tenant
|
self.tenant = tenant
|
||||||
|
self.tenant_id = tenant.id
|
||||||
if uuid is None:
|
if uuid is None:
|
||||||
self.uuid = str(uuid4())
|
self.uuid = str(uuid4())
|
||||||
else:
|
else:
|
||||||
self.uuid = uuid
|
self.uuid = uuid
|
||||||
|
|
||||||
|
if paired is None:
|
||||||
|
self.paired = False
|
||||||
|
else:
|
||||||
|
self.paired = paired
|
||||||
|
self.hostname = hostname
|
||||||
|
self.os_version = os_version
|
||||||
|
self.agent_version = agent_version
|
||||||
|
|
||||||
|
|
||||||
def __repr__(self):
|
def __repr__(self):
|
||||||
return '<Agent %s>' % self.uuid
|
return '<Agent %s>' % self.uuid
|
||||||
|
|
||||||
def as_dict(self):
|
def as_dict(self):
|
||||||
|
tags = map(Tag.as_dict, self.tags)
|
||||||
agent = {
|
agent = {
|
||||||
'tenant_id': self.tenant_id,
|
'tenant_id': self.tenant_id,
|
||||||
'uuid': self.uuid
|
'uuid': self.uuid,
|
||||||
|
'hostname': self.hostname,
|
||||||
|
'os_version': self.os_version,
|
||||||
|
'agent_version': self.agent_version,
|
||||||
|
'paired': self.paired,
|
||||||
|
'tags': tags
|
||||||
}
|
}
|
||||||
return agent
|
return agent
|
||||||
|
|
||||||
@ -221,3 +241,27 @@ class Event(Base):
|
|||||||
'message': self.message
|
'message': self.message
|
||||||
}
|
}
|
||||||
return json
|
return json
|
||||||
|
|
||||||
|
|
||||||
|
class Tag(Base):
|
||||||
|
__tablename__ = 'tags'
|
||||||
|
id = Column(Integer, primary_key=True)
|
||||||
|
name = Column(String(128))
|
||||||
|
value = Column(String(1024))
|
||||||
|
|
||||||
|
agent_id = Column(Integer, ForeignKey('agents.id'))
|
||||||
|
agent = relationship("Agent", backref=backref('tags'))
|
||||||
|
|
||||||
|
def __init__(self, name=None, value=None):
|
||||||
|
self.name = name
|
||||||
|
self.value = value
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return '<Tag %s>' % self.id
|
||||||
|
|
||||||
|
def as_dict(self):
|
||||||
|
json = {
|
||||||
|
'name': self.name,
|
||||||
|
'value': self.value
|
||||||
|
}
|
||||||
|
return json
|
||||||
|
44
templates/agents.html
Normal file
44
templates/agents.html
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
{% extends 'layout.html' %}
|
||||||
|
|
||||||
|
{% block body %}
|
||||||
|
<script type="text/javascript" charset="utf-8">
|
||||||
|
/* Data set - can contain whatever information you want */
|
||||||
|
var aDataSet = [
|
||||||
|
];
|
||||||
|
var oTable;
|
||||||
|
|
||||||
|
$(document).ready(function() {
|
||||||
|
|
||||||
|
$('#form').submit(function(){
|
||||||
|
var sData = oTable.$('input').serialize();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('#dynamic').html( '<table cellpadding="0" cellspacing="0" border="0" class="display" id="example"></table>' );
|
||||||
|
$('#example').dataTable( {
|
||||||
|
"bProcessing": true,
|
||||||
|
"sAjaxSource": "/api/allagents/",
|
||||||
|
"aoColumns": [
|
||||||
|
{ "sTitle": "ID", "sWidth":"5%" },
|
||||||
|
{ "sTitle": "UUID", "sClass": "center", "sWidth":"25%" },
|
||||||
|
{ "sTitle": "Tenant ID", "sWidth":"5%" },
|
||||||
|
{ "sTitle": "Hostname", "sWidth":"5%" },
|
||||||
|
{ "sTitle": "OS Version", "sWidth":"10%" },
|
||||||
|
{ "sTitle": "Agent Version", "sWidth":"4%"},
|
||||||
|
{ "sTitle": "Tags", "sWidth":"35%" },
|
||||||
|
{ "sTitle": "Paired", "sWidth":"5%" },
|
||||||
|
]
|
||||||
|
} );
|
||||||
|
oTable = $('#example').dataTable();
|
||||||
|
} );
|
||||||
|
</script>
|
||||||
|
<h1> Agent List </h1>
|
||||||
|
<br>
|
||||||
|
<form id='form' method='POST'>
|
||||||
|
<div style='text-align:right'> <button type="submit" class="btn btn-primary"> Update Pairing </button>
|
||||||
|
</div>
|
||||||
|
<div id="dynamic"></div>
|
||||||
|
<br/>
|
||||||
|
<div style='text-align:right'> <button type="submit" class="btn btn-primary"> Update Pairing </button>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{% endblock %}
|
@ -47,6 +47,7 @@
|
|||||||
<div class="nav-collapse collapse">
|
<div class="nav-collapse collapse">
|
||||||
<ul class="nav">
|
<ul class="nav">
|
||||||
<li><a href="/">Home</a></li>
|
<li><a href="/">Home</a></li>
|
||||||
|
<li><a href="/agents">Agents</a></li>
|
||||||
<li><a href="/events">Events</a></li>
|
<li><a href="/events">Events</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</div><!--/.nav-collapse -->
|
</div><!--/.nav-collapse -->
|
||||||
|
Loading…
Reference in New Issue
Block a user