show sofia status on portal
This commit is contained in:
parent
f80404c777
commit
f5a2346e4f
|
@ -218,6 +218,12 @@ App.newUserRoute = Ember.Route.extend({
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
App.SofiaStatusRoute = Ember.Route.extend({
|
||||||
|
setupController: function(controller) {
|
||||||
|
App.sofiaStatusController.load();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
App.Router.map(function(){
|
App.Router.map(function(){
|
||||||
this.route("calls");
|
this.route("calls");
|
||||||
this.route("channels");
|
this.route("channels");
|
||||||
|
@ -241,6 +247,8 @@ App.Router.map(function(){
|
||||||
this.route("show");
|
this.route("show");
|
||||||
this.route("users");
|
this.route("users");
|
||||||
this.route("newUser");
|
this.route("newUser");
|
||||||
|
this.route("sofiaStatus");
|
||||||
|
this.route("addGateway");
|
||||||
this.route("about", { path: "/about" });
|
this.route("about", { path: "/about" });
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -778,6 +786,95 @@ App.UsersController = Ember.ObjectController.extend({
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
App.sofiaStatusController = Ember.ArrayController.create({
|
||||||
|
content: [],
|
||||||
|
init: function(){
|
||||||
|
},
|
||||||
|
load: function() {
|
||||||
|
var me = this;
|
||||||
|
$.get("/xmlapi/sofia?xmlstatus", function(data){
|
||||||
|
console.log(data);
|
||||||
|
var row_count = 0;
|
||||||
|
var aliases = data.getElementsByTagName("alias");
|
||||||
|
var profiles = data.getElementsByTagName("profile");
|
||||||
|
var gateways = data.getElementsByTagName("gateway");
|
||||||
|
|
||||||
|
me.content.clear();
|
||||||
|
|
||||||
|
for (var i=0; i<aliases.length; i++) {
|
||||||
|
var row = {};
|
||||||
|
row.name = aliases[i].getElementsByTagName("name")[0].textContent;
|
||||||
|
row.type = aliases[i].getElementsByTagName("type")[0].textContent;
|
||||||
|
row.data = aliases[i].getElementsByTagName("data")[0].textContent;
|
||||||
|
row.state = aliases[i].getElementsByTagName("state")[0].textContent;
|
||||||
|
console.log(row)
|
||||||
|
row_count++;
|
||||||
|
me.pushObject(row);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (var i=0; i<profiles.length; i++) {
|
||||||
|
var row = {};
|
||||||
|
row.name = profiles[i].getElementsByTagName("name")[0].textContent;
|
||||||
|
row.type = profiles[i].getElementsByTagName("type")[0].textContent;
|
||||||
|
row.data = profiles[i].getElementsByTagName("data")[0].textContent;
|
||||||
|
row.state = profiles[i].getElementsByTagName("state")[0].textContent;
|
||||||
|
row.actions = "Start | Stop | Restart | More ...";
|
||||||
|
console.log(row)
|
||||||
|
row_count++;
|
||||||
|
me.pushObject(row);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (var i=0; i<gateways.length; i++) {
|
||||||
|
var row = {};
|
||||||
|
row.name = gateways[i].getElementsByTagName("name")[0].textContent;
|
||||||
|
row.type = gateways[i].getElementsByTagName("type")[0].textContent;
|
||||||
|
row.data = gateways[i].getElementsByTagName("data")[0].textContent;
|
||||||
|
row.state = gateways[i].getElementsByTagName("state")[0].textContent;
|
||||||
|
row.actions = "Reg | UnReg | Delete";
|
||||||
|
console.log(row)
|
||||||
|
row_count++;
|
||||||
|
me.pushObject(row);
|
||||||
|
}
|
||||||
|
|
||||||
|
me.set('total', row_count);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
App.SofiaStatusController = Ember.ObjectController.extend({
|
||||||
|
newGatewayButtons: [
|
||||||
|
{title: 'Submit', clicked: "submit"},
|
||||||
|
{title: 'Cancel', clicked: "cancel", dismiss: 'modal'}
|
||||||
|
],
|
||||||
|
|
||||||
|
actions: {
|
||||||
|
//Submit the modal
|
||||||
|
submit: function() {
|
||||||
|
alert("Not implemented");
|
||||||
|
return false;
|
||||||
|
$.post("/txtapi/lua?create_gw.lua%20" + $("#gateway_name").val(), {
|
||||||
|
success: function() { },
|
||||||
|
error: function(e) { }
|
||||||
|
});
|
||||||
|
|
||||||
|
// Bootstrap.NM.push('Successfully submitted modal', 'success');
|
||||||
|
return Bootstrap.ModalManager.hide('newUserForm');
|
||||||
|
},
|
||||||
|
|
||||||
|
//Cancel the modal, we don't need to hide the model manually because we set {..., dismiss: 'modal'} on the button meta data
|
||||||
|
cancel: function() {
|
||||||
|
Bootstrap.ModalManager.hide('newUserForm');
|
||||||
|
return Bootstrap.NM.push('Modal was cancelled', 'info');
|
||||||
|
},
|
||||||
|
|
||||||
|
//Show the modal
|
||||||
|
addGateway: function() {
|
||||||
|
return Bootstrap.ModalManager.show('newUserForm');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// App.initialize();
|
// App.initialize();
|
||||||
var global_debug_event = false;
|
var global_debug_event = false;
|
||||||
var global_background_job = false;
|
var global_background_job = false;
|
||||||
|
|
|
@ -92,6 +92,7 @@
|
||||||
<li><a id="menu-calls" href="#calls">Calls</a></li>
|
<li><a id="menu-calls" href="#calls">Calls</a></li>
|
||||||
<li><a id="menu-channels" href="#channels">Channels</a></li>
|
<li><a id="menu-channels" href="#channels">Channels</a></li>
|
||||||
<li><a href="#show">Show</a></li>
|
<li><a href="#show">Show</a></li>
|
||||||
|
<li><a href="#sofiaStatus">Sofia</a></li>
|
||||||
<li><a href="#about">About</a></li>
|
<li><a href="#about">About</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</nav>
|
</nav>
|
||||||
|
@ -640,6 +641,66 @@
|
||||||
</div>
|
</div>
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<script type="text/x-handlebars" data-template-name="sofiaStatus">
|
||||||
|
<div class="pull-right">
|
||||||
|
{{#bs-button type="primary" clicked="addGateway"}}Add Gateway{{/bs-button}}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{{#bs-modal name="newUserForm" fade="true" footerButtonsBinding="addGatewayButtons" title="Add Gateway"}}
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label" for="gateway_name">Name</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="input-xlarge" name="gateway_name" value="">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label" for="gateway_realm">Realm</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="input-xlarge" name="gateway_realm" value="">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label" for="gateway_name">Username</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="input-xlarge" name="gateway_username" value="">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label" for="gateway_name">Password</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="input-xlarge" name="gateway_password" value="">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="modal-footer">
|
||||||
|
{{#bs-button type="primary" clicked="submit"}}Add{{/bs-button}}
|
||||||
|
{{#bs-button clicked="cancel"}}Cancel{{/bs-button}}
|
||||||
|
</div>
|
||||||
|
{{/bs-modal}}
|
||||||
|
|
||||||
|
<h1>Sofia Status</h1>
|
||||||
|
|
||||||
|
<div>
|
||||||
|
<table class="table">
|
||||||
|
<tr>
|
||||||
|
<th>Type</th>
|
||||||
|
<th>Name</th>
|
||||||
|
<th>Data</th>
|
||||||
|
<th>State</th>
|
||||||
|
<th>Action</th>
|
||||||
|
</tr>
|
||||||
|
{{#each App.sofiaStatusController.content}}
|
||||||
|
<tr>
|
||||||
|
<td>{{ type }}</td>
|
||||||
|
<td>{{ name }}</td>
|
||||||
|
<td>{{ data }}</td>
|
||||||
|
<td>{{ state }}</td>
|
||||||
|
<td>{{ actions }}</td>
|
||||||
|
</tr>
|
||||||
|
{{/each}}
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</script>
|
||||||
|
|
||||||
<script type="text/x-handlebars" data-template-name="calls">
|
<script type="text/x-handlebars" data-template-name="calls">
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<label><input type="checkbox" id="auto_update_calls" value="1" onclick="auto_update_calls();">Auto Update</label>
|
<label><input type="checkbox" id="auto_update_calls" value="1" onclick="auto_update_calls();">Auto Update</label>
|
||||||
|
|
Loading…
Reference in New Issue