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 NameDescription
checkDateUTC timestamp as to when the duplicate 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 your matching rules.
providerCheckIdWill always be the same as checkId above.
resultStateWill 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 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
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 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:

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

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