advertising_oaid/README.md

125 lines
3.7 KiB
Markdown
Raw Normal View History

# OAID Service Component
2023-09-01 08:05:21 +00:00
## Introduction
2023-09-01 08:05:21 +00:00
The Open Anonymous Device Identifier (OAID) service facilitates personalized ad placement based on OAIDs, each of which is a non-permanent device identifier. The service provides personalized ads for users while protecting their personal data privacy. It can also interact with third-party tracking platforms to provide conversion attribution analysis for advertisers.
2023-09-01 08:05:21 +00:00
## Directory Structure
```
/domains/advertising/oaid # Service code of the OAID service component
├── interfaces # API code
├── profile # Service configuration profile
├── services # Service code
├── test # Test cases
├── LICENSE # License file
└── bundle.json # Build file
```
## How to Use
### Obtaining an OAID
You can use the APIs provided in this repository to obtain OAIDs.
1. Request the ad tracking permission.
Configure the [ohos.permission.APP_TRACKING_CONSENT](https://docs.openharmony.cn/pages/v4.0/zh-cn/application-dev/security/permission-list.md/) permission in the **module.json5** file of the module.
```javascript
{
"module": {
"requestPermissions": [
{
"name": "ohos.permission.APP_TRACKING_CONSENT" // Request the ad tracking permission.
}
]
}
}
```
2. Request authorization from the user by displaying a dialog box when the application is started.
```javascript
import abilityAccessCtrl from '@ohos.abilityAccessCtrl';
private requestOAIDTrackingConsentPermissions(context: any): void {
// Display a dialog box when the page is displayed to request the user to grant the ad tracking permission.
const atManager = abilityAccessCtrl.createAtManager();
try {
atManager.requestPermissionsFromUser(context, ["ohos.permission.APP_TRACKING_CONSENT"]).then((data) => {
if (data.authResults[0] == 0) {
console.info(`request permission success`);
} else {
console.info(`user rejected`);
}
}).catch((err) => {
console.error(`request permission failed, error message: ${err.message}`);
})
} catch(err) {
console.error(`catch err->${JSON.stringify(err)}`);
}
}
```
3. Obtain an OAID.
- Obtain an OAID through the callback function.
```javascript
import identifier from '@ohos.identifier.oaid';
private getOaidByCallback() {
try {
identifier.getOAID((err, data) => {
if (err.code) {
console.info(`getAdsIdentifierInfo failed, message: ${err.message}`);
} else {
const oaid = data;
console.error(`getOaidFromOaidSaAPi by callback success`);
}
});
} catch (err) {
console.error(`catch err->${JSON.stringify(err)}`);
}
}
```
- Obtain an OAID through the promise.
```javascript
import identifier from '@ohos.identifier.oaid';
private getOaidByPromise() {
try {
// Obtain an OAID.
identifier.getOAID().then((data) => {
const oaid = data;
console.info(`getAdsIdentifierInfo by promise success`);
}).catch((err) => {
console.error(`getAdsIdentifierInfo failed, message: ${err.message}`);
})
} catch (err) {
console.error(`catch err->${JSON.stringify(err)}`);
}
}
```
### Resetting the OAID
You can use the API provided in this repository to reset OAIDs. The API is a system API.
```javascript
import identifier from '@ohos.identifier.oaid';
private resetOaid() {
try {
identifier.resetOAID();
} catch (err) {
console.error(`reset oaid catch error: ${err.code} ${err.message}`);
}
}
```
## Repositories Involved