Skip to main content

Set targeting in diffrent advertisment platforms.

Project description

Targeting Platform

Pypi Version Python Version License

Prerequsites

To use module following tools need to be configured:

  • Redis - is used for caching platform information (catalog of lineitems/adgroups e.g.) and locks. It depends on amount of information in your platform but as a starting point 1Gb memory will be enough. For now only single entrypoint is supported. Prefix for cache keys is PLATFORM_CACHE_ (set in CACHE_KEYS_PREFIX) and for locks PLATFORM_LOCK_ (LOCK_KEYS_PREFIX).

Credentials for platforms

Each platform has it's own format of credentials. You need to obtaint credetantial before starting to use platforms thorugh this module.

DV360 (dv360)

Requires service account private key (whole JSON for service account). E.g.

{
    "type": "service_account",
    "project_id": "",
    "private_key_id": "",
    "private_key": "-----BEGIN PRIVATE KEY-----\n\n-----END PRIVATE KEY-----\n",
    "client_email": "",
    "client_id": "",
    "auth_uri": "https://accounts.google.com/o/oauth2/auth",
    "token_uri": "https://oauth2.googleapis.com/token",
    "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
    "client_x509_cert_url": ""
}

Meta (Facebook) (meta)

Example of credentails (app_scoped_system_user_id is required for detailed access validation):

{
    "access_token": "",
    "app_scoped_system_user_id":
}

The Trade Desk (ttd)

Example of credentials (login and password is required for automatic token renewal):

{
    "PartnerId": "",
    "token": "",
    "Login": "",
    "Password": ""
}

Platforms

DV360

Library works as with normal lineitems as with YouTube through SDF. In case of passing lineitem id for YouTube (in array all ids should be either for normal or YouTube lineitems) methods will return Pandas DataFrame with prepared data - you need to get CSV from it and manually upload to Google.

Meta

While testing/using you can receive Rate Limit (set by Meta Marketing API) - you need to monitor your limits before operations. For current implementaion (probably will be chnaged in future releases) there is no retries and exceptions - you simply get empty result (means set/chnaged nothing).

The Trade Desk (TTD)

Setting locations (geofence) in Data Groups can take a time - about 45 minutes. It is how TTD operates - it takes seconds to create thousands of points in geofences, but about an hour while they will be availible to use (TTD API). In code we have expponential retries to repeat operations till success (do not be confused - 403 error does aslo mean "we can't find geofence" in terms of TTD) - so all you need to wait.

How to use

See examples in integration tests.

You can adopt these tests by placing appropriate sectet files into folder secrets.

Locks

To prevent simultanous updating of the same placements in the platform locks are used. While you are calling clear, pause, delete and set operations lock will be acquired and released in the end of the operation (or after 1 hour in case of any error). If method can't acquire lock it will return empty results (no exception raised).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

targeting_platform-0.3.4.tar.gz (45.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

targeting_platform-0.3.4-py3-none-any.whl (46.7 kB view details)

Uploaded Python 3

File details

Details for the file targeting_platform-0.3.4.tar.gz.

File metadata

  • Download URL: targeting_platform-0.3.4.tar.gz
  • Upload date:
  • Size: 45.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.6

File hashes

Hashes for targeting_platform-0.3.4.tar.gz
Algorithm Hash digest
SHA256 ca8c4e9f0ec4860d3a11b6eaa12c0b6adb97be9ed383b566a772d292b2996ecd
MD5 0057131efa5a01fb20acebc98a59651d
BLAKE2b-256 09accbc744a4d5c0234b123f5bc3b9fa28f4bc8457864ee0aa1d3b57cec8bc6d

See more details on using hashes here.

File details

Details for the file targeting_platform-0.3.4-py3-none-any.whl.

File metadata

File hashes

Hashes for targeting_platform-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ef8313a51ba88cdda46a7a39a8240f6d97603103bf362cd17cebfc4a02430cbf
MD5 a41d210612235a8c2565964ef7a2733e
BLAKE2b-256 ae3e3cd41dee5e4d3a10711f08cecacdda7ff29b46d9314d86c7b01642fa58dc

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page