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 NameDescription
checkDateUTC timestamp as to when the blocklist check was matched
checkIdThe check run that found the match
checkPerformedByWith 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.
checkSourceWill always be builtin
checkTypeWill 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)
confidenceLevelWhat was the matching score, based on the configured matching rules.
providerCheckIdWill always be the same as checkId above.
resultStateWill 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 NameValue Description
match.entity.idThe entityID that we matched to
match.entity.customer_referenceIf the matched entity has a customer reference, then this is included as well
match.levelHow strong a match
blacklist.attributeThe specific attribute that was matched (or ENTIRE_ENTITY if a general blocklist match)
blacklist.reasonWhy this particular matching entity/attribute was blocklisted
match.type.entityA pipe ( | ) separated list of the entity fields we matched on.
match.type.documentA pipe ( | ) separated list of the document fields we matched on.
match.notesWhich matching rule was used to determine that a match has been made.
status.currentIf this match has been assessed, what’s the final status. It will be one of:
false_positive
true_positive
status.manual_updateWill be the requestID of the request that set the final state of this match
status.set_dateUTC date stamp when the status was set
status.set_byThe username of the person who set the status
status.false_positive.ignoreInternal flag used to indicate this result can be ignored when evaluating overall entity state
status.true_positiveInternal 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:

Blocklist Result
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:

Example Blocklist Result
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 ],
Built with