Duplicate Check Results
If there are duplicate checks enabled in your recipe, this would be a method to identify customers that have tried to sign up previously.
Duplicate checks, and their close counterpart, the blocklist check, will return a ProcessResultObject for each match to another entity, based on your configured matching rules.
Each ProcessResultObject
will contain the following values:
Field Name | Description |
---|---|
checkDate | UTC timestamp as to when the duplicate 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 your matching rules. |
providerCheckId | Will always be the same as checkId above. |
resultState | Will be one of: _ CHECKED_SUCCESS_CLEAR : duplicate 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 duplicate 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 |
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 duplicate 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 you would see something like the following in the entityProfileResult checkResults section:
1 ... 2 { 3 "checkClass": "fraud", 4 "checkType": "duplicate", 5 "code": "POTENTIAL_MATCH", 6 "message": "Potential duplicate match (Manual review required)", 7 "result": "FAIL" 8 }, 9 { 10 "checkClass": "kyc", 11 "checkType": "two_plus", 12 "code": "BLOCKED_BY_OTHER_FAIL", 13 "message": "Can't check while there are potential duplicate matches", 14 "result": "UNCHECKED" 15 }, 16 { 17 "checkClass": "kyc", 18 "checkType": "id", 19 "code": "BLOCKED_BY_OTHER_FAIL", 20 "message": "Can't check while there are potential duplicate matches", 21 "result": "UNCHECKED" 22 }, 23 ...
In there you can see that there is a duplicate 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 "duplicateCheckResults": [ 2 { 3 "checkDate": "2021-03-24T05:49:48.925Z", 4 "checkId": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 5 "checkPerformedBy": "bl", 6 "checkSource": "builtin", 7 "checkType": "blacklist,duplicate,two_plus,id,visa,pep,fraudlist", 8 "confidenceLevel": 50, 9 "providerCheckID": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 10 "resultNotes": [ 11 { 12 "kvpKey": "match.entity.id", 13 "kvpType": "general.string", 14 "kvpValue": "562d651e-72c2-62b3-0494-bc7c6c5fa622" 15 }, 16 { 17 "kvpKey": "match.level", 18 "kvpType": "general.string", 19 "kvpValue": "MEDIUM" 20 }, 21 { 22 "kvpKey": "match.type.entity", 23 "kvpType": "general.string", 24 "kvpValue": "Date|Fnam" 25 }, 26 { 27 "kvpKey": "match.notes", 28 "kvpType": "general.string", 29 "kvpValue": "Match rule #5" 30 }, 31 { 32 "kvpKey": "original_checksource", 33 "kvpType": "general.string", 34 "kvpValue": "builtin" 35 }, 36 { 37 "kvpKey": "status.false_positive.ignore", 38 "kvpType": "result.code", 39 "kvpValue": "01F1HCJ9Z28PEH116EPRBERPTZ" 40 }, 41 { 42 "kvpKey": "status.current", 43 "kvpType": "general.string", 44 "kvpValue": "false_positive" 45 }, 46 { 47 "kvpKey": "status.manual_update", 48 "kvpType": "result.code", 49 "kvpValue": "01F1HCJ9Z28PEH116EPRBERPTZ" 50 }, 51 { 52 "kvpKey": "status.set_by", 53 "kvpType": "general.string", 54 "kvpValue": "rohit@frankieone.com" 55 }, 56 { 57 "kvpKey": "status.set_date", 58 "kvpType": "general.datetime", 59 "kvpValue": "2021-03-24T05:50:53Z" 60 } 61 ], 62 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 63 }, 64 { 65 "checkDate": "2021-03-24T05:49:48.925Z", 66 "checkId": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 67 "checkPerformedBy": "bl", 68 "checkSource": "builtin", 69 "checkType": "blacklist,duplicate,two_plus,id,visa,pep,fraudlist", 70 "confidenceLevel": 50, 71 "providerCheckID": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 72 "resultNotes": [ 73 { 74 "kvpKey": "match.entity.id", 75 "kvpType": "general.string", 76 "kvpValue": "3dd1a14c-ea67-69c6-94b9-511abad25c56" 77 }, 78 { 79 "kvpKey": "match.level", 80 "kvpType": "general.string", 81 "kvpValue": "MEDIUM" 82 }, 83 { 84 "kvpKey": "match.type.entity", 85 "kvpType": "general.string", 86 "kvpValue": "Date|Fnam" 87 }, 88 { 89 "kvpKey": "match.notes", 90 "kvpType": "general.string", 91 "kvpValue": "Match rule #5" 92 }, 93 { 94 "kvpKey": "original_checksource", 95 "kvpType": "general.string", 96 "kvpValue": "builtin" 97 }, 98 { 99 "kvpKey": "status.true_positive", 100 "kvpType": "result.code", 101 "kvpValue": "01FDP9VKDQF6V763XG9AC778SW" 102 }, 103 { 104 "kvpKey": "status.current", 105 "kvpType": "general.string", 106 "kvpValue": "true_positive" 107 }, 108 { 109 "kvpKey": "status.manual_update", 110 "kvpType": "result.code", 111 "kvpValue": "01FDP9VKDQF6V763XG9AC778SW" 112 }, 113 { 114 "kvpKey": "status.set_by", 115 "kvpType": "general.string", 116 "kvpValue": "ops-verify@frankiefinancial.com" 117 }, 118 { 119 "kvpKey": "status.set_date", 120 "kvpType": "general.datetime", 121 "kvpValue": "2021-08-22T06:48:06Z" 122 } 123 ], 124 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 125 }, 126 { 127 "checkDate": "2021-03-24T05:49:48.925Z", 128 "checkId": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 129 "checkPerformedBy": "bl", 130 "checkSource": "builtin", 131 "checkType": "blacklist,duplicate,two_plus,id,visa,pep,fraudlist", 132 "confidenceLevel": 50, 133 "providerCheckID": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 134 "resultNotes": [ 135 { 136 "kvpKey": "match.entity.id", 137 "kvpType": "general.string", 138 "kvpValue": "1dd0b3af-97b7-5db0-fc35-9b180aa0b37d" 139 }, 140 { 141 "kvpKey": "match.level", 142 "kvpType": "general.string", 143 "kvpValue": "MEDIUM" 144 }, 145 { 146 "kvpKey": "match.type.entity", 147 "kvpType": "general.string", 148 "kvpValue": "Date|Fnam" 149 }, 150 { 151 "kvpKey": "match.notes", 152 "kvpType": "general.string", 153 "kvpValue": "Match rule #5" 154 }, 155 { 156 "kvpKey": "original_checksource", 157 "kvpType": "general.string", 158 "kvpValue": "builtin" 159 } 160 ], 161 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 162 }, 163 { 164 "checkDate": "2021-03-24T05:49:48.925Z", 165 "checkId": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 166 "checkPerformedBy": "bl", 167 "checkSource": "builtin", 168 "checkType": "blacklist,duplicate,two_plus,id,visa,pep,fraudlist", 169 "confidenceLevel": 80, 170 "providerCheckID": "636b03c3-444b-03f5-9a63-4dd0808f3eca", 171 "resultNotes": [ 172 { 173 "kvpKey": "match.entity.id", 174 "kvpType": "general.string", 175 "kvpValue": "668f310d-26fb-c1f9-7a6a-b202997fb968" 176 }, 177 { 178 "kvpKey": "match.level", 179 "kvpType": "general.string", 180 "kvpValue": "HIGH" 181 }, 182 { 183 "kvpKey": "match.type.entity", 184 "kvpType": "general.string", 185 "kvpValue": "Date" 186 }, 187 { 188 "kvpKey": "match.type.document", 189 "kvpType": "general.string", 190 "kvpValue": "IdNo" 191 }, 192 { 193 "kvpKey": "match.notes", 194 "kvpType": "general.string", 195 "kvpValue": "Match rule #2" 196 }, 197 { 198 "kvpKey": "original_checksource", 199 "kvpType": "general.string", 200 "kvpValue": "builtin" 201 }, 202 { 203 "kvpKey": "status.false_positive.ignore", 204 "kvpType": "result.code", 205 "kvpValue": "01F1HCJ3X0GJNN86BCDW2MB4RR" 206 }, 207 { 208 "kvpKey": "status.current", 209 "kvpType": "general.string", 210 "kvpValue": "false_positive" 211 }, 212 { 213 "kvpKey": "status.manual_update", 214 "kvpType": "result.code", 215 "kvpValue": "01F1HCJ3X0GJNN86BCDW2MB4RR" 216 }, 217 { 218 "kvpKey": "status.set_by", 219 "kvpType": "general.string", 220 "kvpValue": "rohit@frankieone.com" 221 }, 222 { 223 "kvpKey": "status.set_date", 224 "kvpType": "general.datetime", 225 "kvpValue": "2021-03-24T05:50:47Z" 226 } 227 ], 228 "resultState": "CHECKED_SUCCESS_WITH_NOTES" 229 } 230 ],