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

PAIR: Support for Generic TechLab Version #12146 #12599

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

therevoltingx
Copy link

@therevoltingx therevoltingx commented Dec 19, 2024

Documentation PR

prebid/prebid.github.io#5785

Storage or Cookie

localStorage.setItem(
  'pairId',
  btoa(JSON.stringify(['my-pair-id']))
);

Clean Room Configuration

{
    userSync: {
      userIds: [{
        name: 'openPairId',
        inserter: 'some-domain.com',
        matcher: 'another-domain.com',
        params: {
          liveramp: {
            storageKey: '_lr_pairId'
          },
          habu: {
            storageKey: '_habu_pairId'
          }
       },
    }]
  }
}

Bid Request

{
  "ext": {
    "eids": [
      source: "pair-protocol.com",
      mm: 3,
      inserter: 'some-domain.com',
      matcher: 'another-domain.com',  
      "uids": [
        {
          "id": "0x1234", // using clean room A
          "atype": 3
        },
        {
          "id": "0x456", // using clean room B
          "atype": 3
        }
      ]
    ]
  }
}

return undefined;
}

return {'id': ids};
Copy link
Collaborator

@dgirardi dgirardi Dec 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this requires some more logic to be converted into an EID - the userId module expects a string either from decode, or from eids.openPairId.getValue(id) eids.pairId.getValue(id) (because that's what referenced in decode - see other comment below)

From my testing (putting some random data in local storage), this does not generate any EID.

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Seems that other modules return a hash in this format, including the original pairId and a few other examples:

return {'id': ids};

return {id: res};

return {id: newId, callback: getIdCallback(newId, pixelUrl)};
return {id: localValue};

I think your test was failing because I was not properly exporting the correct module. Do you mind testing again?

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, the return value should be an object with id and/or callback. I was referring to the contents of id. But I did miss that it can also be an array of strings, which seems to be true in your case if the test fixtures are realistic.

You're likely correct that the problem was just the module identifier.

The id returned from here is passed through decode and used to generate the EID. If you want to test it without setting up the entire system, you could do something like

const id = {id: ['test-pair-id7', 'test-pair-id8', 'test-pair-id9']} 
// if the above is the return value from `getId`, then the corresponding EIDs are
const eids = createEidsArray(openPairIdSubmodule.decode(id.id), new Map(Object.entries(openPairIdSubmodule.eids)))

With createEidsArray from here

Copy link
Collaborator

@dgirardi dgirardi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I also recommend merging or rebasing with master, there's been quite a few changes to userId since this PR's parent.

* @returns {{pairId:string} | undefined }
*/
decode(value) {
return value && Array.isArray(value) ? {'pairId': value} : undefined
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This should be openPairId - if it's meant to be distinct from the other module - or if they're meant to be mutually exclusive (clashes are not a problem), the EID configuration in this should also use pairId.

@therevoltingx therevoltingx force-pushed the feature/adds-generic-pair branch from 3ff3e51 to 73e6c68 Compare December 23, 2024 09:42
@therevoltingx
Copy link
Author

@dgirardi I've gone ahead and rebased and addressed your comments. Please review again.

@patmmccann
Copy link
Collaborator

@therevoltingx your unit tests are failing; this isnt yet ready for review

@therevoltingx
Copy link
Author

@patmmccann my unit tests are passing on my end:

gulp test --modules=openPairIdSystem --file ./test/spec/modules/pairIdSystem_spec.js

What is failing for you?

@therevoltingx
Copy link
Author

gulp test seems to fail. do i need to add the submodule manually somewhere, seems to be a problem with loading the submodule within the spec

@patmmccann
Copy link
Collaborator

patmmccann commented Dec 26, 2024

If you click details next to the red x below, it has details on the failed tests

@patmmccann
Copy link
Collaborator

gulp test seems to fail. do i need to add the submodule manually somewhere, seems to be a problem with loading the submodule within the spec

Submodules.json

@therevoltingx
Copy link
Author

@patmmccann ok i have rebased with latest master and also tests are passing now!

@therevoltingx therevoltingx force-pushed the feature/adds-generic-pair branch 2 times, most recently from c5f58b9 to 6a6f7c1 Compare December 29, 2024 08:29
@patmmccann patmmccann requested a review from dgirardi December 30, 2024 19:54
@patmmccann
Copy link
Collaborator

can you add changes to .submodules.json?

Copy link
Collaborator

@patmmccann patmmccann left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please add coverage on the eid you expect getting formed

@therevoltingx
Copy link
Author

@patmmccann ok i've added a test for createEidsArray this is similar to what i saw in other ID modules. If this is not the test you were looking for please link me to a similar test in user module.

Thanks.

@therevoltingx therevoltingx force-pushed the feature/adds-generic-pair branch 3 times, most recently from a019874 to 99f5b66 Compare January 14, 2025 23:03
@therevoltingx therevoltingx force-pushed the feature/adds-generic-pair branch 2 times, most recently from 99bfe9e to 57123ff Compare January 17, 2025 00:00
@therevoltingx therevoltingx force-pushed the feature/adds-generic-pair branch from 57123ff to 6ced3b0 Compare January 17, 2025 00:05
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants