apple_search_ads 0.0.6 apple_search_ads: ^0.0.6 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.6
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
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-----
- 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
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-----
Step 3: Upload the Public Key #
- From the Search Ads UI, navigate to
Account Settings > API
. - Paste the contents of the
public-key.pem
file (including theBEGIN
andEND
lines) into the Public Key field. - 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: ---
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");
}
}