webui: add / remove peers

This commit is contained in:
zeners 2016-01-12 19:26:04 +01:00
parent 5f77719f9c
commit 2e41c373b5
4 changed files with 165 additions and 32 deletions

View File

@ -3,12 +3,92 @@
var m = require("mithril"); var m = require("mithril");
var rs = require("retroshare"); var rs = require("retroshare");
var newkey = "";
var remote = "";
module.exports = { module.exports = {
view: function(){ view: function(){
return m("h2","add new friend"); var key = m.route.param("radix");
var pgp = m.route.param("pgp_id");
var peer_id =m.route.param("peer_id");
if (key===undefined && pgp === undefined) {
var owncert = rs("peers/self/certificate");
if (owncert === undefined ) {
owncert = {cert_string:"< waiting for server ... >"}
} }
} return m("div", [
m("h2","add new friend (Step 1/3)"),
m("p","Your own key, give it to your friends"),
m("pre", owncert.cert_string),
m("p","paste your friends key below"),
m("textarea", {
ref:"cert",
cols:"70",
rows:"16",
onchange: m.withAttr("value", function(value){newkey=value;})
}),
m("br"),
m("input.btn2",{
type:"button",
value:"read",
onclick: function (){
m.route("/addpeer",{radix:newkey})
},
})
]);
} else if (pgp === undefined) {
rs.request("peers/examine_cert",{cert_string:key},
function(data,responsetoken){
data.radix=key;
m.route("/addpeer", data);
}
);
return m("div", [
m("h2","add new friend (Step 2/3)"),
m("div", "analyse cert, please wait for server ...")
// { data: null, debug_msg: "failed to load certificate ", returncode: "fail" }
]);
} else {
var result = {
cert_string:key ,
flags:{
allow_direct_download:false,
allow_push:false,
// set to false, until the webinterface supports managment of the blacklist/whitelist
require_whitelist: false,
}
};
return m("div",[
m("h2","add new friend (Step 2/3)"),
m("p","Do you want to add "
+ m.route.param("name")
+ " (" + m.route.param("location") + ")"
+ " to your friendslist?"),
m("input.checkbox[type=checkbox]", {
onchange: m.withAttr("checked", function(checked){
result.flags.allow_direct_download=checked;
})
}), "Allow direct downloads from this node",
m("br"),
m("input.checkbox[type=checkbox]", {
onchange: m.withAttr("checked", function(checked){
result.flags.allow_push=checked;
})
}), "Auto download recommended files from this node",
m("div.btn2",{
onclick: function(){
rs.request("peers",result,function(data, responsetoken){
m.route("/peers");
})
}
},"add to friendslist")
])
}
}
};
/* /*

View File

@ -37,7 +37,7 @@ function Page(content, runst){
} else { } else {
if ("waiting_init|waiting_startup".match(runstate.runstate)) { if ("waiting_init|waiting_startup".match(runstate.runstate)) {
return m("h2","server starting ...") return m("h2","server starting ...")
} else if("waiting_account_select|running_ok*".match(runstate.runstate)) { } else if("waiting_account_select|running_ok.*".match(runstate.runstate)) {
if (runst === undefined || runst.match(runstate.runstate)) { if (runst === undefined || runst.match(runstate.runstate)) {
return m("div", [ return m("div", [
m("div", menu.view()), m("div", menu.view()),
@ -61,9 +61,8 @@ function Page(content, runst){
}; };
var me ={}; module.exports = {
init:function(main){
me.init = function(main){
console.log("start init ..."); console.log("start init ...");
var menudef = require("menudef"); var menudef = require("menudef");
var maps = {}; var maps = {};
@ -80,7 +79,6 @@ me.init = function(main){
m.route.mode = "hash"; m.route.mode = "hash";
m.route(main,"/",maps); m.route(main,"/",maps);
console.log("init done."); console.log("init done.");
}
}; };
module.exports = me;

View File

@ -6,34 +6,78 @@ var rs = require("retroshare");
module.exports = {view: function(){ module.exports = {view: function(){
var peers = rs("peers"); var peers = rs("peers");
console.log("peers:" + peers); console.log("peers:" + peers);
//waiting for peerlist ...
if(peers === undefined){ if(peers === undefined){
return m("div",[ return m("div",[
m("h2","peers"), m("h2","peers"),
m("h3","waiting_server"), m("h3","waiting_server"),
]); ]);
}; };
//building peerlist (prebuild for counting)
var online = 0; var online = 0;
var peerlist = peers.map(function(peer){ var peerlist = peers.map(function(peer){
var isonline = false; var isonline = false;
var avatar_address ="";
//building location list (prebuild for state + icon)
var loclist = peer.locations.map(function(location){ var loclist = peer.locations.map(function(location){
if (location.is_online && ! isonline){ if (location.is_online && ! isonline){
online +=1; online +=1;
isonline = true; isonline = true;
} }
return m("li", if (location.avatar_address != "" && avatar_address =="") {
{style:"color:" + (location.is_online ? "lime": "grey")}, avatar_address=location.avatar_address;
location.location); }
}); return m("div",{
return [ style:"color:" + (location.is_online ? "lime": "grey")
m("h2", {style:"color:" + (isonline ? "lime": "grey")} ,peer.name), + ";cursor:pointer",
m("ul", loclist ),
]; },location.location);
}); });
//return friend (peer + locations)
return m("div.flexbox[style=color:lime]",[
// avatar-icon
m("div", [
avatar_address == "" ? "" : (
m("img",{
src: rs.apiurl("peers" + avatar_address),
style:"border-radius:3mm;margin:2mm;",
})
)
]),
//peername + locations
m("div.flexwidemember",[
m("h1[style=margin-bottom:1mm;]",
{style:"color:" + (isonline ? "lime": "grey")} ,
peer.name
),
m("div", loclist ),
]),
//remove-button
m("div", {
style: "color:red;" +
"font-size:1.5em;" +
"padding:0.2em;" +
"cursor:pointer",
onclick: function (){
var yes = window.confirm(
"Remove " + peer.name + " from friendslist?");
if(yes){
rs.request("peers/" + peer.pgp_id +"/delete");
}
}
}, "X")
]);
});
// return add-peer-button + peerlist
return m("div",[ return m("div",[
m("div.btn2",{onclick: function(){m.route("/addpeer")}},"add new friend"), m("div.btn2",{onclick: function(){m.route("/addpeer")}},"add new friend"),
m("h2","peers ( online: " + online +" / " + peers.length + "):"), m("h2","peers (online: " + online +" / " + peers.length + "):"),
m("table", [ m("div", [
peerlist, peerlist,
]), ]),
]); ]);

View File

@ -215,3 +215,14 @@ rs.forceUpdate = function(path){
cache[path].requested=false; cache[path].requested=false;
} }
//return api-path
rs.apiurl = function(path) {
if (path === undefined) {
path="";
}
if (path.length > 0 && "^\\\\|\\/".match(path)) {
path=path.substr(1);
}
return api_url + path;
}