mirror of
https://github.com/tlsnotary/PageSigner.git
synced 2026-01-09 14:48:07 -05:00
101 lines
6.2 KiB
JavaScript
101 lines
6.2 KiB
JavaScript
var is_chrome = window.navigator.userAgent.match('Chrome') ? true : false;
|
|
|
|
function install_bar(sessionId, serverName, hideButton) {
|
|
if (hideButton === undefined) {
|
|
hideButton = false;
|
|
}
|
|
|
|
var table = document.createElement("table");
|
|
table.style.position = "fixed";
|
|
table.style.top = "0px";
|
|
table.style.left = "100px";
|
|
table.style.background = "rgba(242, 241, 240, 0.9)";
|
|
table.style.width = "80%";
|
|
table.style.height = "32px";
|
|
table.style.visibility = 'hidden';
|
|
table.style.opacity = '0';
|
|
table.style.webkitTransition = 'visibility 0s 2s, opacity 2s linear';
|
|
table.style.transition = 'visibility 0s 2s, opacity 2s linear';
|
|
var row = document.createElement("tr");
|
|
|
|
var cell1 = document.createElement("td");
|
|
var cell2 = document.createElement("td");
|
|
var cell3 = document.createElement("td");
|
|
var cell4 = document.createElement("td");
|
|
|
|
cell3.style.align = "right";
|
|
cell4.style.align = "right";
|
|
var img = document.createElement("img");
|
|
//icon.png base64-encoded
|
|
img.src = "";
|
|
img.height = 16;
|
|
img.width = 16;
|
|
var text = document.createElement("text");
|
|
text.textContent = "PageSigner verified that this page was received from ";
|
|
var domain = document.createElement("text");
|
|
domain.id = "domainName";
|
|
domain.textContent = serverName;
|
|
var button = document.createElement("button");
|
|
button.id = "viewRaw";
|
|
button.textContent = "View raw data";
|
|
button.style.MozBorderRadius = "4px";
|
|
button.style.WebkitBorderRadius = "4px";
|
|
button.style.borderRadius = "4px";
|
|
button.onclick = function() {
|
|
if (is_chrome) {
|
|
chrome.runtime.sendMessage({
|
|
destination: 'extension',
|
|
message: 'viewraw',
|
|
args: {
|
|
dir: sessionId
|
|
}
|
|
});
|
|
} else {
|
|
var port = chrome.runtime.connect({
|
|
name: "notification-to-extension"
|
|
});
|
|
port.postMessage({
|
|
'destination': 'extension',
|
|
'message': 'viewraw',
|
|
args: {
|
|
dir: sessionId
|
|
}
|
|
});
|
|
}
|
|
};
|
|
if (hideButton) {
|
|
button.hidden = true;
|
|
}
|
|
|
|
var close = document.createElement("a");
|
|
close.text = "x";
|
|
close.style = 'cursor: pointer;';
|
|
close.onclick = function(event) {
|
|
document.getElementById('tablediv').hidden = true;
|
|
}
|
|
|
|
cell4.appendChild(close);
|
|
cell3.appendChild(button)
|
|
cell2.appendChild(text);
|
|
cell2.appendChild(domain);
|
|
cell1.appendChild(img);
|
|
row.appendChild(cell1);
|
|
row.appendChild(cell2);
|
|
row.appendChild(cell3);
|
|
row.appendChild(cell4);
|
|
table.appendChild(row);
|
|
var tablediv = document.createElement('div');
|
|
tablediv.appendChild(table);
|
|
tablediv.id = 'tablediv';
|
|
document.body.appendChild(tablediv);
|
|
|
|
setTimeout(function() {
|
|
//make a transition to visible
|
|
table.style.visibility = 'visible';
|
|
table.style.opacity = '1';
|
|
table.style.webkitTransition = 'opacity 2s linear';
|
|
table.style.transition = 'opacity 2s linear';
|
|
}, 0);
|
|
|
|
}
|