apple_search_ads 0.0.7 copy "apple_search_ads: ^0.0.7" to clipboard
apple_search_ads: ^0.0.7 copied to clipboard

A Dart package to interact with the Apple Search Ads API using OAuth 2.0 authentication.

Apple Search Ads Dart Package #

A Dart package to interact with the Apple Search Ads API using OAuth 2.0 authentication.

Features #

  • Authenticate with Apple Search Ads API
  • Generate JWT-based client secrets

Getting Started #

Add this to your package's pubspec.yaml file:

dependencies:
  apple_search_ads: ^0.0.7
copied to clipboard

Apple Search Ads API - Private and Public Key Generation #

This guide will walk you through the process of generating a private key, extracting a public key, and uploading the public key to your Apple Search Ads account. This is essential for managing secure access to your Search Ads accounts via the Apple Search Ads API.

Prerequisites #

  • OpenSSL: You need OpenSSL installed on your machine.
  • macOS/UNIX: OpenSSL comes pre-installed.
  • Windows: You need to download and install OpenSSL.

Step 1: Generate a Private Key #

To generate a private key using the Elliptic Curve Digital Signature Algorithm (ECDSA), run the following command:

openssl ecparam -genkey -name prime256v1 -noout -out private-key.pem
copied to clipboard

Parameters #

  • name: Specifies the curve name. Use prime256v1 for the ECDSA algorithm.
  • out: The filename where the generated key will be stored (e.g., private-key.pem).

Example Output #

The generated private-key.pem file should resemble the following. Example private key like this:

-----BEGIN EC PRIVATE KEY-----
 ---YOUR-PRIVATE-KEY----
-----END EC PRIVATE KEY-----
copied to clipboard
  • Important: Always keep your private key secure and never share it. If your private key becomes compromised, you need to re-create a private key and client secret, and reupload it to your Apple Search Ads account.

Step 2: Extract a Public Key #

To extract the public key from the private key, use the following command:

openssl ec -in private-key.pem -pubout -out public-key.pem
copied to clipboard

Parameters #

  • in: The filename of the private key (private-key.pem).
  • out: The filename where the extracted public key will be stored (public-key.pem).

Example Output #

Open the public-key.pem file in a text editor. It should look like this:

-----BEGIN PUBLIC KEY-----
MHYwEAYHKoZIzj0CAQYFK4EEACIDYgAEOuKrT6zrIYzVdp/BzGrfTNoiJBdG/bn8
8yFSdfjl8e5QAS9KkNHkOiMZJo5D8gIKSCbYJffb4JzQlMYNhXzZbD2CBZ71gjTy
UVAlPDSBniSgthzUn8nlTJKLxPbJ5Tkkg3k06YZJWnkV
-----END PUBLIC KEY-----
copied to clipboard

Step 3: Upload the Public Key #

  1. From the Search Ads UI, navigate to Account Settings > API.
  2. Paste the contents of the public-key.pem file (including the BEGIN and END lines) into the Public Key field.
  3. Click Save.

After saving, a group of credentials (including clientId, teamId, and keyId) will be displayed above the public key field. Use these credentials to create a client secret.

Credentials Example #

clientId: SEARCHADS.---
teamId: SEARCHADS.---
keyId: ---
copied to clipboard

If you need to make edits to the public key, go to Account Settings > API > Edit.

Step 4: Store Your Key Pair #

Copy both your private key (private-key.pem) and public key (public-key.pem) into your working directory for safe keeping. Always ensure these files are stored securely.

For more information, visit the Apple Developer Documentation.

Usage #

import 'package:apple_search_ads/apple_search_ads.dart';

Future<void> main() async {
  final authenticator = AppleSearchAdsAuthenticator(
    clientId: "YOUR_CLIENT_ID",
    teamId: "YOUR_TEAM_ID",
    orgId: "YOUR-ORG-ID",
    keyId: "YOUR_KEY_ID",
    keyContent: "YOUR_PRIVATE_KEY",
    verbose: true,
  );

  final accessToken = await authenticator.authenticate();
  if (accessToken != null) {
    print("Authenticated successfully with access token: $accessToken");
  } else {
    print("Failed to authenticate");
  }
}
copied to clipboard
3
likes
140
points
33
downloads

Publisher

unverified uploader

Weekly Downloads

2024.07.06 - 2025.01.18

A Dart package to interact with the Apple Search Ads API using OAuth 2.0 authentication.

Repository (GitHub)
View/report issues

Documentation

API reference

License

MIT (license)

Dependencies

dart_jsonwebtoken, flutter, http, json_annotation

More

Packages that depend on apple_search_ads