Blocklist Check Results
If there are blocklist checks enabled in the recipe, there’ll be an ability to pick up on customers or entity attributes that have been blocked previously.
Blocklist checks, and their close counterpart the duplicate check, will return a ProcessResultObject for each match to another entity, based on your configured matching rules.
Blacklist or Blocklist?
The API documents refer to “blacklists” as well as “blocklists”. We’re in the process of renaming all our blacklist references to blocklists, so recognise that these terms are interchangable and refer to the same mechanism.
Blocklist will be the preferred naming convention going forward.
Each ProcessResultObject
will contain the following values:
Field Name | Description |
---|---|
checkDate | UTC timestamp as to when the blocklist check was matched |
checkId | The check run that found the match |
checkPerformedBy | With be one of “dup”, “bl” or “dup+bl”, as the checks run for duplicate and blocklist are the same and generally run at the same time. |
checkSource | Will always be builtin |
checkType | Will be the full list of checks that are scheduled to be run as part of the recipe (or as requested in an ad-hoc query) |
confidenceLevel | What was the matching score, based on the configured matching rules. |
providerCheckId | Will always be the same as checkId above. |
resultState | Will be one of: _ CHECKED_SUCCESS_CLEAR : blocklist check was run and no match found _ CHECKED_SUCCESS_WITH_NOTES : There was a match found that requires/required review. * CHECKED_FAILED : there was an error running the blocklist check. If you see this, please let FrankieOne dev support know and provide the entityID, requestID and date/time of the error. |
The following resultNote
Key-Value-Pairs will also be set.
Key Name | Value Description |
---|---|
match.entity.id | The entityID that we matched to |
match.entity.customer_reference | If the matched entity has a customer reference, then this is included as well |
match.level | How strong a match |
blacklist.attribute | The specific attribute that was matched (or ENTIRE_ENTITY if a general blocklist match) |
blacklist.reason | Why this particular matching entity/attribute was blocklisted |
match.type.entity | A pipe ( | ) separated list of the entity fields we matched on. |
match.type.document | A pipe ( | ) separated list of the document fields we matched on. |
match.notes | Which matching rule was used to determine that a match has been made. |
status.current | If this match has been assessed, what’s the final status. It will be one of: false_positive true_positive |
status.manual_update | Will be the requestID of the request that set the final state of this match |
status.set_date | UTC date stamp when the status was set |
status.set_by | The username of the person who set the status |
status.false_positive.ignore | Internal flag used to indicate this result can be ignored when evaluating overall entity state |
status.true_positive | Internal flag used to indicate a true positive match |
Effect on EntityProfileResult
When there is a blocklist match (either a true positive or all potential matches haven’t yet been marked as false positives), this will prevent any further checks from being run. In that case, there would be something like the following in the entityProfileResult checkResults
section:
1 ... 2 { 3 "checkClass": "fraud", 4 "checkType": "blacklist", 5 "code": "POTENTIAL_MATCH", 6 "message": "Potential blacklist match (Manual review required)", 7 "result": "FAIL" 8 }, 9 { 10 "checkClass": "aml", 11 "checkType": "pep_media", 12 "code": "BLOCKED_BY_OTHER_FAIL", 13 "message": "Can't check while there are potential blacklist matches", 14 "result": "UNCHECKED" 15 }, 16 { 17 "checkClass": "none", 18 "checkType": "idvalidate", 19 "code": "BLOCKED_BY_OTHER_FAIL", 20 "message": "Can't check while there are potential blacklist matches", 21 "result": "UNCHECKED" 22 } 23 ...
In there you can see that there is a blacklist FAIL result and subsequent checks are blocked by this failure.
Example
An example where there are two false positive matches, one true positive and outstanding are below:
1 "blacklistCheckResults": [ 2 { 3 "checkDate": "2021-08-10T07:35:33.953Z", 4 "checkId": "9c6e3b73-9a83-162b-c76e-cc8d63cf2674", 5 "checkPerformedBy": "bl", 6 "checkSource": "builtin", 7 "checkType": "blacklist,pep_media,idvalidate", 8 "confidenceLevel": 60, 9 "providerCheckID": "9c6e3b73-9a83-162b-c76e-cc8d63cf2674", 10 "resultNotes": [ 11 { 12 "kvpKey": "match.entity.id", 13 "kvpType": "general.string", 14 "kvpValue": "97f96378-1b64-af6d-9f09-a96fb13be05f" 15 }, 16 { 17 "kvpKey": "match.entity.customer_reference", 18 "kvpType": "id.external", 19 "kvpValue": "5290008-new-applicant" 20 }, 21 { 22 "kvpKey": "match.level", 23 "kvpType": "general.string", 24 "kvpValue": "MEDIUM" 25 }, 26 { 27 "kvpKey": "match.type.document", 28 "kvpType": "general.string", 29 "kvpValue": "IdNo" 30 }, 31 { 32 "kvpKey": "match.notes", 33 "kvpType": "general.string", 34 "kvpValue": "Match rule #2" 35 }, 36 { 37 "kvpKey": "blacklist.reason", 38 "kvpType": "general.string", 39 "kvpValue": "FABRICATED_IDENTITY" 40 }, 41 { 42 "kvpKey": "blacklist.attribute", 43 "kvpType": "general.string", 44 "kvpValue": "ID_DOCUMENT" 45 }, 46 { 47 "kvpKey": "original_checksource", 48 "kvpType": "general.string", 49 "kvpValue": "builtin" 50 }, 51 { 52 "kvpKey": "status.false_positive.ignore", 53 "kvpType": "result.code", 54 "kvpValue": "01FCQG0KBSKA5P27WGP8EZTNHX" 55 }, 56 { 57 "kvpKey": "status.current", 58 "kvpType": "general.string", 59 "kvpValue": "false_positive" 60 }, 61 { 62 "kvpKey": "status.manual_update", 63 "kvpType": "result.code", 64 "kvpValue": "01FCQG0KBSKA5P27WGP8EZTNHX" 65 }, 66 { 67 "kvpKey": "status.set_by", 68 "kvpType": "general.string", 69 "kvpValue": "jerry@frankieone.com" 70 }, 71 { 72 "kvpKey": "status.set_date", 73 "kvpType": "general.datetime", 74 "kvpValue": "2021-08-10T07:39:15Z" 75 } 76 ], 77 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 78 }, 79 { 80 "checkDate": "2021-08-10T07:35:33.953Z", 81 "checkId": "9c6e3b73-9a83-162b-c76e-cc8d63cf2674", 82 "checkPerformedBy": "bl", 83 "checkSource": "builtin", 84 "checkType": "blacklist,pep_media,idvalidate", 85 "confidenceLevel": 50, 86 "providerCheckID": "9c6e3b73-9a83-162b-c76e-cc8d63cf2674", 87 "resultNotes": [ 88 { 89 "kvpKey": "match.entity.id", 90 "kvpType": "general.string", 91 "kvpValue": "3e3cac65-813b-975a-b3e8-0c772767b74a" 92 }, 93 { 94 "kvpKey": "match.level", 95 "kvpType": "general.string", 96 "kvpValue": "MEDIUM" 97 }, 98 { 99 "kvpKey": "match.type.entity", 100 "kvpType": "general.string", 101 "kvpValue": "Date|Fnam" 102 }, 103 { 104 "kvpKey": "match.notes", 105 "kvpType": "general.string", 106 "kvpValue": "Match rule #5" 107 }, 108 { 109 "kvpKey": "blacklist.reason", 110 "kvpType": "general.string", 111 "kvpValue": "FABRICATED_IDENTITY" 112 }, 113 { 114 "kvpKey": "blacklist.attribute", 115 "kvpType": "general.string", 116 "kvpValue": "FULL_NAME" 117 }, 118 { 119 "kvpKey": "original_checksource", 120 "kvpType": "general.string", 121 "kvpValue": "builtin" 122 }, 123 { 124 "kvpKey": "status.true_positive", 125 "kvpType": "result.code", 126 "kvpValue": "01FDPBHTK2NKJWCC4EYEVGR18P" 127 }, 128 { 129 "kvpKey": "status.current", 130 "kvpType": "general.string", 131 "kvpValue": "true_positive" 132 }, 133 { 134 "kvpKey": "status.manual_update", 135 "kvpType": "result.code", 136 "kvpValue": "01FDPBHTK2NKJWCC4EYEVGR18P" 137 }, 138 { 139 "kvpKey": "status.set_by", 140 "kvpType": "general.string", 141 "kvpValue": "ops-verify@frankiefinancial.com" 142 }, 143 { 144 "kvpKey": "status.set_date", 145 "kvpType": "general.datetime", 146 "kvpValue": "2021-08-22T07:17:43Z" 147 } 148 ], 149 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 150 }, 151 { 152 "checkDate": "2021-08-10T07:35:33.953Z", 153 "checkId": "9c6e3b73-9a83-162b-c76e-cc8d63cf2674", 154 "checkPerformedBy": "bl", 155 "checkSource": "builtin", 156 "checkType": "blacklist,pep_media,idvalidate", 157 "confidenceLevel": 50, 158 "providerCheckID": "9c6e3b73-9a83-162b-c76e-cc8d63cf2674", 159 "resultNotes": [ 160 { 161 "kvpKey": "match.entity.id", 162 "kvpType": "general.string", 163 "kvpValue": "c435b728-34ba-53e6-cd8d-1a6c18209bf1" 164 }, 165 { 166 "kvpKey": "match.level", 167 "kvpType": "general.string", 168 "kvpValue": "MEDIUM" 169 }, 170 { 171 "kvpKey": "match.type.entity", 172 "kvpType": "general.string", 173 "kvpValue": "Date|Fnam" 174 }, 175 { 176 "kvpKey": "match.notes", 177 "kvpType": "general.string", 178 "kvpValue": "Match rule #5" 179 }, 180 { 181 "kvpKey": "blacklist.reason", 182 "kvpType": "general.string", 183 "kvpValue": "NO_REASON_SUPPLIED" 184 }, 185 { 186 "kvpKey": "blacklist.attribute", 187 "kvpType": "general.string", 188 "kvpValue": "ENTIRE_ENTITY" 189 }, 190 { 191 "kvpKey": "original_checksource", 192 "kvpType": "general.string", 193 "kvpValue": "builtin" 194 } 195 ], 196 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 197 } 198 ],