From b5fbefc5ec37199525fef7910f706ebbc0b29070 Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 13 Nov 2021 10:13:22 +0100 Subject: [PATCH 1/8] create FR strings for certification checklist --- www/i18n/locale-fr-FR.json | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/www/i18n/locale-fr-FR.json b/www/i18n/locale-fr-FR.json index 6e408628..20b18224 100644 --- a/www/i18n/locale-fr-FR.json +++ b/www/i18n/locale-fr-FR.json @@ -564,6 +564,20 @@ "SELECT_WALLET_MODAL": { "TITLE": "Sélection du portefeuille" }, + "CERTIFICATION_MODAL": { + "CHECKLIST_TITLE": "Vérifications avant certification", + "INFOS": "La sécurité de la monnaie Ğ1 repose sur chaque membre. Avant de certifier l'identité de cette personne, vous devez avoir fait quelques vérifications à son propos. Veuillez répondre aux questions suivantes :", + "BTN_ALL_CHECK": "Certifier", + "CHECKLIST_CONDITIONS_NOT_MET": "La certification n'a pas été envoyée. Les vérifications semblent insuffisantes. Veuillez vérifier de nouveau chaque point auprès de la personne à certifier.", + "QUESTIONS": { + "WELL_KNOWN": "Connaissez-vous bien la personne que vous certifiez, et l'avez-vous rencontrée physiquement ?", + "REVOCATION": "A-t-elle téléchargé son document de révocation et sait-elle où le retrouver ?", + "CONTACT": "Pouvez-vous la contacter par plusieurs moyens ?", + "DOUBLE_IDENTITY": "La personne possède-t-elle une autre identité membre active ?", + "MASTER_ACCOUNT": "Maîtrise-t-elle son compte, et a-t-elle déjà effectué des virements depuis son compte ?", + "LICENSE": "A-t-elle compris la licence, et accepte-t-elle de s'y conformer pour la certification d'autres membres ?" + } + }, "WALLET_LIST": { "TITLE": "Mes portefeuilles", "BTN_NEW": "Ajouter un portefeuille", From 8be3dab85ff56c81ef1175758e6800032f7a32e3 Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 13 Nov 2021 10:18:39 +0100 Subject: [PATCH 2/8] create modal for certification checklist --- .../wot/item_checklist_certification.html | 17 ++++ .../wot/modal_certification_checklist.html | 80 +++++++++++++++++++ 2 files changed, 97 insertions(+) create mode 100644 www/templates/wot/item_checklist_certification.html create mode 100644 www/templates/wot/modal_certification_checklist.html diff --git a/www/templates/wot/item_checklist_certification.html b/www/templates/wot/item_checklist_certification.html new file mode 100644 index 00000000..a4e5b983 --- /dev/null +++ b/www/templates/wot/item_checklist_certification.html @@ -0,0 +1,17 @@ +
+
+
+
+
+ COMMON.BTN_YES + COMMON.BTN_NO +
+
+
+ +
\ No newline at end of file diff --git a/www/templates/wot/modal_certification_checklist.html b/www/templates/wot/modal_certification_checklist.html new file mode 100644 index 00000000..5ba91990 --- /dev/null +++ b/www/templates/wot/modal_certification_checklist.html @@ -0,0 +1,80 @@ + + + + + + + + + +

ACCOUNT.CERTIFICATION_MODAL.CHECKLIST_TITLE

+ + + + + + + +
+ + + + + +
{{ identity.uid }} - {{ identity.pubkey }}
+ +
ACCOUNT.CERTIFICATION_MODAL.INFOS
+ +
+
+
+
+ + +
+ + + + + + + +
+
+
\ No newline at end of file From e15698eda7b4b5a6a3ac38012861e9b940a57051 Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 13 Nov 2021 10:29:27 +0100 Subject: [PATCH 3/8] create modal controller for certification checklist --- www/js/controllers/wot-controllers.js | 73 +++++++++++++++++++++++++++ www/js/services/modal-services.js | 5 ++ 2 files changed, 78 insertions(+) diff --git a/www/js/controllers/wot-controllers.js b/www/js/controllers/wot-controllers.js index 4f109795..b2f04f9d 100644 --- a/www/js/controllers/wot-controllers.js +++ b/www/js/controllers/wot-controllers.js @@ -157,6 +157,8 @@ angular.module('cesium.wot.controllers', ['cesium.services']) .controller('WotCertificationsViewCtrl', WotCertificationsViewController) + .controller('WotCertificationChecklistCtrl', WotCertificationChecklistController) + .controller('WotSelectPubkeyIdentityModalCtrl', WotSelectPubkeyIdentityModalController) ; @@ -1429,6 +1431,77 @@ function WotCertificationsViewController($scope, $rootScope, $controller, csSett }; } +/** + * Certification checklist controller + * @param $controller + */ + function WotCertificationChecklistController($scope, $controller, parameters){ + + // allow to display license + $controller('CurrencyViewCtrl', {$scope: $scope}); + + let answers_are_right = parameters.answers_are_right; + $scope.identity = parameters.identity; + + $scope.prepare_cert_checklist = function() { + const original_cert_checklist = [ + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.WELL_KNOWN', + expected_answer: true, + answer: false + }, + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.REVOCATION', + expected_answer: true, + answer: false + }, + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.CONTACT', + expected_answer: true, + answer: false + }, + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.DOUBLE_IDENTITY', + expected_answer: false, + answer: false + }, + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.MASTER_ACCOUNT', + expected_answer: true, + answer: false + }, + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.LICENSE', + expected_answer: true, + answer: false + }, + ]; + + // Fisher-Yates shuffle + function shuffle(array) { + for (let i = array.length - 1; i > 0; i--) { + let j = Math.floor(Math.random() * (i + 1)); // random index from 0 to i + let t = array[i]; array[i] = array[j]; array[j] = t + } + return array; + } + + return shuffle(original_cert_checklist); + } + $scope.cert_checklist = $scope.prepare_cert_checklist(); + + $scope.verifyAnswers = function() { + $scope.cert_checklist.map( question => { + if (question.answer !== question.expected_answer) { + // TODO message should be changed. + answers_are_right.reject(); + } + }); + answers_are_right.resolve(true); + + $scope.closeModal(); + } +} /** * Select identities from a pubkey (useful when many self on the same pubkey) diff --git a/www/js/services/modal-services.js b/www/js/services/modal-services.js index 3ff97d62..4cd65471 100644 --- a/www/js/services/modal-services.js +++ b/www/js/services/modal-services.js @@ -232,6 +232,10 @@ angular.module('cesium.modal.services', ['cesium.utils.services']) parameters); } + function showCertificationCheckList(parameters) { + return ModalUtils.show('templates/wot/modal_certification_checklist.html','WotCertificationChecklistCtrl', parameters); + } + function showSelectPubkeyIdentity(parameters) { return ModalUtils.show('templates/wot/modal_select_pubkey_identity.html', 'WotSelectPubkeyIdentityModalCtrl', parameters); @@ -294,6 +298,7 @@ angular.module('cesium.modal.services', ['cesium.utils.services']) showHelp: showHelp, showAccountSecurity: showAccountSecurity, showLicense: showLicense, + showCertificationCheckList: showCertificationCheckList, showSelectPubkeyIdentity: showSelectPubkeyIdentity, showSelectWallet: showSelectWallet, showPassword: showPassword From a66502338a3a09eebaac946f07e6adfe8b9b1495 Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 13 Nov 2021 10:37:52 +0100 Subject: [PATCH 4/8] display certification checklist modal --- www/js/controllers/wot-controllers.js | 121 ++++++++++++++------------ 1 file changed, 64 insertions(+), 57 deletions(-) diff --git a/www/js/controllers/wot-controllers.js b/www/js/controllers/wot-controllers.js index b2f04f9d..69495697 100644 --- a/www/js/controllers/wot-controllers.js +++ b/www/js/controllers/wot-controllers.js @@ -785,35 +785,39 @@ function WotIdentityAbstractController($scope, $rootScope, $state, $translate, $ return; } - UIUtils.alert.confirm('CONFIRM.CERTIFY_RULES', 'CONFIRM.POPUP_SECURITY_WARNING_TITLE', { - cssClass: 'warning', - okText: 'WOT.BTN_YES_CERTIFY', - okType: 'button-assertive' + // Certification checklist before confirmation + let answers_are_right = $q.defer(); + answers_are_right.promise.then(function(){ + UIUtils.loading.show(); + wallet.certify($scope.formData.uid, + $scope.formData.pubkey, + $scope.formData.blockUid || ($scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.timestamp), + $scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.sig, + $scope.formData.isMember, + $scope.formData.wasMember) + .then(function(cert) { + UIUtils.loading.hide(); + if (cert) { + $scope.prepareNewCert(wallet, cert); + $scope.alreadyCertified = true; + UIUtils.toast.show('INFO.CERTIFICATION_DONE'); + $scope.formData.received_cert_pending.unshift(cert); + $scope.formData.requirements.pendingCertificationCount++; + $scope.doMotion(); + } + }) + .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); }) - .then(function(confirm){ - if (!confirm) { - return; - } - UIUtils.loading.show(); - wallet.certify($scope.formData.uid, - $scope.formData.pubkey, - $scope.formData.blockUid || ($scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.timestamp), - $scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.sig, - $scope.formData.isMember, - $scope.formData.wasMember) - .then(function(cert) { - UIUtils.loading.hide(); - if (cert) { - $scope.prepareNewCert(wallet, cert); - $scope.alreadyCertified = true; - UIUtils.toast.show('INFO.CERTIFICATION_DONE'); - $scope.formData.received_cert_pending.unshift(cert); - $scope.formData.requirements.pendingCertificationCount++; - $scope.doMotion(); - } - }) - .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); - }); + .catch( + UIUtils.onError('ACCOUNT.CERTIFICATION_MODAL.CHECKLIST_CONDITIONS_NOT_MET') + ); + + // display certification checklist modal + return Modals.showCertificationCheckList({ + answers_are_right: answers_are_right, + identity: $scope.formData, + }); + }) .catch(function(err) { if (err === 'CANCELLED') return; @@ -891,36 +895,39 @@ function WotIdentityAbstractController($scope, $rootScope, $state, $translate, $ return; } - // Ask confirmation - $translate('CONFIRM.CERTIFY_RULES_TITLE_UID', {uid: identity.uid}) - .then(function (confirmTitle) { - return UIUtils.alert.confirm('CONFIRM.CERTIFY_RULES', confirmTitle); + // Certification checklist before confirmation + let answers_are_right = $q.defer(); + answers_are_right.promise.then(function(){ + UIUtils.loading.show(); + // Send certification + wallet.certify(identity.uid, + identity.pubkey, + identity.blockUid || (identity.requirements && identity.requirements.meta && identity.requirements.meta.timestamp), + identity.requirements && identity.requirements.meta && identity.requirements.meta.sig, + identity.isMember, + identity.wasMember) + .then(function (cert) { + UIUtils.loading.hide(); + if (!cert) return; + return csWot.extendAll([cert], 'pubkey') + .then(function () { + UIUtils.toast.show('INFO.CERTIFICATION_DONE'); + $scope.formData.given_cert_pending.unshift(cert); + $scope.doMotion(); + }); + }) + .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); }) - .then(function (confirm) { - if (!confirm) { - return; - } - UIUtils.loading.show(); - - // Send certification - wallet.certify(identity.uid, - identity.pubkey, - identity.blockUid || (identity.requirements && identity.requirements.meta && identity.requirements.meta.timestamp), - identity.requirements && identity.requirements.meta && identity.requirements.meta.sig, - identity.isMember, - identity.wasMember) - .then(function (cert) { - UIUtils.loading.hide(); - if (!cert) return; - return csWot.extendAll([cert], 'pubkey') - .then(function () { - UIUtils.toast.show('INFO.CERTIFICATION_DONE'); - $scope.formData.given_cert_pending.unshift(cert); - $scope.doMotion(); - }); - }) - .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); - }); + .catch( + UIUtils.onError('ACCOUNT.CERTIFICATION_MODAL.CHECKLIST_CONDITIONS_NOT_MET') + ); + + // Display cert checklist modal + return Modals.showCertificationCheckList({ + answers_are_right: answers_are_right, + identity: identity, + }); + }) .catch(function (err) { if (err === 'CANCELLED') return; From d8c6bab8a256daa57e4a42ccbe17e29c94c53ace Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 13 Nov 2021 10:45:36 +0100 Subject: [PATCH 5/8] remove now useless FR strings --- www/i18n/locale-fr-FR.json | 2 -- 1 file changed, 2 deletions(-) diff --git a/www/i18n/locale-fr-FR.json b/www/i18n/locale-fr-FR.json index 20b18224..c7dd052d 100644 --- a/www/i18n/locale-fr-FR.json +++ b/www/i18n/locale-fr-FR.json @@ -822,8 +822,6 @@ "POPUP_TITLE": "Confirmation", "POPUP_WARNING_TITLE": "Avertissement", "POPUP_SECURITY_WARNING_TITLE": " Avertissement de sécurité", - "CERTIFY_RULES_TITLE_UID": "Certifier {{uid}}", - "CERTIFY_RULES": "Ne PAS certifier un compte si vous pensez que :

  • 1.) il ne correspond pas à une personne physique et vivante.
  • 2.) son propriétaire possède un autre compte déjà certifié.
  • 3.) son propriétaire viole (volontairement ou non) la règle 1 ou 2 (par exemple en certifiant des comptes factices ou en double).

Êtes-vous sûr de vouloir néanmoins certifier cette identité ?", "FULLSCREEN": "Afficher l'application en plein écran ?", "EXIT_APP": "Fermer l'application ?", "TRANSFER": "Récapitulatif du virement :

  • - De : {{from}}
  • - A : {{to}}
  • - Montant : {{amount}} {{unit}}
  • - Commentaire : {{comment}}

Êtes-vous sûr de vouloir effectuer ce virement ?", From c962552311444368891439e74972896a0d7a423a Mon Sep 17 00:00:00 2001 From: matograine Date: Sun, 14 Nov 2021 09:28:31 +0100 Subject: [PATCH 6/8] add a reminder for certification parameters, delays mostly. --- www/i18n/locale-fr-FR.json | 4 +- www/js/controllers/wot-controllers.js | 104 ++++++++++++++++---------- 2 files changed, 67 insertions(+), 41 deletions(-) diff --git a/www/i18n/locale-fr-FR.json b/www/i18n/locale-fr-FR.json index c7dd052d..63c80dcf 100644 --- a/www/i18n/locale-fr-FR.json +++ b/www/i18n/locale-fr-FR.json @@ -576,7 +576,9 @@ "DOUBLE_IDENTITY": "La personne possède-t-elle une autre identité membre active ?", "MASTER_ACCOUNT": "Maîtrise-t-elle son compte, et a-t-elle déjà effectué des virements depuis son compte ?", "LICENSE": "A-t-elle compris la licence, et accepte-t-elle de s'y conformer pour la certification d'autres membres ?" - } + }, + "REMINDER_TITLE": "Rappel", + "SHORT_LICENSE_REMINDER": "

Vous pouvez rappeler à la personne certifiée les paramètres des certifications :

- Chaque membre peut avoir émis 100 certifications valides au maximum.

- Les certifications sont enregistrées à un intervalle de 5 jours.

- Une nouvelle identité membre doit réunir au minimum 5 certifications en moins de deux mois.

- Un membre doit renouveler son adhésion chaque année.

- Les certifications sont valides durant deux ans.

" }, "WALLET_LIST": { "TITLE": "Mes portefeuilles", diff --git a/www/js/controllers/wot-controllers.js b/www/js/controllers/wot-controllers.js index 69495697..309fe097 100644 --- a/www/js/controllers/wot-controllers.js +++ b/www/js/controllers/wot-controllers.js @@ -788,25 +788,37 @@ function WotIdentityAbstractController($scope, $rootScope, $state, $translate, $ // Certification checklist before confirmation let answers_are_right = $q.defer(); answers_are_right.promise.then(function(){ - UIUtils.loading.show(); - wallet.certify($scope.formData.uid, - $scope.formData.pubkey, - $scope.formData.blockUid || ($scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.timestamp), - $scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.sig, - $scope.formData.isMember, - $scope.formData.wasMember) - .then(function(cert) { - UIUtils.loading.hide(); - if (cert) { - $scope.prepareNewCert(wallet, cert); - $scope.alreadyCertified = true; - UIUtils.toast.show('INFO.CERTIFICATION_DONE'); - $scope.formData.received_cert_pending.unshift(cert); - $scope.formData.requirements.pendingCertificationCount++; - $scope.doMotion(); - } - }) - .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); + UIUtils.alert.confirm( + 'ACCOUNT.CERTIFICATION_MODAL.SHORT_LICENSE_REMINDER', + 'ACCOUNT.CERTIFICATION_MODAL.REMINDER_TITLE', + { + cssClass: 'positive', + okText: 'COMMON.BTN_OK', + okType: 'button-positive' + } + ) + .then(function(confirm){ + if (! confirm) {return} + UIUtils.loading.show(); + wallet.certify($scope.formData.uid, + $scope.formData.pubkey, + $scope.formData.blockUid || ($scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.timestamp), + $scope.formData.requirements && $scope.formData.requirements.meta && $scope.formData.requirements.meta.sig, + $scope.formData.isMember, + $scope.formData.wasMember) + .then(function(cert) { + UIUtils.loading.hide(); + if (cert) { + $scope.prepareNewCert(wallet, cert); + $scope.alreadyCertified = true; + UIUtils.toast.show('INFO.CERTIFICATION_DONE'); + $scope.formData.received_cert_pending.unshift(cert); + $scope.formData.requirements.pendingCertificationCount++; + $scope.doMotion(); + } + }) + .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); + }) }) .catch( UIUtils.onError('ACCOUNT.CERTIFICATION_MODAL.CHECKLIST_CONDITIONS_NOT_MET') @@ -898,29 +910,41 @@ function WotIdentityAbstractController($scope, $rootScope, $state, $translate, $ // Certification checklist before confirmation let answers_are_right = $q.defer(); answers_are_right.promise.then(function(){ - UIUtils.loading.show(); - // Send certification - wallet.certify(identity.uid, - identity.pubkey, - identity.blockUid || (identity.requirements && identity.requirements.meta && identity.requirements.meta.timestamp), - identity.requirements && identity.requirements.meta && identity.requirements.meta.sig, - identity.isMember, - identity.wasMember) - .then(function (cert) { - UIUtils.loading.hide(); - if (!cert) return; - return csWot.extendAll([cert], 'pubkey') - .then(function () { - UIUtils.toast.show('INFO.CERTIFICATION_DONE'); - $scope.formData.given_cert_pending.unshift(cert); - $scope.doMotion(); - }); - }) + UIUtils.alert.confirm( + 'ACCOUNT.CERTIFICATION_MODAL.SHORT_LICENSE_REMINDER', + 'ACCOUNT.CERTIFICATION_MODAL.REMINDER_TITLE', + { + cssClass: 'positive', + okText: 'COMMON.BTN_OK', + okType: 'button-positive' + } + ) + .then(function(confirm){ + if (! confirm) {return} + UIUtils.loading.show(); + // Send certification + wallet.certify(identity.uid, + identity.pubkey, + identity.blockUid || (identity.requirements && identity.requirements.meta && identity.requirements.meta.timestamp), + identity.requirements && identity.requirements.meta && identity.requirements.meta.sig, + identity.isMember, + identity.wasMember) + .then(function (cert) { + UIUtils.loading.hide(); + if (!cert) return; + return csWot.extendAll([cert], 'pubkey') + .then(function () { + UIUtils.toast.show('INFO.CERTIFICATION_DONE'); + $scope.formData.given_cert_pending.unshift(cert); + $scope.doMotion(); + }); + }) .catch(UIUtils.onError('ERROR.SEND_CERTIFICATION_FAILED')); }) - .catch( - UIUtils.onError('ACCOUNT.CERTIFICATION_MODAL.CHECKLIST_CONDITIONS_NOT_MET') - ); + }) + .catch( + UIUtils.onError('ACCOUNT.CERTIFICATION_MODAL.CHECKLIST_CONDITIONS_NOT_MET') + ); // Display cert checklist modal return Modals.showCertificationCheckList({ From bf2c69500eb101805b96a840b8ed6a73ccaa4d55 Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 20 Nov 2021 12:48:31 +0100 Subject: [PATCH 7/8] Questions list modification: - add two questions - rework existing questions - sort question list creation for lisibility --- www/i18n/locale-fr-FR.json | 10 ++++++---- www/js/controllers/wot-controllers.js | 19 +++++++++++++++---- 2 files changed, 21 insertions(+), 8 deletions(-) diff --git a/www/i18n/locale-fr-FR.json b/www/i18n/locale-fr-FR.json index 63c80dcf..84c2f92d 100644 --- a/www/i18n/locale-fr-FR.json +++ b/www/i18n/locale-fr-FR.json @@ -570,12 +570,14 @@ "BTN_ALL_CHECK": "Certifier", "CHECKLIST_CONDITIONS_NOT_MET": "La certification n'a pas été envoyée. Les vérifications semblent insuffisantes. Veuillez vérifier de nouveau chaque point auprès de la personne à certifier.", "QUESTIONS": { - "WELL_KNOWN": "Connaissez-vous bien la personne que vous certifiez, et l'avez-vous rencontrée physiquement ?", + "WELL_KNOWN": "Connaissez-vous bien la personne que vous certifiez, et connaissez-vous des gens qui la connaissent bien également ?", "REVOCATION": "A-t-elle téléchargé son document de révocation et sait-elle où le retrouver ?", - "CONTACT": "Pouvez-vous la contacter par plusieurs moyens ?", + "CONTACT": "Avez-vous contacté cette personne par plusieurs moyens et vous a-t-elle répondu ?", "DOUBLE_IDENTITY": "La personne possède-t-elle une autre identité membre active ?", - "MASTER_ACCOUNT": "Maîtrise-t-elle son compte, et a-t-elle déjà effectué des virements depuis son compte ?", - "LICENSE": "A-t-elle compris la licence, et accepte-t-elle de s'y conformer pour la certification d'autres membres ?" + "MASTER_ACCOUNT": "Maîtrise-t-elle son compte, et a-t-elle déjà effectué au moins un virement depuis son compte ?", + "LICENSE": "A-t-elle compris la licence, et accepte-t-elle de s'y conformer pour la certification d'autres membres ?", + "CREDENTIALS": "L’identifiant et le mot de passe de son compte sont-ils longs et complexes (phrases de passe) ? A-t-elle compris que l’identifiant doit également rester secret ? Est-elle certaine de s’en souvenir ou de pouvoir les retrouver ?", + "PUBLIC_KEY_DIFFERENT": "La clef publique indiquée ici est-elle différente de celle que vous a communiqué cette personne ?" }, "REMINDER_TITLE": "Rappel", "SHORT_LICENSE_REMINDER": "

Vous pouvez rappeler à la personne certifiée les paramètres des certifications :

- Chaque membre peut avoir émis 100 certifications valides au maximum.

- Les certifications sont enregistrées à un intervalle de 5 jours.

- Une nouvelle identité membre doit réunir au minimum 5 certifications en moins de deux mois.

- Un membre doit renouveler son adhésion chaque année.

- Les certifications sont valides durant deux ans.

" diff --git a/www/js/controllers/wot-controllers.js b/www/js/controllers/wot-controllers.js index 309fe097..e3207623 100644 --- a/www/js/controllers/wot-controllers.js +++ b/www/js/controllers/wot-controllers.js @@ -1492,20 +1492,31 @@ function WotCertificationsViewController($scope, $rootScope, $controller, csSett answer: false }, { - question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.DOUBLE_IDENTITY', - expected_answer: false, + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.MASTER_ACCOUNT', + expected_answer: true, answer: false }, { - question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.MASTER_ACCOUNT', + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.LICENSE', expected_answer: true, answer: false }, { - question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.LICENSE', + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.CREDENTIALS', expected_answer: true, answer: false }, + // questions with negative answers + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.DOUBLE_IDENTITY', + expected_answer: false, + answer: false + }, + { + question: 'ACCOUNT.CERTIFICATION_MODAL.QUESTIONS.PUBLIC_KEY_DIFFERENT', + expected_answer: false, + answer: false + }, ]; // Fisher-Yates shuffle From 0f79e0bb1f9ce9b142472ffb8edfd136d748ded2 Mon Sep 17 00:00:00 2001 From: matograine Date: Sat, 20 Nov 2021 12:54:14 +0100 Subject: [PATCH 8/8] select only 5 questions --- www/js/controllers/wot-controllers.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/www/js/controllers/wot-controllers.js b/www/js/controllers/wot-controllers.js index e3207623..456b7ea3 100644 --- a/www/js/controllers/wot-controllers.js +++ b/www/js/controllers/wot-controllers.js @@ -1528,7 +1528,7 @@ function WotCertificationsViewController($scope, $rootScope, $controller, csSett return array; } - return shuffle(original_cert_checklist); + return shuffle(original_cert_checklist).slice(0, 5); } $scope.cert_checklist = $scope.prepare_cert_checklist();