mirror of
https://github.com/the-djmaze/snappymail.git
synced 2024-09-20 15:45:55 +08:00
OpenPGP (Compose) (#53) UNSTABLE
This commit is contained in:
parent
b330f77bc0
commit
1c4ce1dfb2
|
@ -328,6 +328,7 @@ RainLoopApp.prototype.reloadOpenPgpKeys = function ()
|
|||
{
|
||||
var
|
||||
aKeys = [],
|
||||
oEmail = new EmailModel(),
|
||||
oOpenpgpKeyring = RL.data().openpgpKeyring,
|
||||
oOpenpgpKeys = oOpenpgpKeyring ? oOpenpgpKeyring.keys : []
|
||||
;
|
||||
|
@ -336,20 +337,28 @@ RainLoopApp.prototype.reloadOpenPgpKeys = function ()
|
|||
if (oItem && oItem.primaryKey)
|
||||
{
|
||||
var
|
||||
|
||||
oPrimaryUser = oItem.getPrimaryUser(),
|
||||
sUser = (oPrimaryUser && oPrimaryUser.user) ? oPrimaryUser.user.userId.userid
|
||||
: (oItem.users && oItem.users[0] ? oItem.users[0].userId.userid : '')
|
||||
;
|
||||
|
||||
oEmail.clear();
|
||||
oEmail.mailsoParse(sUser);
|
||||
|
||||
if (oEmail.validate())
|
||||
{
|
||||
aKeys.push(new OpenPgpKeyModel(
|
||||
iIndex,
|
||||
oItem.primaryKey.getFingerprint(),
|
||||
oItem.primaryKey.getKeyId().toHex().toLowerCase(),
|
||||
sUser,
|
||||
oEmail.email,
|
||||
oItem.isPrivate(),
|
||||
oItem.armor())
|
||||
);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
RL.data().openpgpkeys(aKeys);
|
||||
|
|
|
@ -182,6 +182,7 @@ NewHtmlEditorWrapper.prototype.init = function ()
|
|||
self.editor.setKeystroke(window.CKEDITOR.CTRL + 65/* A */, 'selectAll');
|
||||
|
||||
self.fOnReady();
|
||||
self.__resizable = true;
|
||||
self.resize();
|
||||
});
|
||||
}
|
||||
|
@ -206,7 +207,7 @@ NewHtmlEditorWrapper.prototype.blur = function ()
|
|||
|
||||
NewHtmlEditorWrapper.prototype.resize = function ()
|
||||
{
|
||||
if (this.editor)
|
||||
if (this.editor && this.__resizable)
|
||||
{
|
||||
this.editor.resize(this.$element.width(), this.$element.innerHeight());
|
||||
}
|
||||
|
|
|
@ -5,16 +5,18 @@
|
|||
* @param {string} sGuID
|
||||
* @param {string} sID
|
||||
* @param {string} sUserID
|
||||
* @param {string} sEmail
|
||||
* @param {boolean} bIsPrivate
|
||||
* @param {string} sArmor
|
||||
* @constructor
|
||||
*/
|
||||
function OpenPgpKeyModel(iIndex, sGuID, sID, sUserID, bIsPrivate, sArmor)
|
||||
function OpenPgpKeyModel(iIndex, sGuID, sID, sUserID, sEmail, bIsPrivate, sArmor)
|
||||
{
|
||||
this.index = iIndex;
|
||||
this.id = sID;
|
||||
this.guid = sGuID;
|
||||
this.user = sUserID;
|
||||
this.email = sEmail;
|
||||
this.armor = sArmor;
|
||||
this.isPrivate = !!bIsPrivate;
|
||||
|
||||
|
@ -25,5 +27,6 @@ OpenPgpKeyModel.prototype.index = 0;
|
|||
OpenPgpKeyModel.prototype.id = '';
|
||||
OpenPgpKeyModel.prototype.guid = '';
|
||||
OpenPgpKeyModel.prototype.user = '';
|
||||
OpenPgpKeyModel.prototype.email = '';
|
||||
OpenPgpKeyModel.prototype.armor = '';
|
||||
OpenPgpKeyModel.prototype.isPrivate = false;
|
||||
|
|
|
@ -6,18 +6,8 @@
|
|||
function SettingsOpenPGP()
|
||||
{
|
||||
this.openpgpkeys = RL.data().openpgpkeys;
|
||||
|
||||
this.openpgpkeysPublic = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && !oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
|
||||
this.openpgpkeysPrivate = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
this.openpgpkeysPublic = RL.data().openpgpkeysPublic;
|
||||
this.openpgpkeysPrivate = RL.data().openpgpkeysPrivate;
|
||||
|
||||
this.openPgpKeyForDeletion = ko.observable(null).extend({'falseTimeout': 3000}).extend({'toggleSubscribe': [this,
|
||||
function (oPrev) {
|
||||
|
|
|
@ -98,7 +98,6 @@ function WebMailDataStorage()
|
|||
return bLoading || bCreating || bDeleting || bRenaming;
|
||||
}, this);
|
||||
|
||||
|
||||
this.foldersInboxUnreadCount = ko.observable(0);
|
||||
|
||||
this.currentFolder = ko.observable(null).extend({'toggleSubscribe': [null,
|
||||
|
@ -348,6 +347,18 @@ function WebMailDataStorage()
|
|||
this.openpgpkeys = ko.observableArray([]);
|
||||
this.openpgpKeyring = null;
|
||||
|
||||
this.openpgpkeysPublic = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && !oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
|
||||
this.openpgpkeysPrivate = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
|
||||
// google
|
||||
this.googleActions = ko.observable(false);
|
||||
this.googleLoggined = ko.observable(false);
|
||||
|
@ -716,7 +727,6 @@ WebMailDataStorage.prototype.getNextFolderNames = function (bBoot)
|
|||
};
|
||||
|
||||
/**
|
||||
* @param {Function} fCallback
|
||||
* @param {string} sFromFolderFullNameRaw
|
||||
* @param {Array} aUidForRemove
|
||||
* @param {string=} sToFolderFullNameRaw = ''
|
||||
|
|
|
@ -16,13 +16,168 @@ function PopupsComposeOpenPgpViewModel()
|
|||
this.password = ko.observable('');
|
||||
this.password.focus = ko.observable(true);
|
||||
|
||||
this.from = ko.observable('');
|
||||
this.to = ko.observableArray([]);
|
||||
this.text = ko.observable('');
|
||||
|
||||
this.resultCallback = null;
|
||||
|
||||
this.submitRequest = ko.observable(false);
|
||||
|
||||
// commands
|
||||
this.doCommand = Utils.createCommand(this, function () {
|
||||
|
||||
this.cancelCommand();
|
||||
var
|
||||
self = this,
|
||||
bResult = true,
|
||||
aOpenpgpkeysPublic = RL.data().openpgpkeysPublic(),
|
||||
oKey = null,
|
||||
oPrivateKey = null,
|
||||
aPublicKeys = [],
|
||||
fFindPublicKey = function (sEmail) {
|
||||
|
||||
var
|
||||
oResult = null,
|
||||
oKey = _.find(aOpenpgpkeysPublic, function (oItem) {
|
||||
return oItem && sEmail === oItem.email;
|
||||
})
|
||||
;
|
||||
|
||||
if (oKey)
|
||||
{
|
||||
try
|
||||
{
|
||||
oResult = window.openpgp.key.readArmored(oKey.armor);
|
||||
if (oResult && !oResult.err && oResult.keys && oResult.keys[0])
|
||||
{
|
||||
oResult = oResult.keys[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
oResult = null;
|
||||
}
|
||||
}
|
||||
catch (e)
|
||||
{
|
||||
oResult = null;
|
||||
}
|
||||
}
|
||||
|
||||
return oResult;
|
||||
}
|
||||
;
|
||||
|
||||
this.submitRequest(true);
|
||||
|
||||
if (bResult && this.sign() && '' === this.from())
|
||||
{
|
||||
this.notification('Please specify From email address');
|
||||
bResult = false;
|
||||
}
|
||||
|
||||
if (bResult && this.sign())
|
||||
{
|
||||
oKey = _.find(RL.data().openpgpkeysPrivate(), function (oItem) {
|
||||
return oItem && self.from() === oItem.email;
|
||||
});
|
||||
|
||||
if (oKey)
|
||||
{
|
||||
try
|
||||
{
|
||||
oPrivateKey = window.openpgp.key.readArmored(oKey.armor);
|
||||
if (oPrivateKey && !oPrivateKey.err && oPrivateKey.keys && oPrivateKey.keys[0])
|
||||
{
|
||||
oPrivateKey = oPrivateKey.keys[0];
|
||||
oPrivateKey.decrypt(this.password());
|
||||
}
|
||||
else
|
||||
{
|
||||
oPrivateKey = null;
|
||||
}
|
||||
}
|
||||
catch (e)
|
||||
{
|
||||
oPrivateKey = null;
|
||||
}
|
||||
}
|
||||
|
||||
if (!oPrivateKey)
|
||||
{
|
||||
this.notification('No private key found for "' + this.from() + '" email');
|
||||
bResult = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (bResult && this.encrypt() && 0 === this.to().length)
|
||||
{
|
||||
this.notification('Please specify at least one recipient');
|
||||
bResult = false;
|
||||
}
|
||||
|
||||
if (bResult && this.encrypt())
|
||||
{
|
||||
aPublicKeys = _.compact(_.map(this.to(), function (sEmail) {
|
||||
var oKey = fFindPublicKey(sEmail);
|
||||
if (!oKey && bResult)
|
||||
{
|
||||
self.notification('No public key found for "' + sEmail + '" email');
|
||||
bResult = false;
|
||||
}
|
||||
|
||||
return oKey;
|
||||
|
||||
}));
|
||||
|
||||
if (0 === aPublicKeys.length || this.to().length !== aPublicKeys.length)
|
||||
{
|
||||
bResult = false;
|
||||
}
|
||||
}
|
||||
|
||||
_.delay(function () {
|
||||
|
||||
if (self.resultCallback && bResult)
|
||||
{
|
||||
try {
|
||||
|
||||
if (oPrivateKey && 0 === aPublicKeys.length)
|
||||
{
|
||||
self.resultCallback(
|
||||
window.openpgp.signClearMessage([oPrivateKey], self.text())
|
||||
);
|
||||
}
|
||||
else if (oPrivateKey && 0 < aPublicKeys.length)
|
||||
{
|
||||
self.resultCallback(
|
||||
window.openpgp.signAndEncryptMessage(aPublicKeys, oPrivateKey, self.text())
|
||||
);
|
||||
}
|
||||
else if (!oPrivateKey && 0 < aPublicKeys.length)
|
||||
{
|
||||
self.resultCallback(
|
||||
window.openpgp.encryptMessage(aPublicKeys, self.text())
|
||||
);
|
||||
}
|
||||
}
|
||||
catch (e)
|
||||
{
|
||||
self.notification('OpenPGP error: ' + e);
|
||||
bResult = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (bResult)
|
||||
{
|
||||
self.cancelCommand();
|
||||
}
|
||||
|
||||
self.submitRequest(false);
|
||||
|
||||
}, 10);
|
||||
|
||||
}, function () {
|
||||
return '' === this.notification();
|
||||
return !this.submitRequest() && (this.sign() || this.encrypt());
|
||||
});
|
||||
|
||||
Knoin.constructorEnd(this);
|
||||
|
@ -36,6 +191,14 @@ PopupsComposeOpenPgpViewModel.prototype.clearPopup = function ()
|
|||
|
||||
this.password('');
|
||||
this.password.focus(false);
|
||||
|
||||
this.from('');
|
||||
this.to([]);
|
||||
this.text('');
|
||||
|
||||
this.submitRequest(false);
|
||||
|
||||
this.resultCallback = null;
|
||||
};
|
||||
|
||||
PopupsComposeOpenPgpViewModel.prototype.onHide = function ()
|
||||
|
@ -53,20 +216,11 @@ PopupsComposeOpenPgpViewModel.prototype.onShow = function (fCallback, sText, sFr
|
|||
aRec = []
|
||||
;
|
||||
|
||||
if ('' === sTo + sCc + sBcc)
|
||||
{
|
||||
this.notification('Please specify at least one recipient');
|
||||
return false;
|
||||
}
|
||||
this.resultCallback = fCallback;
|
||||
|
||||
oEmail.clear();
|
||||
oEmail.mailsoParse(sFromEmail);
|
||||
if ('' === oEmail.email)
|
||||
{
|
||||
this.notification('Please specify From email address');
|
||||
return false;
|
||||
}
|
||||
else
|
||||
if ('' !== oEmail.email)
|
||||
{
|
||||
sResultFromEmail = oEmail.email;
|
||||
}
|
||||
|
@ -93,22 +247,7 @@ PopupsComposeOpenPgpViewModel.prototype.onShow = function (fCallback, sText, sFr
|
|||
return '' === oEmail.email ? false : oEmail.email;
|
||||
}));
|
||||
|
||||
if (0 === aRec.length)
|
||||
{
|
||||
this.notification('Please specify at least one recipient');
|
||||
return false;
|
||||
}
|
||||
|
||||
window.console.log(sResultFromEmail);
|
||||
window.console.log(aRec);
|
||||
|
||||
// TODO
|
||||
};
|
||||
|
||||
PopupsComposeOpenPgpViewModel.prototype.onFocus = function ()
|
||||
{
|
||||
if (this.sign())
|
||||
{
|
||||
this.password.focus(true);
|
||||
}
|
||||
this.from(sResultFromEmail);
|
||||
this.to(aRec);
|
||||
this.text(sText);
|
||||
};
|
||||
|
|
|
@ -362,9 +362,12 @@ PopupsComposeViewModel.prototype.openOpenPgpPopup = function ()
|
|||
{
|
||||
if (this.allowOpenPGP() && this.oEditor && !this.oEditor.isHtml())
|
||||
{
|
||||
var self = this;
|
||||
kn.showScreenPopup(PopupsComposeOpenPgpViewModel, [
|
||||
function () {
|
||||
|
||||
function (sResult) {
|
||||
self.editor(function (oEditor) {
|
||||
oEditor.setPlain(sResult);
|
||||
});
|
||||
},
|
||||
this.oEditor.getData(),
|
||||
this.currentIdentityResultEmail(),
|
||||
|
|
|
@ -36,7 +36,7 @@
|
|||
</div>
|
||||
<div class="modal-footer">
|
||||
<a class="btn buttonDo" data-bind="command: doCommand">
|
||||
<i class="icon-key"></i>
|
||||
<i data-bind="css: {'icon-key': !submitRequest(), 'icon-spinner animated': submitRequest()}"></i>
|
||||
|
||||
<span class="i18n" data-i18n-text="POPUPS_COMPOSE_OPEN_PGP/BUTTON_DO"></span>
|
||||
</a>
|
||||
|
|
6
rainloop/v/0.0.0/static/js/admin.min.js
vendored
6
rainloop/v/0.0.0/static/js/admin.min.js
vendored
File diff suppressed because one or more lines are too long
|
@ -3826,6 +3826,7 @@ NewHtmlEditorWrapper.prototype.init = function ()
|
|||
self.editor.setKeystroke(window.CKEDITOR.CTRL + 65/* A */, 'selectAll');
|
||||
|
||||
self.fOnReady();
|
||||
self.__resizable = true;
|
||||
self.resize();
|
||||
});
|
||||
}
|
||||
|
@ -3850,7 +3851,7 @@ NewHtmlEditorWrapper.prototype.blur = function ()
|
|||
|
||||
NewHtmlEditorWrapper.prototype.resize = function ()
|
||||
{
|
||||
if (this.editor)
|
||||
if (this.editor && this.__resizable)
|
||||
{
|
||||
this.editor.resize(this.$element.width(), this.$element.innerHeight());
|
||||
}
|
||||
|
@ -7383,16 +7384,18 @@ IdentityModel.prototype.formattedNameForEmail = function ()
|
|||
* @param {string} sGuID
|
||||
* @param {string} sID
|
||||
* @param {string} sUserID
|
||||
* @param {string} sEmail
|
||||
* @param {boolean} bIsPrivate
|
||||
* @param {string} sArmor
|
||||
* @constructor
|
||||
*/
|
||||
function OpenPgpKeyModel(iIndex, sGuID, sID, sUserID, bIsPrivate, sArmor)
|
||||
function OpenPgpKeyModel(iIndex, sGuID, sID, sUserID, sEmail, bIsPrivate, sArmor)
|
||||
{
|
||||
this.index = iIndex;
|
||||
this.id = sID;
|
||||
this.guid = sGuID;
|
||||
this.user = sUserID;
|
||||
this.email = sEmail;
|
||||
this.armor = sArmor;
|
||||
this.isPrivate = !!bIsPrivate;
|
||||
|
||||
|
@ -7403,6 +7406,7 @@ OpenPgpKeyModel.prototype.index = 0;
|
|||
OpenPgpKeyModel.prototype.id = '';
|
||||
OpenPgpKeyModel.prototype.guid = '';
|
||||
OpenPgpKeyModel.prototype.user = '';
|
||||
OpenPgpKeyModel.prototype.email = '';
|
||||
OpenPgpKeyModel.prototype.armor = '';
|
||||
OpenPgpKeyModel.prototype.isPrivate = false;
|
||||
|
||||
|
@ -8079,9 +8083,12 @@ PopupsComposeViewModel.prototype.openOpenPgpPopup = function ()
|
|||
{
|
||||
if (this.allowOpenPGP() && this.oEditor && !this.oEditor.isHtml())
|
||||
{
|
||||
var self = this;
|
||||
kn.showScreenPopup(PopupsComposeOpenPgpViewModel, [
|
||||
function () {
|
||||
|
||||
function (sResult) {
|
||||
self.editor(function (oEditor) {
|
||||
oEditor.setPlain(sResult);
|
||||
});
|
||||
},
|
||||
this.oEditor.getData(),
|
||||
this.currentIdentityResultEmail(),
|
||||
|
@ -10274,13 +10281,168 @@ function PopupsComposeOpenPgpViewModel()
|
|||
this.password = ko.observable('');
|
||||
this.password.focus = ko.observable(true);
|
||||
|
||||
this.from = ko.observable('');
|
||||
this.to = ko.observableArray([]);
|
||||
this.text = ko.observable('');
|
||||
|
||||
this.resultCallback = null;
|
||||
|
||||
this.submitRequest = ko.observable(false);
|
||||
|
||||
// commands
|
||||
this.doCommand = Utils.createCommand(this, function () {
|
||||
|
||||
this.cancelCommand();
|
||||
var
|
||||
self = this,
|
||||
bResult = true,
|
||||
aOpenpgpkeysPublic = RL.data().openpgpkeysPublic(),
|
||||
oKey = null,
|
||||
oPrivateKey = null,
|
||||
aPublicKeys = [],
|
||||
fFindPublicKey = function (sEmail) {
|
||||
|
||||
var
|
||||
oResult = null,
|
||||
oKey = _.find(aOpenpgpkeysPublic, function (oItem) {
|
||||
return oItem && sEmail === oItem.email;
|
||||
})
|
||||
;
|
||||
|
||||
if (oKey)
|
||||
{
|
||||
try
|
||||
{
|
||||
oResult = window.openpgp.key.readArmored(oKey.armor);
|
||||
if (oResult && !oResult.err && oResult.keys && oResult.keys[0])
|
||||
{
|
||||
oResult = oResult.keys[0];
|
||||
}
|
||||
else
|
||||
{
|
||||
oResult = null;
|
||||
}
|
||||
}
|
||||
catch (e)
|
||||
{
|
||||
oResult = null;
|
||||
}
|
||||
}
|
||||
|
||||
return oResult;
|
||||
}
|
||||
;
|
||||
|
||||
this.submitRequest(true);
|
||||
|
||||
if (bResult && this.sign() && '' === this.from())
|
||||
{
|
||||
this.notification('Please specify From email address');
|
||||
bResult = false;
|
||||
}
|
||||
|
||||
if (bResult && this.sign())
|
||||
{
|
||||
oKey = _.find(RL.data().openpgpkeysPrivate(), function (oItem) {
|
||||
return oItem && self.from() === oItem.email;
|
||||
});
|
||||
|
||||
if (oKey)
|
||||
{
|
||||
try
|
||||
{
|
||||
oPrivateKey = window.openpgp.key.readArmored(oKey.armor);
|
||||
if (oPrivateKey && !oPrivateKey.err && oPrivateKey.keys && oPrivateKey.keys[0])
|
||||
{
|
||||
oPrivateKey = oPrivateKey.keys[0];
|
||||
oPrivateKey.decrypt(this.password());
|
||||
}
|
||||
else
|
||||
{
|
||||
oPrivateKey = null;
|
||||
}
|
||||
}
|
||||
catch (e)
|
||||
{
|
||||
oPrivateKey = null;
|
||||
}
|
||||
}
|
||||
|
||||
if (!oPrivateKey)
|
||||
{
|
||||
this.notification('No private key found for "' + this.from() + '" email!');
|
||||
bResult = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (bResult && this.encrypt() && 0 === this.to().length)
|
||||
{
|
||||
this.notification('Please specify at least one recipient');
|
||||
bResult = false;
|
||||
}
|
||||
|
||||
if (bResult && this.encrypt())
|
||||
{
|
||||
aPublicKeys = _.compact(_.map(this.to(), function (sEmail) {
|
||||
var oKey = fFindPublicKey(sEmail);
|
||||
if (!oKey && bResult)
|
||||
{
|
||||
self.notification('No public key found for "' + sEmail + '" email!');
|
||||
bResult = false;
|
||||
}
|
||||
|
||||
return oKey;
|
||||
|
||||
}));
|
||||
|
||||
if (0 === aPublicKeys.length || this.to().length !== aPublicKeys.length)
|
||||
{
|
||||
bResult = false;
|
||||
}
|
||||
}
|
||||
|
||||
_.delay(function () {
|
||||
|
||||
if (self.resultCallback && bResult)
|
||||
{
|
||||
try {
|
||||
|
||||
if (oPrivateKey && 0 === aPublicKeys.length)
|
||||
{
|
||||
self.resultCallback(
|
||||
window.openpgp.signClearMessage([oPrivateKey], self.text())
|
||||
);
|
||||
}
|
||||
else if (oPrivateKey && 0 < aPublicKeys.length)
|
||||
{
|
||||
self.resultCallback(
|
||||
window.openpgp.signAndEncryptMessage(aPublicKeys, oPrivateKey, self.text())
|
||||
);
|
||||
}
|
||||
else if (!oPrivateKey && 0 < aPublicKeys.length)
|
||||
{
|
||||
self.resultCallback(
|
||||
window.openpgp.encryptMessage(aPublicKeys, self.text())
|
||||
);
|
||||
}
|
||||
}
|
||||
catch (e)
|
||||
{
|
||||
self.notification('OpenPGP error: ' + e);
|
||||
bResult = false;
|
||||
}
|
||||
}
|
||||
|
||||
if (bResult)
|
||||
{
|
||||
self.cancelCommand();
|
||||
}
|
||||
|
||||
self.submitRequest(false);
|
||||
|
||||
}, 10);
|
||||
|
||||
}, function () {
|
||||
return '' === this.notification();
|
||||
return !this.submitRequest() && (this.sign() || this.encrypt());
|
||||
});
|
||||
|
||||
Knoin.constructorEnd(this);
|
||||
|
@ -10294,6 +10456,14 @@ PopupsComposeOpenPgpViewModel.prototype.clearPopup = function ()
|
|||
|
||||
this.password('');
|
||||
this.password.focus(false);
|
||||
|
||||
this.from('');
|
||||
this.to([]);
|
||||
this.text('');
|
||||
|
||||
this.submitRequest(false);
|
||||
|
||||
this.resultCallback = null;
|
||||
};
|
||||
|
||||
PopupsComposeOpenPgpViewModel.prototype.onHide = function ()
|
||||
|
@ -10311,20 +10481,11 @@ PopupsComposeOpenPgpViewModel.prototype.onShow = function (fCallback, sText, sFr
|
|||
aRec = []
|
||||
;
|
||||
|
||||
if ('' === sTo + sCc + sBcc)
|
||||
{
|
||||
this.notification('Please specify at least one recipient');
|
||||
return false;
|
||||
}
|
||||
this.resultCallback = fCallback;
|
||||
|
||||
oEmail.clear();
|
||||
oEmail.mailsoParse(sFromEmail);
|
||||
if ('' === oEmail.email)
|
||||
{
|
||||
this.notification('Please specify From email address');
|
||||
return false;
|
||||
}
|
||||
else
|
||||
if ('' !== oEmail.email)
|
||||
{
|
||||
sResultFromEmail = oEmail.email;
|
||||
}
|
||||
|
@ -10351,24 +10512,9 @@ PopupsComposeOpenPgpViewModel.prototype.onShow = function (fCallback, sText, sFr
|
|||
return '' === oEmail.email ? false : oEmail.email;
|
||||
}));
|
||||
|
||||
if (0 === aRec.length)
|
||||
{
|
||||
this.notification('Please specify at least one recipient');
|
||||
return false;
|
||||
}
|
||||
|
||||
window.console.log(sResultFromEmail);
|
||||
window.console.log(aRec);
|
||||
|
||||
// TODO
|
||||
};
|
||||
|
||||
PopupsComposeOpenPgpViewModel.prototype.onFocus = function ()
|
||||
{
|
||||
if (this.sign())
|
||||
{
|
||||
this.password.focus(true);
|
||||
}
|
||||
this.from(sResultFromEmail);
|
||||
this.to(aRec);
|
||||
this.text(sText);
|
||||
};
|
||||
|
||||
/**
|
||||
|
@ -12918,18 +13064,8 @@ Utils.addSettingsViewModel(SettingsSocialScreen, 'SettingsSocial', 'SETTINGS_LAB
|
|||
function SettingsOpenPGP()
|
||||
{
|
||||
this.openpgpkeys = RL.data().openpgpkeys;
|
||||
|
||||
this.openpgpkeysPublic = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && !oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
|
||||
this.openpgpkeysPrivate = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
this.openpgpkeysPublic = RL.data().openpgpkeysPublic;
|
||||
this.openpgpkeysPrivate = RL.data().openpgpkeysPrivate;
|
||||
|
||||
this.openPgpKeyForDeletion = ko.observable(null).extend({'falseTimeout': 3000}).extend({'toggleSubscribe': [this,
|
||||
function (oPrev) {
|
||||
|
@ -13664,7 +13800,6 @@ function WebMailDataStorage()
|
|||
return bLoading || bCreating || bDeleting || bRenaming;
|
||||
}, this);
|
||||
|
||||
|
||||
this.foldersInboxUnreadCount = ko.observable(0);
|
||||
|
||||
this.currentFolder = ko.observable(null).extend({'toggleSubscribe': [null,
|
||||
|
@ -13914,6 +14049,18 @@ function WebMailDataStorage()
|
|||
this.openpgpkeys = ko.observableArray([]);
|
||||
this.openpgpKeyring = null;
|
||||
|
||||
this.openpgpkeysPublic = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && !oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
|
||||
this.openpgpkeysPrivate = ko.computed(function () {
|
||||
return _.filter(this.openpgpkeys(), function (oItem) {
|
||||
return !!(oItem && oItem.isPrivate);
|
||||
});
|
||||
}, this);
|
||||
|
||||
// google
|
||||
this.googleActions = ko.observable(false);
|
||||
this.googleLoggined = ko.observable(false);
|
||||
|
@ -14282,7 +14429,6 @@ WebMailDataStorage.prototype.getNextFolderNames = function (bBoot)
|
|||
};
|
||||
|
||||
/**
|
||||
* @param {Function} fCallback
|
||||
* @param {string} sFromFolderFullNameRaw
|
||||
* @param {Array} aUidForRemove
|
||||
* @param {string=} sToFolderFullNameRaw = ''
|
||||
|
@ -17113,6 +17259,7 @@ RainLoopApp.prototype.reloadOpenPgpKeys = function ()
|
|||
{
|
||||
var
|
||||
aKeys = [],
|
||||
oEmail = new EmailModel(),
|
||||
oOpenpgpKeyring = RL.data().openpgpKeyring,
|
||||
oOpenpgpKeys = oOpenpgpKeyring ? oOpenpgpKeyring.keys : []
|
||||
;
|
||||
|
@ -17121,20 +17268,28 @@ RainLoopApp.prototype.reloadOpenPgpKeys = function ()
|
|||
if (oItem && oItem.primaryKey)
|
||||
{
|
||||
var
|
||||
|
||||
oPrimaryUser = oItem.getPrimaryUser(),
|
||||
sUser = (oPrimaryUser && oPrimaryUser.user) ? oPrimaryUser.user.userId.userid
|
||||
: (oItem.users && oItem.users[0] ? oItem.users[0].userId.userid : '')
|
||||
;
|
||||
|
||||
oEmail.clear();
|
||||
oEmail.mailsoParse(sUser);
|
||||
|
||||
if (oEmail.validate())
|
||||
{
|
||||
aKeys.push(new OpenPgpKeyModel(
|
||||
iIndex,
|
||||
oItem.primaryKey.getFingerprint(),
|
||||
oItem.primaryKey.getKeyId().toHex().toLowerCase(),
|
||||
sUser,
|
||||
oEmail.email,
|
||||
oItem.isPrivate(),
|
||||
oItem.armor())
|
||||
);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
RL.data().openpgpkeys(aKeys);
|
||||
|
|
16
rainloop/v/0.0.0/static/js/app.min.js
vendored
16
rainloop/v/0.0.0/static/js/app.min.js
vendored
File diff suppressed because one or more lines are too long
Loading…
Reference in a new issue