Expand my Community achievements bar.

Applications for the 2024 Adobe Target Community Mentorship Program are open! Click to the right to learn more about participating as either an Aspirant, to professionally level up with a new Certification, or as a Mentor, to share your Adobe Target expertise and inspire through your leadership! Submit your application today.
SOLVED

Passing IP Address using Single Profile API

Avatar

Level 1

Hello,

I am calling the Single Profile API from many IP Address/GEO from across the globe.  Is this something that is supported by the Adobe servers.  Can I pass the IP address in the API call to ensure that the profile is updated in a timely fashion and properly targeted?  Please note that I am not targeting in Geo Location but have experienced delays in using the profile update API in the past.

 

Thanks!

1 Accepted Solution

Avatar

Correct answer by
Employee Advisor

Hi James,

I do not know of a method to pass the IP of a visitor into the API you are mentioning. However, you shouldn't need to. But if you prefer, you can send your profile update API call to the Target server where that visitor's profile lives. This works well if you are using the PCID update method. The mboxPC will identify which server to update.

For example, mboxPC=1368007744041-575948.01_00 the 2 digits between the "." and the "_" are the server ID of that visitor. You can make your API call directly to that server using this host: mboxedge01.tt.omtrdc.net. Where the "01" matches the server ID portion of the mboxPC.

This isn't required. Target servers will propogate the profiles from server to server as needed, but it will probably give you a better update time.

View solution in original post

8 Replies

Avatar

Correct answer by
Employee Advisor

Hi James,

I do not know of a method to pass the IP of a visitor into the API you are mentioning. However, you shouldn't need to. But if you prefer, you can send your profile update API call to the Target server where that visitor's profile lives. This works well if you are using the PCID update method. The mboxPC will identify which server to update.

For example, mboxPC=1368007744041-575948.01_00 the 2 digits between the "." and the "_" are the server ID of that visitor. You can make your API call directly to that server using this host: mboxedge01.tt.omtrdc.net. Where the "01" matches the server ID portion of the mboxPC.

This isn't required. Target servers will propogate the profiles from server to server as needed, but it will probably give you a better update time.

Avatar

Level 1

Hello,

Thank you for your response.  I was wondering if the requestLocation.ipAddress found here  (https://docs.adobe.com/dev/products/target/reference/delivery.html) would help.  

Any thoughts?

 

Thanks!

Avatar

Employee Advisor

Ah, that is for content delivery. If you have a server-side implemenation of Target and you want Target to use the end users IP (rather than your server's IP) to perform geo segmentation off of you can add that to a deliver API call. It doesn't apply to the profile update API though.

Avatar

Level 1

Ah I see thank you for clarifying.  Do you know what delay times are to be expected when using the profile update API?

Avatar

Employee Advisor

james hartley wrote...

...Do you know what delay times are to be expected when using the profile update API?

 

When you use the mboxedge## subdomain method I describe above, updates should be real time. I just tested and verified this. If you don't use the mboxedge## subdomain I would guess that could be 30 min for updates to propigate to the other servers, if needed. Though I haven't tested this one personally for timing.

Using the mboxTrace debugging tool (https://marketing.adobe.com/resources/help/en_US/target/target/c_content_trouble.html) I can see my API profile is updated.

You can see I named my attribute: profile.apiUpdateAttr. You don't see the "profile." portion in the mbox trace view, but it is required in the API call. I just posted a date and time as my attribute value.

Avatar

Level 1

Thanks again!  I have a few follow-up questions.

Currently I am referencing the following host. mycompanyname.tt.omtrdc.net.

It sounds like we should be using mboxedge01.tt.omtrdc.net.  If so, how is the user properly associated to my account?  Additionally, how many regions are there? 

Avatar

Employee Advisor

Using the host: mycompanyname.tt.omtrdc.net is a valid method. If desired you can update the profile directly where it resides with the mboxedge##.tt.omtrdc.net host. In North America there are at least 3 different servers, more globally though I don't have the exact number.

The user is still associated with your account because the folder, not the subdomain defines this. See the example API Profile Update call from the documentation:

https://CLIENT.tt.omtrdc.net/m2/CLIENT/profile/update?mboxPC=1368007744041-575948.01_00&profile.attr=0

Avatar

Level 1

Hi Ryan,


Thanks for your continued assistance.  I have tested this a number of times with varying degrees of success and I am interested in your opinion.

Using the application Postman I tested the following call to the profile update API while in the Tokyo region and saw realtime updates to my profile in the browser console.  However when returning to the U.S. I replicated the same call (updating PC and sessions IDs, server ID of course) but have had no luck getting a customer profile param to appear in the console debug.  Any thoughts?

1230709_pastedImage_1.png