2018-04-23 15:18:46 +00:00
|
|
|
/* gpgme.js - Javascript integration for gpgme
|
|
|
|
* Copyright (C) 2018 Bundesamt für Sicherheit in der Informationstechnik
|
|
|
|
*
|
|
|
|
* This file is part of GPGME.
|
|
|
|
*
|
|
|
|
* GPGME is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU Lesser General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2.1 of
|
|
|
|
* the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* GPGME is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2018-10-18 03:56:27 +00:00
|
|
|
* License along with this program; if not, see <https://www.gnu.org/licenses/>.
|
2018-04-23 15:18:46 +00:00
|
|
|
* SPDX-License-Identifier: LGPL-2.1+
|
2018-06-06 11:05:53 +00:00
|
|
|
*
|
|
|
|
* Author(s):
|
|
|
|
* Maximilian Krambach <mkrambach@intevation.de>
|
2018-04-23 15:18:46 +00:00
|
|
|
*/
|
|
|
|
|
2018-07-10 12:32:26 +00:00
|
|
|
/**
|
|
|
|
* Listing of all possible error codes and messages of a {@link GPGME_Error}.
|
|
|
|
*/
|
2018-08-22 10:18:55 +00:00
|
|
|
export const err_list = {
|
2018-04-25 13:59:36 +00:00
|
|
|
// Connection
|
|
|
|
'CONN_NO_CONNECT': {
|
|
|
|
msg:'Connection with the nativeMessaging host could not be'
|
|
|
|
+ ' established.',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'CONN_EMPTY_GPG_ANSWER':{
|
|
|
|
msg: 'The nativeMessaging answer was empty.',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'CONN_TIMEOUT': {
|
|
|
|
msg: 'A connection timeout was exceeded.',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'CONN_UNEXPECTED_ANSWER': {
|
|
|
|
msg: 'The answer from gnupg was not as expected.',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'CONN_ALREADY_CONNECTED':{
|
|
|
|
msg: 'A connection was already established.',
|
|
|
|
type: 'warning'
|
|
|
|
},
|
|
|
|
// Message/Data
|
|
|
|
'MSG_INCOMPLETE': {
|
|
|
|
msg: 'The Message did not match the minimum requirements for'
|
|
|
|
+ ' the interaction.',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'MSG_EMPTY' : {
|
|
|
|
msg: 'The Message is empty.',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'MSG_WRONG_OP': {
|
|
|
|
msg: 'The operation requested could not be found',
|
2018-04-25 17:45:39 +00:00
|
|
|
type: 'error'
|
2018-04-25 13:59:36 +00:00
|
|
|
},
|
|
|
|
'MSG_NO_KEYS' : {
|
|
|
|
msg: 'There were no valid keys provided.',
|
|
|
|
type: 'warning'
|
|
|
|
},
|
|
|
|
'MSG_NOT_A_FPR': {
|
|
|
|
msg: 'The String is not an accepted fingerprint',
|
|
|
|
type: 'warning'
|
|
|
|
},
|
|
|
|
'KEY_INVALID': {
|
|
|
|
msg:'Key object is invalid',
|
|
|
|
type: 'error'
|
|
|
|
},
|
2018-05-25 17:02:18 +00:00
|
|
|
'KEY_NOKEY': {
|
|
|
|
msg:'This key does not exist in GPG',
|
|
|
|
type: 'error'
|
|
|
|
},
|
2018-05-30 15:05:54 +00:00
|
|
|
'KEY_NO_INIT': {
|
|
|
|
msg:'This property has not been retrieved yet from GPG',
|
|
|
|
type: 'error'
|
2018-06-06 09:57:41 +00:00
|
|
|
},
|
2018-08-17 14:57:41 +00:00
|
|
|
'KEY_ASYNC_ONLY': {
|
|
|
|
msg: 'This property cannot be used in synchronous calls',
|
|
|
|
type: 'error'
|
|
|
|
},
|
2018-06-13 13:22:03 +00:00
|
|
|
'KEY_NO_DEFAULT': {
|
|
|
|
msg:'A default key could not be established. Please check yout gpg ' +
|
|
|
|
'configuration',
|
|
|
|
type: 'error'
|
|
|
|
},
|
2018-06-14 10:15:51 +00:00
|
|
|
'SIG_WRONG': {
|
|
|
|
msg:'A malformed signature was created',
|
|
|
|
type: 'error'
|
|
|
|
},
|
|
|
|
'SIG_NO_SIGS': {
|
|
|
|
msg:'There were no signatures found',
|
|
|
|
type: 'error'
|
|
|
|
},
|
2018-04-25 13:59:36 +00:00
|
|
|
// generic
|
|
|
|
'PARAM_WRONG':{
|
2018-04-25 17:45:39 +00:00
|
|
|
msg: 'Invalid parameter was found',
|
2018-04-25 13:59:36 +00:00
|
|
|
type: 'error'
|
|
|
|
},
|
2018-08-22 14:32:31 +00:00
|
|
|
'DECODE_FAIL': {
|
|
|
|
msg: 'Decoding failed due to unexpected data',
|
|
|
|
type: 'error'
|
|
|
|
},
|
2018-04-25 13:59:36 +00:00
|
|
|
'PARAM_IGNORED': {
|
|
|
|
msg: 'An parameter was set that has no effect in gpgmejs',
|
|
|
|
type: 'warning'
|
|
|
|
},
|
|
|
|
'GENERIC_ERROR': {
|
|
|
|
msg: 'Unspecified error',
|
|
|
|
type: 'error'
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-04-25 08:54:24 +00:00
|
|
|
/**
|
2018-07-10 12:32:26 +00:00
|
|
|
* Checks the given error code and returns an {@link GPGME_Error} error object
|
|
|
|
* with some information about meaning and origin
|
2018-09-05 16:46:28 +00:00
|
|
|
* @param {String} code Error code as defined in {@link err_list}.
|
|
|
|
* @param {String} info Possible additional error message to pass through.
|
|
|
|
* Currently used for errors sent as answer by gnupg via a native Message port
|
2018-07-10 12:32:26 +00:00
|
|
|
* @returns {GPGME_Error}
|
2018-04-25 08:54:24 +00:00
|
|
|
*/
|
2018-08-20 13:12:01 +00:00
|
|
|
export function gpgme_error (code = 'GENERIC_ERROR', info){
|
2018-04-25 13:59:36 +00:00
|
|
|
if (err_list.hasOwnProperty(code)){
|
|
|
|
if (err_list[code].type === 'error'){
|
2018-08-20 10:12:43 +00:00
|
|
|
return new GPGME_Error(code);
|
2018-04-23 15:18:46 +00:00
|
|
|
}
|
2018-04-25 13:59:36 +00:00
|
|
|
if (err_list[code].type === 'warning'){
|
2018-06-06 11:05:53 +00:00
|
|
|
// eslint-disable-next-line no-console
|
2018-07-10 12:32:26 +00:00
|
|
|
// console.warn(code + ': ' + err_list[code].msg);
|
2018-04-23 15:18:46 +00:00
|
|
|
}
|
2018-04-25 13:59:36 +00:00
|
|
|
return null;
|
|
|
|
} else if (code === 'GNUPG_ERROR'){
|
2018-08-20 10:12:43 +00:00
|
|
|
return new GPGME_Error(code, info);
|
2018-04-25 13:59:36 +00:00
|
|
|
}
|
|
|
|
else {
|
2018-08-20 10:12:43 +00:00
|
|
|
return new GPGME_Error('GENERIC_ERROR');
|
2018-04-25 13:59:36 +00:00
|
|
|
}
|
2018-04-23 15:18:46 +00:00
|
|
|
}
|
2018-04-25 13:59:36 +00:00
|
|
|
|
2018-07-10 12:32:26 +00:00
|
|
|
/**
|
|
|
|
* An error class with additional info about the origin of the error, as string
|
2018-09-05 16:46:28 +00:00
|
|
|
* It is created by {@link gpgme_error}, and its' codes are defined in
|
|
|
|
* {@link err_list}.
|
|
|
|
*
|
2018-07-10 12:32:26 +00:00
|
|
|
* @property {String} code Short description of origin and type of the error
|
|
|
|
* @property {String} msg Additional info
|
|
|
|
* @protected
|
2018-09-05 16:46:28 +00:00
|
|
|
* @class
|
2018-07-10 12:32:26 +00:00
|
|
|
* @extends Error
|
|
|
|
*/
|
2018-04-25 13:59:36 +00:00
|
|
|
class GPGME_Error extends Error{
|
2018-08-20 13:12:01 +00:00
|
|
|
constructor (code = 'GENERIC_ERROR', msg=''){
|
2018-08-20 10:12:43 +00:00
|
|
|
|
2018-08-20 13:12:01 +00:00
|
|
|
if (code === 'GNUPG_ERROR' && typeof (msg) === 'string'){
|
2018-04-25 13:59:36 +00:00
|
|
|
super(msg);
|
|
|
|
} else if (err_list.hasOwnProperty(code)){
|
2018-06-06 09:57:41 +00:00
|
|
|
if (msg){
|
2018-06-06 11:05:53 +00:00
|
|
|
super(err_list[code].msg + '--' + msg);
|
2018-06-06 09:57:41 +00:00
|
|
|
} else {
|
|
|
|
super(err_list[code].msg);
|
|
|
|
}
|
2018-04-25 13:59:36 +00:00
|
|
|
} else {
|
|
|
|
super(err_list['GENERIC_ERROR'].msg);
|
|
|
|
}
|
2018-08-20 10:12:43 +00:00
|
|
|
this._code = code;
|
2018-04-25 13:59:36 +00:00
|
|
|
}
|
2018-07-27 18:36:21 +00:00
|
|
|
|
2018-08-20 13:12:01 +00:00
|
|
|
get code (){
|
2018-08-20 10:12:43 +00:00
|
|
|
return this._code;
|
2018-04-25 13:59:36 +00:00
|
|
|
}
|
|
|
|
}
|