1
0
mirror of https://github.com/S2-/pwgen.git synced 2025-08-02 17:00:03 +02:00

31 Commits

Author SHA1 Message Date
s2
eaab8485e7 v1.1.15 2017-11-23 12:29:14 +01:00
s2
f5dc33bbb0 more = 2017-11-23 12:29:01 +01:00
s2
1c7ba3298c 1.1.14 2017-11-23 12:26:21 +01:00
s2
5cd436d8eb = 2017-11-23 12:26:00 +01:00
s2
75bbd1d24c add screencast 2017-11-23 09:15:29 +01:00
s2
8b02b259da make it work with 0 2017-11-23 08:53:59 +01:00
s2
969ad13e23 v1.1.13 2017-11-23 08:49:46 +01:00
s2
005570d04d fix length generator 2017-11-23 08:49:33 +01:00
s2
06cfa9d0da v1.1.12 2017-11-23 08:29:04 +01:00
s2
fa5ba83db2 make length random 2017-11-23 08:28:37 +01:00
s2
5c37f822db wait for transition to be completed 2017-11-22 16:10:15 +01:00
s2
a53d60474d v1.1.11 2017-11-22 12:25:14 +01:00
s2
4d7fefccfc use css for transition 2017-11-22 12:06:55 +01:00
s2
0d6278cd82 v1.1.10 2017-11-22 10:35:18 +01:00
s2
fee9b6b20a show notification when button pressed too 2017-11-22 10:27:58 +01:00
s2
5959bc4cbe v1.1.9 2017-11-22 09:27:29 +01:00
s2
93c4955d1d copy pass to clipboard notification 2017-11-22 09:25:44 +01:00
s2
3a64948533 i like this one better 2017-11-21 21:04:09 +01:00
s2
a0d5b54b5d new screenshot 2017-11-21 20:59:53 +01:00
s2
396236254a readme 2017-11-21 20:54:48 +01:00
s2
fcceca980c v1.1.8 2017-11-21 19:44:29 +01:00
s2
59094b76bb increment delay to 200ms 2017-11-21 19:44:03 +01:00
s2
6c773377b1 v1.1.7 2017-11-21 19:33:35 +01:00
s2
b0932baeea add timeout before copying password 2017-11-21 19:33:09 +01:00
s2
81d5bbb055 add a margin 2017-11-21 15:39:56 +01:00
s2
c26eba33c0 v1.1.6 2017-11-21 09:31:21 +01:00
s2
42838040d2 use crypto.getRandomValues 2017-11-21 09:30:54 +01:00
s2
8ab06aa554 remove useless css 2017-11-21 09:30:44 +01:00
s2
07b558eeb7 v1.1.5 2017-11-21 09:13:36 +01:00
s2
be3046051a do not repeat numbers 2017-11-21 09:11:22 +01:00
s2
17c92ce99a update screenshot 2017-11-21 08:33:42 +01:00
8 changed files with 116 additions and 42 deletions

12
README.md Normal file
View File

@@ -0,0 +1,12 @@
# pwgen reloaded
## What it does
A firefox addon that generates a password and copies it to the clipboard
![pwgen reloaded in action](img/cast.gif)
## install
On amo!
[https://addons.mozilla.org/firefox/addon/pwgen-reloaded/](https://addons.mozilla.org/firefox/addon/pwgen-reloaded/)

BIN
img/cast.gif Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 366 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

After

Width:  |  Height:  |  Size: 29 KiB

View File

@@ -1,5 +0,0 @@
# pwgen
## What it does ##
Simply generate a password and copy it to the clipboard

View File

@@ -2,7 +2,7 @@
"description": "Just a toolbar button that generates a password and copies it to your clipboard.", "description": "Just a toolbar button that generates a password and copies it to your clipboard.",
"manifest_version": 2, "manifest_version": 2,
"name": "pwgen reloaded", "name": "pwgen reloaded",
"version": "1.1.4", "version": "1.1.15",
"homepage_url": "https://github.com/S2-/pwgen", "homepage_url": "https://github.com/S2-/pwgen",
"icons": { "icons": {
"48": "icons/lock-48.png" "48": "icons/lock-48.png"

View File

@@ -2,6 +2,10 @@ body {
margin: 15px; margin: 15px;
} }
div {
margin-top: 5px;
}
input[type="number"] { input[type="number"] {
-moz-appearance: none; -moz-appearance: none;
color: var(--in-content-text-color); color: var(--in-content-text-color);
@@ -17,6 +21,30 @@ input[type="number"] {
font-size: inherit; font-size: inherit;
padding: 5px 10px; padding: 5px 10px;
} }
input[type="checkbox"] { input[type="checkbox"] {
margin-bottom: -7px; margin-bottom: -7px;
} }
.copied {
/*height: 100%;*/
width: 100%;
background-color: #FFF8DC;
position: absolute;
margin: -25px;
margin-top: -5px;
padding: 5px;
text-align: center;
}
.fadein {
visibility: visible;
opacity: 1;
transition: opacity 1s linear;
}
.fadeout {
visibility: hidden;
opacity: 0;
transition: visibility 0s 1s, opacity 1s linear;
}

View File

@@ -2,24 +2,27 @@
<html> <html>
<head> <head>
<meta charset="utf-8"> <meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="chrome://global/skin/global.css" type="text/css" /> <link rel="stylesheet" href="chrome://global/skin/global.css" type="text/css" />
<link rel="stylesheet" href="chrome://global/skin/in-content/common.css" type="text/css" /> <link rel="stylesheet" href="chrome://global/skin/in-content/common.css" type="text/css" />
<link rel="stylesheet" href="chrome://mozapps/content/extensions/extensions.css" type="text/css" />
<link rel="stylesheet" href="resource://gre-resources/forms.css" type="text/css" />
<link rel="stylesheet" href="pwgen.css"/> <link rel="stylesheet" href="pwgen.css"/>
</head> </head>
<body> <body>
<div class="copied" style="display: none;">password copied to clipboard</div>
<form> <form>
<div> <div>
<label for"length">length <input type="number" id="length" value="14" min="0" name="length"></label> <label>length</label>
<label for="length-min">min <input type="number" id="length-min" value="14" min="0" name="length-min" style="width: 50px;"></label>
<label for="length-max">max <input type="number" id="length-max" value="18" min="0" name="length-max" style="width: 50px;"></label>
</div> </div>
<div> <div>
<input type="checkbox" id="special" checked="checked" name="special"> <input type="checkbox" id="special" checked="checked" name="special">
<label for"special">include special chars</label> <label for="special">include special chars</label>
</div> </div>
<div> <div>

View File

@@ -1,17 +1,27 @@
function randPassword(length, includeSpecial) { function randPassword(length, includeSpecial) {
let pwdChars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz1234567890"; let pwdChars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
if (includeSpecial) { if (includeSpecial) {
pwdChars += '°^!"§$%&/()=?`´\\}][{²³€|<>-.,;:*+_µ@~'; pwdChars += '°^!"§$%&/()=?`´\\}][{²³€|<>-.,;:*+_µ@~';
} }
let randPassword = Array(length).fill(pwdChars).map(function(x) {
return x[Math.floor(Math.random() * x.length)] let randValues = new Uint32Array(length);
}).join(''); let randPwd = '';
return randPassword; window.crypto.getRandomValues(randValues);
for(i=0; i<length; i++)
{
randPwd += pwdChars[randValues[i] % pwdChars.length];
}
return randPwd;
}
function generateLength() {
return Math.floor(Math.random() * (getParams().lengthMax - getParams().lengthMin + 1) + getParams().lengthMin);
} }
function getParams() { function getParams() {
return { return {
length: parseInt(document.getElementById('length').value), lengthMin: parseInt(document.getElementById('length-min').value),
lengthMax: parseInt(document.getElementById('length-max').value),
special: document.getElementById('special').checked, special: document.getElementById('special').checked,
directcopy: document.getElementById('directcopy').checked directcopy: document.getElementById('directcopy').checked
} }
@@ -19,7 +29,8 @@ function getParams() {
function loadOptions() { function loadOptions() {
return browser.storage.local.get({ return browser.storage.local.get({
length: 14, lengthMin: 14,
lengthMax: 17,
special: true, special: true,
directcopy: false directcopy: false
}); });
@@ -29,37 +40,62 @@ function saveOptions(options) {
return browser.storage.local.set(options); return browser.storage.local.set(options);
} }
function copypasstoclippboard() { function copypasstoclippboard(cb) {
var copyText = document.getElementById('pw'); setTimeout(function() {
copyText.select(); var copyText = document.getElementById('pw');
document.execCommand('copy'); copyText.select();
document.execCommand('copy');
if (typeof(cb) === 'function') {
cb();
}
fade(document.getElementsByClassName('copied')[0]);
}, 200);
} }
document.getElementById('new').addEventListener('click', (ev) => { function fade(element) {
ev.preventDefault(); var clone = element.cloneNode(true);
var params = getParams(); clone.style.display = 'block';
document.getElementById('pw').value = randPassword(params.length, params.special); element.parentNode.insertBefore(clone, element.nextSibling);
});
document.getElementById('copy').addEventListener('click', (ev) => { setTimeout(() => {
ev.preventDefault(); clone.className += ' fadeout';
copypasstoclippboard(); }, 500);
});
var list = document.getElementsByTagName('input'); setTimeout(() => {
for (var i = 0; i < list.length; i++) { clone.remove();
list[i].addEventListener('change', (ev) => { }, 1600);
saveOptions(getParams()); }
document.addEventListener('DOMContentLoaded', function() {
document.getElementById('new').addEventListener('click', (ev) => {
ev.preventDefault();
var params = getParams();
document.getElementById('pw').value = randPassword(generateLength(), params.special);
}); });
}
loadOptions().then((options) => { document.getElementById('copy').addEventListener('click', (ev) => {
document.getElementById('length').value = options.length; ev.preventDefault();
document.getElementById('special').checked = options.special;
document.getElementById('directcopy').checked = options.directcopy;
document.getElementById('pw').value = randPassword(getParams().length, getParams().special);
if (options.directcopy) {
copypasstoclippboard(); copypasstoclippboard();
});
var list = document.getElementsByTagName('input');
for (var i = 0; i < list.length; i++) {
list[i].addEventListener('change', (ev) => {
saveOptions(getParams());
});
} }
loadOptions().then((options) => {
document.getElementById('length-min').value = options.lengthMin;
document.getElementById('length-max').value = options.lengthMax;
document.getElementById('special').checked = options.special;
document.getElementById('directcopy').checked = options.directcopy;
document.getElementById('pw').value = randPassword(generateLength(), getParams().special);
if (options.directcopy) {
copypasstoclippboard();
}
});
}); });