oidc-lib
Version:
A library for creating OIDC Service Providers
194 lines (174 loc) • 107 kB
JavaScript
var display_render_callback;
module.exports = {
loadPersonas: loadPersonas,
initializePersonas: initializePersonas,
reloadPersonas: reloadPersonas,
getPersonas: getPersonas,
getPersona: getPersona,
getCredentialCount: getCredentialCount,
savePersonaChanges: savePersonaChanges,
updatePersona: updatePersona,
click_data_card: click_data_card,
select_card: select_card,
edit_card: edit_card,
add_card: add_card,
delete_card: delete_card,
add_card_select: add_card_select,
add_card_credential_keypress: add_card_credential_keypress,
process_add_card_persona: process_add_card_persona,
locate_or_add_credential_persona: locate_or_add_credential_persona,
paint_cards: paint_cards,
persona_submission_enabled: persona_submission_enabled,
load_data_cards: load_data_cards,
output_card: output_card,
submitOnCr: submitOnCr,
// claimer_interactive_phone_input: claimer_interactive_phone_input,
processSyncResult: processSyncResult,
// BFHPhone: BFHPhone,
getFile: getFile,
getFileChanged: getFileChanged,
personaCollectionFactory: personaCollectionFactory,
emptyScopeInfo: emptyScopeInfo,
setUpWalletPin: setUpWalletPin,
process_pin: process_pin,
process_pin_enter: process_pin_enter,
display_render_callback: display_render_callback
}
const default_minimal_image = "";
const default_official_image = "";
const default_unknown_image = "";
const default_incognito_image = "";
const plus_card_image = "";
const personal_card = "";
const moduleName = 'wallet';
var personaCollection;
var incognito = false;
const builtinPersonaKinds = ['natural', 'minimal', 'official'];
var process_pin_options;
const CARD_SELECTED = '#E1E1E1';
const CARD_NOT_SELECTED = '#F8F8F8';
function submitOnCr(event, func, parameter) {
if (event.which == 13 || event.keyCode == 13) {
pk.app.renderScript(func, parameter);
return false;
}
return true;
}
// currentPersona is a card id or 'selected'
function paint_cards(currentPersona, scopeInfo)
{
var personas = personaCollection.personas;
if (!scopeInfo){
scopeInfo = emptyScopeInfo();
}
/*
var card_template = `\
<div class="row figure card_group" id="card_{{cardId}}" onclick="pk.ptools.click_data_card(event);" oncontextmenu="pk.ptools.delete_card(event);return false;">\
<img class="cg_card img-fluid" src="{{card_design}}">\
<span class="cg_details fas fa-address-card" style="font-size:1.6em; color: white" onclick="pk.ptools.click_data_card(event, \'data\');">\
{{submitButton}}\
</span>\
{{card_text_spans}}\
</div>`;
*/
var card_template = `\
<div class="row figure card_group" id="card_{{cardId}}" onclick="pk.ptools.click_data_card(event, \'data\');" oncontextmenu="pk.ptools.delete_card(event);return false;">\
<img class="cg_card img-fluid" src="{{card_design}}">\
<span class="cg_details fas fa-ellipsis-v" style="font-size:1.6em; color: white" onclick="pk.ptools.click_data_card(event, \'more\');">\
{{submitButton}}\
</span>\
{{card_text_spans}}\
</div>`;
var natural = getPersona("natural");
var options = natural.data.options ? natural.data.options : {};
var submitButtonTemplate = '<i class="far fa-paper-plane px-3" style="font-size:1em;" onclick="pk.ptools.click_data_card(event, \'submit\');"></i>';
var omniWarning;
var submitButton = personaCollection.submitEnabled ? submitButtonTemplate : '';
var setHtml = '';
var matchingCards = 0;
for (var key in personas){
var persona = personas[key];
// new candidates still have an undefined scope but
// if they are explicitly referenced by kid
// they match the request.
if (persona.kind === 'minimal' && !options.self_asserted_personas){
continue;
}
// don't show candidates
if (persona.kind === 'candidate'){
continue;
}
potentialMatches = true;
if (persona.scope || currentPersona === 'selected'
|| persona.kind !== 'candidate'){
// the general case: scope must match
if (scope_and_claim_mismatch(persona, scopeInfo)){
continue;
}
}
var card_text_spans = '';
if (persona.card_formats){
for (var k in persona.card_formats){
var css_obj = persona.card_formats[k];
var css = '';
for (var j in css_obj){
css += j + ':' + css_obj[j] + ';';
}
card_text_spans += '<span style="' + css + '">'
+ persona[k] + '</span>';
}
}
var cardHtml = card_template.replace(/{{cardId}}/g, persona.id);
cardHtml = cardHtml.replace('{{card_design}}', persona.card_design);
cardHtml = cardHtml.replace('{{card_logo_url}}', persona.card_logo_url);
cardHtml = cardHtml.replace('{{card_title}}', persona.card_title);
cardHtml = cardHtml.replace('{{credential_description}}', persona.credential_description);
// omniWarning = persona.omnidirectional ? 'fa-bullhorn' : '';
omniWarning = persona.omnidirectional ? 'fa-shoe-prints' : '';
cardHtml = cardHtml.replace('{{omnidirectional}}', omniWarning);
cardHtml = cardHtml.replace('{{card_text_spans}}', card_text_spans);
cardHtml = cardHtml.replace('{{submitButton}}', submitButton);
setHtml += cardHtml;
matchingCards++;
}
if (scopeInfo.scopeArray.length && matchingCards === 0){
triggerOAuthError(400, "invalid_scope", "neither scope nor claims match a card");
return;
}
var cardSetEl = document.getElementById('card_set');
if (cardSetEl !== undefined){
cardSetEl.innerHTML = setHtml;
}
if (currentPersona !== undefined){
if (currentPersona === 'selected'){
currentPersona = personaCollection.selectedCard;
}
var currentTarget = document.getElementById('card_' + currentPersona);
if (currentTarget !== null){
var eventSimulator = {
currentTarget: currentTarget,
simulated: true
};
select_card(eventSimulator);
}
}
function scope_and_claim_mismatch(persona, requestScope){
var match = false;
var scopes = requestScope.scopeArray;
// no requestScope means accept all scopes
if (scopes.length == 0){
return false;
}
for (var i=0; i<scopes.length; i++){
var scope = scopes[i];
if (scope === 'openid' || scope === 'vc'){
continue;
}
if (persona.scope.includes(scope)){
match = true;
break;
}
}
if (requestScope.claims && requestScope.claims.id_token){
for (var key in requestScope.claims.id_token){
var addi