Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Refactoring UserIdentity logics #1097

Draft
wants to merge 174 commits into
base: syw-UID2-4159-token-gen-code-renaming
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from 18 commits
Commits
Show all changes
174 commits
Select commit Hold shift + click to select a range
e057a84
testing debug config value
Ian-Nara Oct 4, 2024
a70141b
testing debug config value
Ian-Nara Oct 4, 2024
ec27533
[CI Pipeline] Released Snapshot version: 5.40.49-alpha-24-SNAPSHOT
Oct 4, 2024
b24fbf8
don't use logback conf in debug mode
Ian-Nara Oct 4, 2024
3f1eb09
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-thro…
Ian-Nara Oct 4, 2024
59d9dd7
add more log information
Ian-Nara Oct 4, 2024
b4aa9c4
[CI Pipeline] Released Snapshot version: 5.40.50-alpha-25-SNAPSHOT
Oct 4, 2024
da0e058
fix if statement
Ian-Nara Oct 4, 2024
7589983
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-thro…
Ian-Nara Oct 4, 2024
7ec499f
[CI Pipeline] Released Snapshot version: 5.40.51-alpha-27-SNAPSHOT
Oct 4, 2024
3a377d5
add debug logback conf
Ian-Nara Oct 7, 2024
ea6d9fd
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-thro…
Ian-Nara Oct 7, 2024
ba116b3
[CI Pipeline] Released Snapshot version: 5.40.52-alpha-28-SNAPSHOT
Oct 7, 2024
4803b7f
operator debug
Ian-Nara Oct 7, 2024
0de3185
[CI Pipeline] Released Snapshot version: 5.40.53-alpha-29-SNAPSHOT
Oct 7, 2024
7772761
Adding vsock and dante logging
thomasm-ttd Oct 7, 2024
4823823
[CI Pipeline] Released Snapshot version: 5.40.54-alpha-30-SNAPSHOT
Oct 7, 2024
407e548
Temp change the CID
thomasm-ttd Oct 8, 2024
3b65da6
Revert CID change
thomasm-ttd Oct 8, 2024
b7dd254
Adding debug port to eks pod
cody-constine-ttd Oct 8, 2024
efbc1ac
[CI Pipeline] Released Snapshot version: 5.40.55-alpha-31-SNAPSHOT
Oct 8, 2024
579fdc1
Remove assertions used to check argument validity in public methods
asloobq Oct 10, 2024
44093af
Exclude code and assertion from source needed only for tests
asloobq Oct 10, 2024
b91591b
replace assert for refresh token length with exception
asloobq Oct 10, 2024
0a82473
Replace assert with NPE in statsCollector public methods
asloobq Oct 10, 2024
21555c0
Update the handler for shutdown
thomasm-ttd Oct 11, 2024
d45f4cf
Turn of the exit on error
thomasm-ttd Oct 11, 2024
912a6a9
[CI Pipeline] Released Snapshot version: 5.40.56-alpha-34-SNAPSHOT
Oct 11, 2024
bd6438a
Convert assert in default switch case to exception. Refactor methods
asloobq Oct 11, 2024
6e964c6
Refactor error messages to static string
asloobq Oct 11, 2024
9c24935
refactor redundant code to call function
asloobq Oct 11, 2024
7e5ad5d
1. Refactor EncryptedTokenEncoder#encodeIntoIdentityResponse
sunnywu Oct 14, 2024
131d203
Use EncryptedTokenEncoder directly inside UIDOperatorService class in…
sunnywu Oct 14, 2024
d9845b7
Merge branch 'syw-UID2-4159-token-gen-code-renaming' into syw-UID2-41…
sunnywu Oct 14, 2024
b2fc597
Update version of shared
thomasm-ttd Oct 14, 2024
9a0d39e
[CI Pipeline] Released Snapshot version: 5.40.87-alpha-108-SNAPSHOT
Oct 14, 2024
5a0bb89
Merge branch 'syw-UID2-4159-token-gen-code-renaming' into syw-UID2-41…
sunnywu Oct 14, 2024
0e621d3
[CI Pipeline] Released Snapshot version: 5.40.88-alpha-109-SNAPSHOT
Oct 14, 2024
b507d8e
Fixed UserIdentity member variables as final and added constructor
sunnywu Oct 15, 2024
f5877b7
1. Addressed code review feedbacks
sunnywu Oct 15, 2024
ccc639f
Made UserIdentity abstract first
sunnywu Oct 15, 2024
dabff48
Fixed a few id variable to rawUid/firstLevelHash to make it clear. Fi…
sunnywu Oct 15, 2024
44ed5d3
Merge remote-tracking branch 'origin/syw-UID2-4159-token-gen-code-ren…
sunnywu Oct 15, 2024
60abeed
Convert asserts to exceptions in OptOut code
asloobq Oct 15, 2024
ce6bf60
[CI Pipeline] Released Snapshot version: 5.40.87-alpha-110-SNAPSHOT
Oct 15, 2024
19c6c7a
Fix partition timestamp check
asloobq Oct 16, 2024
6031d14
Merge remote-tracking branch 'origin/syw-UID2-4159-token-gen-code-ren…
sunnywu Oct 16, 2024
3b1718c
1. Removed the UserIdentity's refreshedAt field as that's redundant and
sunnywu Oct 16, 2024
0ab0a79
1. Removed privacyBits and establishedAt from UserIdentity/HashedDiiI…
sunnywu Oct 16, 2024
7538bfb
added comments
sunnywu Oct 16, 2024
249c25d
fixed variable name
sunnywu Oct 16, 2024
3624f15
Merge remote-tracking branch 'origin/syw-UID2-4159-token-gen-code-ren…
sunnywu Oct 16, 2024
a38af09
Merge remote-tracking branch 'origin/syw-UID2-4159-token-gen-code-ref…
sunnywu Oct 16, 2024
a890446
Changed assertion to warn
asloobq Oct 16, 2024
dff8dae
remove sleep and reset version
Ian-Nara Oct 16, 2024
29ae2c5
safe debugging enclave
Ian-Nara Oct 17, 2024
3c28951
safe debugging enclave
Ian-Nara Oct 17, 2024
58ca0e2
Merge branch 'main' into ian-UID2-4235-enclave-debug-without-debugger…
Ian-Nara Oct 17, 2024
e8916e5
[CI Pipeline] Released Snapshot version: 5.40.87-alpha-44-SNAPSHOT
Oct 17, 2024
78e61d0
Add comment for warning
asloobq Oct 17, 2024
aff43f2
fix if
Ian-Nara Oct 17, 2024
3ce1b21
[CI Pipeline] Released Snapshot version: 5.40.88-alpha-45-SNAPSHOT
Oct 17, 2024
1519f45
syslog
Ian-Nara Oct 18, 2024
3b50392
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-with…
Ian-Nara Oct 18, 2024
21b407e
[CI Pipeline] Released Snapshot version: 5.40.89-alpha-46-SNAPSHOT
Oct 18, 2024
3cb8e47
syslog
Ian-Nara Oct 18, 2024
ef23487
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-with…
Ian-Nara Oct 18, 2024
7eb0424
[CI Pipeline] Released Snapshot version: 5.40.90-alpha-47-SNAPSHOT
Oct 18, 2024
1d701e4
syslog
Ian-Nara Oct 18, 2024
f71550d
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-with…
Ian-Nara Oct 18, 2024
b5ac102
[CI Pipeline] Released Snapshot version: 5.40.91-alpha-48-SNAPSHOT
Oct 18, 2024
4772242
syslog
Ian-Nara Oct 18, 2024
87a578b
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-with…
Ian-Nara Oct 18, 2024
beacc48
[CI Pipeline] Released Snapshot version: 5.40.92-alpha-49-SNAPSHOT
Oct 18, 2024
5aa2004
syslog
Ian-Nara Oct 18, 2024
72fc624
Merge remote-tracking branch 'origin/ian-UID2-4235-enclave-debug-with…
Ian-Nara Oct 18, 2024
95a826c
syslog
Ian-Nara Oct 18, 2024
0e63e5a
debug
Ian-Nara Oct 18, 2024
aa8c292
[CI Pipeline] Released Snapshot version: 5.40.93-alpha-50-SNAPSHOT
Oct 18, 2024
c241870
debug
Ian-Nara Oct 18, 2024
f2ee9f5
Merge pull request #1099 from IABTechLab/ian-UID2-4235-enclave-debug-…
Ian-Nara Oct 18, 2024
3fc5dc3
[CI Pipeline] Released Patch version: 5.40.106
Oct 18, 2024
e08e05e
Merge pull request #1108 from IABTechLab/ci-f2ee9f5939369ecb70f2b8eab…
github-actions[bot] Oct 18, 2024
24ab08e
Remove unwanted assertions. Address review comments
asloobq Oct 18, 2024
029a25b
Merge main
thomasm-ttd Oct 20, 2024
9457a94
[CI Pipeline] Released Snapshot version: 5.40.107-alpha-111-SNAPSHOT
Oct 20, 2024
1afe2ee
Update version of shared
thomasm-ttd Oct 21, 2024
2f87dae
Merge branch 'tjm-UID2-4246-only-shutdown-on-401' of github.com:IABTe…
thomasm-ttd Oct 21, 2024
566120d
Merge pull request #1082 from IABTechLab/tjm-UID2-4246-only-shutdown-…
thomasm-ttd Oct 21, 2024
05e6377
[CI Pipeline] Released Minor version: 5.41.0
Oct 21, 2024
6303b64
Merge pull request #1110 from IABTechLab/ci-566120df6b8cee126e14b45d7…
github-actions[bot] Oct 21, 2024
4c1de75
Moved privacyBits out of FirstLevelHashIdentity and treat it as a sep…
sunnywu Oct 21, 2024
062f908
Added a new IdentityRequest constructor to set default values for pri…
sunnywu Oct 21, 2024
ce1ab8b
Merge pull request #1085 from IABTechLab/aaq-UID2-3393-remove-assertions
asloobq Oct 22, 2024
76a1345
Update src/main/java/com/uid2/operator/model/IdentityRequest.java
sunnywu Oct 28, 2024
5db6e4f
Replace privacy bits type to PrivacyBits class instance
sunnywu Oct 28, 2024
741237d
Replace privacy bits type to PrivacyBits class instance
sunnywu Oct 28, 2024
3900017
Replace privacy bits type to PrivacyBits class instance
sunnywu Oct 28, 2024
e5b104d
missing a newline
sunnywu Oct 28, 2024
e25cd19
1. Added PrivacyBitsTest/IdentityResponseTest/RawUidResponseTest classes
sunnywu Oct 28, 2024
986cf2e
Created verifyFirstLevelHashIdentityAndEstablishedAt method for verif…
sunnywu Oct 28, 2024
f445180
Created verifyFirstLevelHashIdentityAndEstablishedAt method for verif…
sunnywu Oct 28, 2024
e4e7d2d
Merge remote-tracking branch 'origin/main' into syw-UID2-4159-token-g…
sunnywu Oct 28, 2024
fa1c0f1
Checking privacy bits in more tests in UIDOperatorVerticleTest
sunnywu Oct 28, 2024
d745cc7
Change optout loading exception to a warning temporarily
asloobq Oct 28, 2024
20d695c
[CI Pipeline] Released Snapshot version: 5.41.1-alpha-116-SNAPSHOT
Oct 29, 2024
81646aa
Merge pull request #1125 from IABTechLab/aaq-UID2-3393-remove-asserti…
asloobq Oct 29, 2024
c950c6d
revered version in pom.xml
sunnywu Oct 30, 2024
a908e1f
added some comments and renamed refreshIdentity method param to input…
sunnywu Oct 30, 2024
04dfc14
fixed unit tests checking establishedAt between advertisingTokenInput…
sunnywu Oct 30, 2024
2edcb05
Refactored unit test codes to standardise the advertisingTokenInput/r…
sunnywu Oct 30, 2024
ca44945
Refactored unit test codes to standardise the advertisingTokenInput/r…
sunnywu Oct 30, 2024
da549b0
Code review feedback
sunnywu Nov 4, 2024
c6586a5
renamed IUIDOperatorService#mapIdentity to mapHashedDiiIdentity
sunnywu Nov 4, 2024
d76bceb
renamed to
sunnywu Nov 4, 2024
23a6f50
Code review feedback and renamed AdvertisingTOkenInput/RefreshTokenIn…
sunnywu Nov 4, 2024
bfde65c
add back use metrics for the operator-served SDKs
Ian-Nara Nov 5, 2024
3002d0d
Merge pull request #1139 from IABTechLab/ian-UID2-4408-add-old-js-sdk…
Ian-Nara Nov 5, 2024
7149e81
[CI Pipeline] Released Patch version: 5.41.6
Nov 5, 2024
bf42c0b
Merge pull request #1140 from IABTechLab/ci-3002d0d91bde6f24469f9ec64…
github-actions[bot] Nov 5, 2024
b880e15
[CI Pipeline] Released Patch version: 5.41.8
Nov 6, 2024
6efb434
Merge pull request #1141 from IABTechLab/ci-bf42c0b4e7ddc4ffc37984b70…
github-actions[bot] Nov 6, 2024
5c81dc8
[CI Pipeline] Released Patch version: 5.41.8
Nov 6, 2024
645ba1c
Merge pull request #1143 from IABTechLab/ci-bf42c0b4e7ddc4ffc37984b70…
github-actions[bot] Nov 6, 2024
facd5a6
Added counter for tcf
cody-constine-ttd Nov 6, 2024
de1569a
fixed bad config value:
cody-constine-ttd Nov 6, 2024
d58eb09
find participants on old sdks
Ian-Nara Nov 7, 2024
015091b
update workflow refs
Ian-Nara Nov 7, 2024
13e033e
Fixed extra tag
cody-constine-ttd Nov 7, 2024
8126001
support phone number
ssundahlTTD Nov 7, 2024
aae3f73
update shared version
Ian-Nara Nov 7, 2024
d99c64d
Merge pull request #1145 from IABTechLab/ian-find-participants-on-old…
Ian-Nara Nov 7, 2024
4976107
[CI Pipeline] Released Patch version: 5.41.15
Nov 7, 2024
9483d25
Merge remote-tracking branch 'origin/main' into sas-UID2-4272-support…
ssundahlTTD Nov 7, 2024
8b86c2c
UID2-4429 More efficient disk space utilisation when building operato…
atarassov-ttd Oct 28, 2024
2aba623
Merge pull request #1148 from IABTechLab/ant-4429-build-disk-space-cl…
atarassov-ttd Nov 8, 2024
62421ce
UID2-4430 Automatic allocation of cores to vsockpx and operator vertx
atarassov-ttd Oct 29, 2024
a543932
Merge pull request #1149 from IABTechLab/ant-UID2-4430-vsockpx-thread…
atarassov-ttd Nov 8, 2024
557754b
Merge pull request #1146 from IABTechLab/sas-UID2-4272-support-euid-p…
ssundahlTTD Nov 8, 2024
8886f91
Merge pull request #1144 from IABTechLab/cbc-add-metrics-to-tcf
cody-constine-ttd Nov 8, 2024
3dd9ba5
[CI Pipeline] Released Minor version: 5.42.0
Nov 8, 2024
4e36633
Merge pull request #1150 from IABTechLab/ci-8886f91bfed809f42591982c8…
github-actions[bot] Nov 8, 2024
564b274
Ignore CVE-2024-47535 and CVE-2024-7254 (#1153)
thomasm-ttd Nov 15, 2024
75dfd6d
[CI Pipeline] Released Patch version: 5.42.3
Nov 18, 2024
b83fa90
[CI Pipeline] Released Patch version: 5.42.4
Nov 18, 2024
0a51642
[CI Pipeline] Released Patch version: 5.42.5
Nov 18, 2024
1385f2f
[CI Pipeline] Released Patch version: 5.42.6
Nov 18, 2024
75a9c29
Added site name as contact for CSTG
cody-constine-ttd Nov 18, 2024
c20cc48
Added site ID
cody-constine-ttd Nov 18, 2024
b2e30d9
Removing API contact
cody-constine-ttd Nov 19, 2024
079bfe5
Merge pull request #1160 from IABTechLab/cbc-UID2-CSTG-log-api-contact
cody-constine-ttd Nov 19, 2024
4359b3d
Upgrading vertx version
cody-constine-ttd Nov 22, 2024
b23dcdc
[CI Pipeline] Released Snapshot version: 5.42.7-alpha-139-SNAPSHOT
Nov 22, 2024
3768f82
Adding new shared version
cody-constine-ttd Nov 22, 2024
0b1e00a
Merge branch 'cbc-UID2-4461-upgrade-vertx-version' of github.com:IABT…
cody-constine-ttd Nov 22, 2024
c687ccf
Merge pull request #1176 from IABTechLab/cbc-UID2-4461-upgrade-vertx-…
cody-constine-ttd Nov 25, 2024
3954046
Remove siteIdsUsingV4Tokens (#1178)
cYKatherine Nov 26, 2024
9f0f28b
UID2-3804 Remove `advertising_token_v4_percentage` env var (#1180)
cYKatherine Dec 3, 2024
7d2ad65
[CI Pipeline] Released Patch version: 5.42.17
Dec 3, 2024
eed0b69
Merge pull request #1182 from IABTechLab/ci-9f0f28b58612bc74206fb667e…
github-actions[bot] Dec 3, 2024
a002ad1
Code review feedback,
sunnywu Dec 5, 2024
242b08d
xuy-UID2-4341-change-log-level Refine response logging (#1183)
clarkxuyang Dec 5, 2024
4a1af7d
Xuy UI d2 2578 update share lib to add site name to metrics (#1179)
clarkxuyang Dec 5, 2024
06d49c8
[CI Pipeline] Released Minor version: 5.43.0
Dec 5, 2024
e148266
Merge pull request #1184 from IABTechLab/ci-4a1af7de1ed658dc0ea6f76ba…
github-actions[bot] Dec 5, 2024
ea0b247
Renamed IdentityRequest/IdentityResponse to TokenGenerateRequest/Resp…
sunnywu Dec 9, 2024
4476ee1
- Renamed RawUidResponse to IdentityMapResponseItem, MapRequest to Id…
sunnywu Dec 9, 2024
6bb1fb9
1. Renamed FirstLevelHashIdentity/HashedDiiIdentity/RawUidIdentity to…
sunnywu Dec 9, 2024
a8f0915
1. Renamed IdentityType to DiiType
sunnywu Dec 9, 2024
e5dea0e
Increase max form buffer
vishalegbert-ttd Dec 10, 2024
382facf
Merge pull request #1195 from IABTechLab/vse-UID2-4593-increase-max-f…
vishalegbert-ttd Dec 10, 2024
1b72e55
[CI Pipeline] Released Patch version: 5.43.4
Dec 10, 2024
b792232
Use correct raw UID version for UID2 UIDOperatorVerticleTest and rena…
sunnywu Dec 10, 2024
7875d98
Merge remote-tracking branch 'origin/main' into syw-UID2-4159-token-g…
sunnywu Dec 10, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,18 @@ public class AdvertisingTokenInput extends VersionedToken {
public final OperatorIdentity operatorIdentity;
public final SourcePublisher sourcePublisher;
public final RawUidIdentity rawUidIdentity;
public final int privacyBits;
public final Instant establishedAt;

public AdvertisingTokenInput(TokenVersion version, Instant createdAt, Instant expiresAt, OperatorIdentity operatorIdentity,
SourcePublisher sourcePublisher, RawUidIdentity rawUidIdentity) {
SourcePublisher sourcePublisher, RawUidIdentity rawUidIdentity, int privacyBits,
Instant establishedAt) {
super(version, createdAt, expiresAt);
this.operatorIdentity = operatorIdentity;
this.sourcePublisher = sourcePublisher;
this.rawUidIdentity = rawUidIdentity;
this.privacyBits = privacyBits;
this.establishedAt = establishedAt;
}
}

22 changes: 22 additions & 0 deletions src/main/java/com/uid2/operator/model/IdentityRequest.java
Original file line number Diff line number Diff line change
@@ -1,12 +1,32 @@
package com.uid2.operator.model;

import com.uid2.operator.model.userIdentity.HashedDiiIdentity;
import com.uid2.operator.util.PrivacyBits;

import java.time.Instant;

public final class IdentityRequest {
public final SourcePublisher sourcePublisher;
public final HashedDiiIdentity hashedDiiIdentity;
public final OptoutCheckPolicy optoutCheckPolicy;

public final int privacyBits;
public final Instant establishedAt;

public IdentityRequest(
SourcePublisher sourcePublisher,
HashedDiiIdentity hashedDiiIdentity,
OptoutCheckPolicy tokenGeneratePolicy,
int privacyBits,
Instant establishedAt)
{
this.sourcePublisher = sourcePublisher;
this.hashedDiiIdentity = hashedDiiIdentity;
this.optoutCheckPolicy = tokenGeneratePolicy;
this.privacyBits = privacyBits;
this.establishedAt = establishedAt;
}

public IdentityRequest(
SourcePublisher sourcePublisher,
HashedDiiIdentity hashedDiiIdentity,
Expand All @@ -15,6 +35,8 @@ public IdentityRequest(
this.sourcePublisher = sourcePublisher;
this.hashedDiiIdentity = hashedDiiIdentity;
this.optoutCheckPolicy = tokenGeneratePolicy;
this.privacyBits = PrivacyBits.DEFAULT_PRIVACY_BIT_VALUE;
this.establishedAt = Instant.now();
}

public boolean shouldCheckOptOut() {
Expand Down
22 changes: 22 additions & 0 deletions src/main/java/com/uid2/operator/model/IdentityResponse.java
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package com.uid2.operator.model;

import com.uid2.shared.model.TokenVersion;
import io.vertx.core.json.JsonObject;

import java.time.Instant;

Expand Down Expand Up @@ -52,4 +53,25 @@ public Instant getRefreshFrom() {
public boolean isOptedOut() {
return advertisingToken == null || advertisingToken.isEmpty();
}

// for v1/v2 token/generate and token/refresh and client/generate (CSTG) endpoints
public JsonObject toJsonV1() {
final JsonObject json = new JsonObject();
json.put("advertising_token", getAdvertisingToken());
json.put("refresh_token", getRefreshToken());
json.put("identity_expires", getIdentityExpires().toEpochMilli());
json.put("refresh_expires", getRefreshExpires().toEpochMilli());
json.put("refresh_from", getRefreshFrom().toEpochMilli());
return json;
}

// for the original/legacy token/generate and token/refresh endpoint
public JsonObject toJsonV0() {
final JsonObject json = new JsonObject();
json.put("advertisement_token", getAdvertisingToken());
json.put("advertising_token", getAdvertisingToken());
json.put("refresh_token", getRefreshToken());

return json;
}
}
6 changes: 5 additions & 1 deletion src/main/java/com/uid2/operator/model/RefreshTokenInput.java
Original file line number Diff line number Diff line change
Expand Up @@ -9,12 +9,16 @@ public class RefreshTokenInput extends VersionedToken {
public final OperatorIdentity operatorIdentity;
public final SourcePublisher sourcePublisher;
public final FirstLevelHashIdentity firstLevelHashIdentity;
// by default, inherited from the previous refresh token's privacy bits
public final int privacyBits;


public RefreshTokenInput(TokenVersion version, Instant createdAt, Instant expiresAt, OperatorIdentity operatorIdentity,
SourcePublisher sourcePublisher, FirstLevelHashIdentity firstLevelHashIdentity) {
SourcePublisher sourcePublisher, FirstLevelHashIdentity firstLevelHashIdentity, int privacyBits) {
super(version, createdAt, expiresAt);
this.operatorIdentity = operatorIdentity;
this.sourcePublisher = sourcePublisher;
this.firstLevelHashIdentity = firstLevelHashIdentity;
this.privacyBits = privacyBits;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,15 @@
public class FirstLevelHashIdentity extends UserIdentity {
public final byte[] firstLevelHash;

public FirstLevelHashIdentity(IdentityScope identityScope, IdentityType identityType, byte[] firstLevelHash, int privacyBits,
Instant establishedAt, Instant refreshedAt) {
super(identityScope, identityType, privacyBits, establishedAt, refreshedAt);
// for brand new token generation, it should be the time it is generated
// if the first level hash is from token/refresh call, it will be when the raw UID was originally created in the earliest token generation
public final Instant establishedAt;

public FirstLevelHashIdentity(IdentityScope identityScope, IdentityType identityType, byte[] firstLevelHash,
Instant establishedAt) {
super(identityScope, identityType);
this.firstLevelHash = firstLevelHash;
this.establishedAt = establishedAt;
}

public boolean matches(FirstLevelHashIdentity that) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,8 @@
public class HashedDiiIdentity extends UserIdentity {
public final byte[] hashedDii;

public HashedDiiIdentity(IdentityScope identityScope, IdentityType identityType, byte[] hashedDii, int privacyBits,
Instant establishedAt, Instant refreshedAt) {
super(identityScope, identityType, privacyBits, establishedAt, refreshedAt);
public HashedDiiIdentity(IdentityScope identityScope, IdentityType identityType, byte[] hashedDii) {
super(identityScope, identityType);
this.hashedDii = hashedDii;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,8 @@
public class RawUidIdentity extends UserIdentity {
public final byte[] rawUid;

public RawUidIdentity(IdentityScope identityScope, IdentityType identityType, byte[] rawUid, int privacyBits,
Instant establishedAt, Instant refreshedAt) {
super(identityScope, identityType, privacyBits, establishedAt, refreshedAt);
public RawUidIdentity(IdentityScope identityScope, IdentityType identityType, byte[] rawUid) {
super(identityScope, identityType);
this.rawUid = rawUid;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,15 +10,9 @@ public abstract class UserIdentity {

public final IdentityScope identityScope;
public final IdentityType identityType;
public final int privacyBits;
public final Instant establishedAt;
public final Instant refreshedAt;

public UserIdentity(IdentityScope identityScope, IdentityType identityType, int privacyBits, Instant establishedAt, Instant refreshedAt) {
public UserIdentity(IdentityScope identityScope, IdentityType identityType) {
this.identityScope = identityScope;
this.identityType = identityType;
this.privacyBits = privacyBits;
this.establishedAt = establishedAt;
this.refreshedAt = refreshedAt;
}
}
46 changes: 27 additions & 19 deletions src/main/java/com/uid2/operator/service/EncryptedTokenEncoder.java
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ private byte[] encodeIntoAdvertisingTokenV2(AdvertisingTokenInput t, KeysetKey m

Buffer b2 = Buffer.buffer();
b2.appendLong(t.expiresAt.toEpochMilli());
encodeSiteIdentityV2(b2, t.sourcePublisher, t.rawUidIdentity, siteKey);
encodeSiteIdentityV2(b2, t.sourcePublisher, t.rawUidIdentity, siteKey, t.privacyBits, t.establishedAt);

final byte[] encryptedId = AesCbc.encrypt(b2.getBytes(), masterKey).getPayload();

Expand All @@ -53,9 +53,10 @@ private byte[] encodeIntoAdvertisingTokenV2(AdvertisingTokenInput t, KeysetKey m
private byte[] encodeIntoAdvertisingTokenV3(AdvertisingTokenInput t, KeysetKey masterKey, KeysetKey siteKey) {
final Buffer sitePayload = Buffer.buffer(69);
encodePublisherRequesterV3(sitePayload, t.sourcePublisher);
sitePayload.appendInt(t.rawUidIdentity.privacyBits);
sitePayload.appendLong(t.rawUidIdentity.establishedAt.toEpochMilli());
sitePayload.appendLong(t.rawUidIdentity.refreshedAt.toEpochMilli());
sitePayload.appendInt(t.privacyBits);
sitePayload.appendLong(t.establishedAt.toEpochMilli());
// this is the refreshedAt field in the spec - but effectively it is the time this advertising token is generated
sitePayload.appendLong(t.createdAt.toEpochMilli());
sitePayload.appendBytes(t.rawUidIdentity.rawUid); // 32 or 33 bytes

final Buffer masterPayload = Buffer.buffer(130);
Expand Down Expand Up @@ -126,8 +127,9 @@ private RefreshTokenInput decodeRefreshTokenV2(Buffer b) {
TokenVersion.V2, createdAt, validTill,
new OperatorIdentity(0, OperatorType.Service, 0, 0),
new SourcePublisher(siteId, 0, 0),
new FirstLevelHashIdentity(IdentityScope.UID2, IdentityType.Email, identity, privacyBits,
Instant.ofEpochMilli(establishedMillis), null));
new FirstLevelHashIdentity(IdentityScope.UID2, IdentityType.Email, identity,
Instant.ofEpochMilli(establishedMillis)),
privacyBits);
}

private RefreshTokenInput decodeRefreshTokenV3(Buffer b, byte[] bytes) {
Expand Down Expand Up @@ -160,7 +162,8 @@ private RefreshTokenInput decodeRefreshTokenV3(Buffer b, byte[] bytes) {

return new RefreshTokenInput(
TokenVersion.V3, createdAt, expiresAt, operatorIdentity, sourcePublisher,
new FirstLevelHashIdentity(identityScope, identityType, firstLevelHash, privacyBits, establishedAt, null));
new FirstLevelHashIdentity(identityScope, identityType, firstLevelHash, establishedAt),
privacyBits);
}

@Override
Expand Down Expand Up @@ -228,8 +231,9 @@ public AdvertisingTokenInput decodeAdvertisingTokenV2(Buffer b) {
Instant.ofEpochMilli(expiresMillis),
new OperatorIdentity(0, OperatorType.Service, 0, masterKeyId),
new SourcePublisher(siteId, siteKeyId, 0),
new RawUidIdentity(IdentityScope.UID2, IdentityType.Email, rawUid, privacyBits,
Instant.ofEpochMilli(establishedMillis), null)
new RawUidIdentity(IdentityScope.UID2, IdentityType.Email, rawUid),
privacyBits,
Instant.ofEpochMilli(establishedMillis)
);

} catch (Exception e) {
Expand All @@ -252,6 +256,7 @@ public AdvertisingTokenInput decodeAdvertisingTokenV3orV4(Buffer b, byte[] bytes
final SourcePublisher sourcePublisher = decodeSourcePublisherV3(sitePayload, 0);
final int privacyBits = sitePayload.getInt(16);
final Instant establishedAt = Instant.ofEpochMilli(sitePayload.getLong(20));
// refreshedAt is currently not used
final Instant refreshedAt = Instant.ofEpochMilli(sitePayload.getLong(28));
final byte[] rawUid = sitePayload.slice(36, sitePayload.length()).getBytes();
final IdentityScope identityScope = rawUid.length == 32 ? IdentityScope.UID2 : decodeIdentityScopeV3(rawUid[0]);
Expand All @@ -269,7 +274,8 @@ public AdvertisingTokenInput decodeAdvertisingTokenV3orV4(Buffer b, byte[] bytes

return new AdvertisingTokenInput(
tokenVersion, createdAt, expiresAt, operatorIdentity, sourcePublisher,
new RawUidIdentity(identityScope, identityType, rawUid, privacyBits, establishedAt, refreshedAt)
new RawUidIdentity(identityScope, identityType, rawUid),
privacyBits, establishedAt
);
}

Expand Down Expand Up @@ -304,7 +310,8 @@ public byte[] encodeIntoRefreshTokenV2(RefreshTokenInput t, KeysetKey serviceKey
// give an extra minute for clients which are trying to refresh tokens close to or at the refresh expiry timestamp
b.appendLong(t.expiresAt.plusSeconds(60).toEpochMilli());
b.appendInt(serviceKey.getId());
final byte[] encryptedIdentity = encryptIdentityV2(t.sourcePublisher, t.firstLevelHashIdentity, serviceKey);
final byte[] encryptedIdentity = encryptIdentityV2(t.sourcePublisher, t.firstLevelHashIdentity, serviceKey,
t.privacyBits);
b.appendBytes(encryptedIdentity);
return b.getBytes();
}
Expand All @@ -315,7 +322,7 @@ public byte[] encodeIntoRefreshTokenV3(RefreshTokenInput t, KeysetKey serviceKey
refreshPayload.appendLong(t.createdAt.toEpochMilli());
encodeOperatorIdentityV3(refreshPayload, t.operatorIdentity);
encodePublisherRequesterV3(refreshPayload, t.sourcePublisher);
refreshPayload.appendInt(t.firstLevelHashIdentity.privacyBits);
refreshPayload.appendInt(t.privacyBits);
refreshPayload.appendLong(t.firstLevelHashIdentity.establishedAt.toEpochMilli());
refreshPayload.appendByte(encodeIdentityTypeV3(t.firstLevelHashIdentity.identityScope, t.firstLevelHashIdentity.identityType));
refreshPayload.appendBytes(t.firstLevelHashIdentity.firstLevelHash);
Expand All @@ -330,9 +337,9 @@ public byte[] encodeIntoRefreshTokenV3(RefreshTokenInput t, KeysetKey serviceKey
}

private void encodeSiteIdentityV2(Buffer b, SourcePublisher sourcePublisher, RawUidIdentity rawUidIdentity,
KeysetKey siteEncryptionKey) {
KeysetKey siteEncryptionKey, int privacyBits, Instant establishedAt) {
b.appendInt(siteEncryptionKey.getId());
final byte[] encryptedIdentity = encryptIdentityV2(sourcePublisher, rawUidIdentity, siteEncryptionKey);
final byte[] encryptedIdentity = encryptIdentityV2(sourcePublisher, rawUidIdentity, siteEncryptionKey, privacyBits, establishedAt);
b.appendBytes(encryptedIdentity);
}

Expand Down Expand Up @@ -364,15 +371,16 @@ private String generateAdvertisingTokenString(AdvertisingTokenInput advertisingT
return bytesToBase64Token(advertisingTokenBytes, advertisingTokenInput.version);
}

private byte[] encryptIdentityV2(SourcePublisher sourcePublisher, FirstLevelHashIdentity firstLevelHashIdentity, KeysetKey key) {
return encryptIdentityV2(sourcePublisher, firstLevelHashIdentity.firstLevelHash, firstLevelHashIdentity.privacyBits,
private byte[] encryptIdentityV2(SourcePublisher sourcePublisher, FirstLevelHashIdentity firstLevelHashIdentity,
KeysetKey key, int privacyBits) {
return encryptIdentityV2(sourcePublisher, firstLevelHashIdentity.firstLevelHash, privacyBits,
firstLevelHashIdentity.establishedAt, key);
}

private byte[] encryptIdentityV2(SourcePublisher sourcePublisher, RawUidIdentity rawUidIdentity,
KeysetKey key) {
return encryptIdentityV2(sourcePublisher, rawUidIdentity.rawUid, rawUidIdentity.privacyBits,
rawUidIdentity.establishedAt, key);
KeysetKey key, int privacyBits, Instant establishedAt) {
return encryptIdentityV2(sourcePublisher, rawUidIdentity.rawUid, privacyBits,
establishedAt, key);
}


Expand Down
7 changes: 2 additions & 5 deletions src/main/java/com/uid2/operator/service/InputUtil.java
Original file line number Diff line number Diff line change
Expand Up @@ -261,14 +261,11 @@ public boolean isValid() {
return valid;
}

public HashedDiiIdentity toHashedDiiIdentity(IdentityScope identityScope, int privacyBits, Instant establishedAt) {
public HashedDiiIdentity toHashedDiiIdentity(IdentityScope identityScope) {
return new HashedDiiIdentity(
identityScope,
this.identityType,
getIdentityInput(),
privacyBits,
establishedAt,
establishedAt);
getIdentityInput());
}
}

Expand Down
Loading