---
title: "Analitik entegrasyonları"
description: "Kullanıcı aboneliklerini takip etmek ve optimize etmek için analitik araçlarını Adapty ile entegre edin."
---

Adapty, tüm [abonelik olaylarını](events) [Amplitude](amplitude), [Mixpanel](mixpanel) ve [AppMetrica](appmetrica) gibi analitik servislere gönderir. Ayrıca [webhook](webhook) entegrasyonu aracılığıyla olayları sunucunuza da iletebiliriz. En güzel yanı şu: olayları siz göndermek zorunda değilsiniz, bunu bizim yerinize yapıyoruz. Tek yapmanız gereken entegrasyonu Adapty Kontrol Paneli'nde yapılandırmak.

Adapty aşağıdaki üçüncü taraf analitik servisleriyle entegrasyonu destekler:

- [Amplitude](amplitude)
- [AppMetrica](appmetrica)
- [Firebase ve Google Analytics](firebase-and-google-analytics)
- [Mixpanel](mixpanel)
- [PostHog](posthog)
- [SplitMetrics Acquire](splitmetrics)

:::note
Analitik sağlayıcınızı görmüyor musunuz?

Bize bildirin! [Özellik talebi oluşturun](https://adapty.featurebase.app/en?b=6979f233ebd3cffd4f425ba0), eklemeyi değerlendirelim.
:::

## Olay özellikleri \{#event-properties\}

Webhook olayları JSON formatında gönderilir. Tüm olaylar aynı yapıyı izler; ancak alanlar olay türüne, mağazaya ve özel yapılandırmanıza göre farklılık gösterir.

| Özellik                       | Tür           | Açıklama                                                     |
| ----------------------------- | ------------- | ------------------------------------------------------------ |
| **profile_id**                | uuid          | Adapty kullanıcı ID'si.                                      |
| **currency**                  | str           | Yerel para birimi (varsayılan USD).                          |
| **price_usd**                 | float         | Apple/Google payı düşülmeden önceki ürün fiyatı. Gelir.     |
| **proceeds_usd**              | float         | Apple/Google payı düşüldükten sonraki ürün fiyatı. Net gelir. |
| **net_revenue_usd**           | float         | USD cinsinden net gelir (Apple/Google payı ve vergiler düşüldükten sonraki kazanç). Boş olabilir. |
| **price_local**               | float         | Yerel para biriminde Apple/Google payı düşülmeden önceki ürün fiyatı. Gelir. |
| **proceeds_local**            | float         | Yerel para biriminde Apple/Google payı düşüldükten sonraki ürün fiyatı. Net gelir. |
| **transaction_id**            | str           | Satın alma veya yenileme gibi bir işlem için benzersiz tanımlayıcı. |
| **original_transaction_id**   | str           | Orijinal satın almanın işlem tanımlayıcısı.                  |
| **purchase_date**             | ISO 8601 date | Ürün satın alma tarihi ve saati.                             |
| **original_purchase_date**    | ISO 8601 date | Orijinal satın almanın tarihi ve saati.                      |
| **environment**               | str           | _Sandbox_ veya _Production_ olabilir.                        |
| **vendor_product_id**         | str           | Apple App Store, Google Play Store veya Stripe'taki ürün ID'si. |
| **base_plan_id**              | str           | Google Play Store'daki [temel plan ID'si](https://support.google.com/googleplay/android-developer/answer/12154973) veya Stripe'taki [fiyat ID'si](https://docs.stripe.com/products-prices/how-products-and-prices-work#use-products-and-prices). |
| **event_datetime**            | ISO 8601 date | Olayın tarihi ve saati.                                      |
| **store**                     | str           | _app_store_ veya _play_store_ olabilir.                      |
| **trial_duration**            | str           | Deneme süresinin gün cinsinden uzunluğu. "{} days" formatında gönderilir; örneğin "7 days". |
| **cancellation_reason**       | str           | <p>Kullanıcının aboneliği iptal etme nedeni.</p><p></p><p>Olabilecek değerler:</p><p>iOS & Android</p><p>_voluntarily_cancelled_, _billing_error_, _refund_</p><p>iOS</p><p>_price_increase_, _product_was_not_available_, _unknown_</p><p>Android</p><p>_new_subscription_replace_, _cancelled_by_developer_</p> |
| **subscription_expires_at**   | ISO 8601 date | Abonelik bitiş tarihi. Genellikle gelecekte bir tarihtir.    |
| **consecutive_payments**      | int           | Kullanıcının kesintisiz abone olduğu dönem sayısı. Mevcut dönemi de içerir. |
| **rate_after_first_year**     | bool          | Aboneliğin bir yıllık kesintisiz yenilemeden sonra indirimli komisyon oranına (%15) hak kazandığını gösteren boolean. Komisyon oranları programa uygunluk ve ülkeye göre değişir. Ayrıntılar için [Mağaza komisyonu ve vergileri](controls-filters-grouping-compare-proceeds#store-commission-and-taxes) bölümüne bakın. |
| **promotional_offer_id**      | str           | Adapty Kontrol Paneli'nin Ürün bölümünde belirtilen promosyon teklifi ID'si. |
| **store_offer_category**      | str           | _introductory_ veya _promotional_ olabilir.                  |
| **store_offer_discount_type** | str           | _free_trial_, _pay_as_you_go_ veya _pay_up_front_ olabilir.  |
| **paywall_name**              | str           | İşlemin gerçekleştiği paywall'ın adı.                        |
| **paywall_revision**          | int           | İşlemin gerçekleştiği paywall'ın revizyonu. Değer 1 olarak ayarlanır. |
| **developer_id**              | str           | İşlemin gerçekleştiği placement'ın geliştirici (SDK) ID'si.  |
| **ab_test_name**              | str           | İşlemin gerçekleştiği A/B testinin adı.                      |
| **ab_test_revision**          | int           | İşlemin gerçekleştiği A/B testinin revizyonu. Değer 1 olarak ayarlanır. |
| **cohort_name**               | str           | Profilin ait olduğu kitlenin adı.                            |
| **profile_event_id**          | uuid          | Tekilleştirme için kullanılabilecek benzersiz olay ID'si.    |
| **store_country**             | str           | Mağaza tarafından bize gönderilen ülke.                      |
| **profile_ip_address**        | str           | Profil IP adresi (IPv4 veya IPv6 olabilir; mevcut olduğunda IPv4 tercih edilir). Cihazın IP'si her değiştiğinde güncellenir. |
| **profile_country**           | str           | Adapty tarafından profil IP'sine göre belirlenir.            |
| **profile_total_revenue_usd** | float         | İadeler dahil olmak üzere profil için toplam gelir.          |
| **variation_id**              | uuid          | Satın almanın yapıldığı paywall'ın benzersiz ID'si.          |
| **access_level_id**           | str           | Ücretli access level ID'si.                                  |
| **is_active**                 | bool          | Profil için ücretli access level'ın aktif olup olmadığını gösteren boolean. |
| **will_renew**                | bool          | Ücretli access level'ın yenilenip yenilenmeyeceğini gösteren boolean. |
| **is_refund**                 | bool          | İşlemin iade edilip edilmediğini gösteren boolean.           |
| **is_lifetime**               | bool          | Ücretli access level'ın süresiz erişim olup olmadığını gösteren boolean. |
| **is_in_grace_period**        | bool          | Profilin ek sürede olup olmadığını gösteren boolean.         |
| **starts_at**                 | ISO 8601 date | Kullanıcı için ücretli access level'ın başladığı tarih ve saat. |
| **renewed_at**                | ISO 8601 date | Ücretli erişimin yenileneceği tarih ve saat.                 |
| **expires_at**                | ISO 8601 date | Ücretli erişimin sona ereceği tarih ve saat.                 |
| **activated_at**              | ISO 8601 date | Ücretli erişimin etkinleştirildiği tarih ve saat.            |
| **billing_issue_detected_at** | ISO 8601 date | Ödeme sorunun tespit edildiği tarih ve saat.                 |
| **profile_has_access_level**  | Bool          | Profilin aktif bir access level'a sahip olup olmadığını gösteren boolean (yalnızca Webhook). |

Her olay şu özelliklere sahiptir:

`transaction_id, original_transaction_id, purchase_date, original_purchase_date, environment, vendor_product_id, event_datetime, store`. 

Bunların yanı sıra bazı olaylar ek özellikler içerir. `subscription_refunded` ve `non_subscription_purchase_refunded` olayları için `price_usd` ve `proceeds_usd` değerlerinin ek özellik olarak sağlanması zorunludur.

| Olay Adı                            | Özellikler                                                   |
| :---------------------------------- | :----------------------------------------------------------- |
| **subscription\_initial\_purchase** | price\_usd, proceeds\_usd, subscription\_expires\_at, consecutive\_payments, rate\_after\_first\_year, trial\_duration |
| **subscription\_renewed**           | price\_usd, proceeds\_usd, subscription\_expires\_at, consecutive\_payments, rate\_after\_first\_year, trial\_duration |
| **subscription\_cancelled**         | cancellation\_reason, trial\_duration                        |
| **trial\_started**                  | subscription\_expires\_at, trial\_duration                   |
| **trial\_converted**                | price\_usd, proceeds\_usd, subscription\_expires\_at, consecutive\_payments, rate\_after\_first\_year, trial\_duration |
| **trial\_cancelled**                | cancellation\_reason, trial\_duration                        |
| **non\_subscription\_purchase**     | price\_usd, proceeds\_usd                                    |
| **billing\_issue\_detected**        | subscription\_expires\_at, trial\_duration                   |
| **entered\_grace\_period**          | subscription\_expires\_at, trial\_duration                   |

Olay örneği

```json title="Json"
{
    "price_usd": 9.99,
    "proceeds_usd": 6.99,
    "transaction_id": "1000000628581600",
    "original_transaction_id": "1000000628581600",
    "purchase_date": "2020-02-18T18:40:22.000000+0000",
    "original_purchase_date": "2020-02-18T18:40:22.000000+0000",
    "environment": "Sandbox",
    "vendor_product_id": "premium",
    "event_datetime": "2020-02-18T18:40:22.000000+0000",
    "store": "app_store"
}
```

Adapty olayları sunucunuza ve üçüncü taraf analitik sistemlere gönderir.

**profile_ip_address** özelliği mevcut cihaz IP'siyle senkronize edilir. Adapty sunucuları SDK'dan bilgi aldığında, kayıtlarımızdakinden farklıysa IP güncellenecektir.

### Profil tanımlayıcısını ayarlama \{#setting-the-profiles-identifier\}

- Seçilen analitik için profil tanımlayıcısını <InlineTooltip tooltip="uygulamanızda kullanıcı özelliklerini ayarlama talimatları">[iOS](setting-user-attributes), [Android](android-setting-user-attributes), [React Native](react-native-setting-user-attributes), [Flutter](flutter-setting-user-attributes) ve [Unity](unity-setting-user-attributes)</InlineTooltip> kullanarak ayarlayın.

:::warning
Tekrarlamayı önleme

Tekrarlamayı önlemek için cihazlardan ve sunucunuzdan abonelik olaylarının gönderilmesini devre dışı bırakmayı unutmayın.
:::

### Belirli bir müşteri için harici analitiği devre dışı bırakma \{#disabling-external-analytics-for-a-specific-customer\}

Belirli bir müşteri için analitik olaylarının gönderilmesini durdurmak isteyebilirsiniz. Bu, uygulamanızda analitik servislerinden çıkış seçeneği sunduğunuzda kullanışlıdır.

Bir müşteri için harici analitiği devre dışı bırakmak üzere `updateProfile()` metodunu kullanın. `AdaptyProfileParameters.Builder` nesnesi oluşturun ve ilgili değeri ayarlayın.  
Harici analitik engellendiğinde, Adapty belirli kullanıcı için hiçbir entegrasyona olay göndermez. Uygulamanızdaki tüm kullanıcılar için bir entegrasyonu devre dışı bırakmak istiyorsanız Adapty Kontrol Paneli'nden kapatmanız yeterlidir.

<Tabs groupId="current-os" queryString>
<TabItem value="swift" label="Swift" default>
```swift showLineNumbers
let builder = AdaptyProfileParameters.Builder()
    .with(analyticsDisabled: true)

Adapty.updateProfile(parameters: builder.build())
```
</TabItem>
<TabItem value="kotlin" label="Kotlin" default>
```kotlin showLineNumbers
val parameters = AdaptyProfileParameters(
    analyticsDisabled = true
)

Adapty.updateProfile(parameters) { error ->
    if (error == null) {
        // successful update
    }
}
```
</TabItem>
<TabItem value="java" label="Java" default>
```java showLineNumbers ]
AdaptyProfileParameters.Builder builder = new AdaptyProfileParameters.Builder()
    .withExternalAnalyticsDisabled(true);

Adapty.updateProfile(builder.build());
```
</TabItem>
<TabItem value="flutter" label="Flutter" default>
```javascript showLineNumbers
final builder = AdaptyProfileParametersBuilder()
  ..setAnalyticsDisabled(true);

try {
  await Adapty().updateProfile(builder.build());
} on AdaptyError catch (adaptyError) {
  // handle the error
} catch (e) {
}
```
</TabItem>
<TabItem value="unity" label="Unity" default>
```csharp showLineNumbers
var builder = new AdaptyProfileParameters.Builder()
    .SetAnalyticsDisabled(true);

Adapty.UpdateProfile(builder.Build(), (error) => {
    if(error != null) {
      // handle the error
    }
});
```
</TabItem>
<TabItem value="rn" label="React Native (TS)" default>
```typescript showLineNumbers
adapty.updateProfile({ analyticsDisabled: true });
```
</TabItem>
</Tabs>

### Reklam tanımlayıcısı toplamayı devre dışı bırakma \{#disable-collection-of-advertising-identifiers\}

<Tabs groupId="current-os" queryString>
<TabItem value="swift" label="iOS" default>
`idfaCollectionDisabled` özelliğini kullanarak IDFA toplamayı devre dışı bırakabilirsiniz. `.activate()` metodundan önce çağırdığınızdan emin olun.

```swift showLineNumbers
// In your AppDelegate class:

let configurationBuilder =
    AdaptyConfiguration
        .builder(withAPIKey: "PUBLIC_SDK_KEY")
 // highlight-start
        .with(idfaCollectionDisabled: true) // set to `true`
// highlight-end

Adapty.activate(with: configurationBuilder.build()) { error in
  // handle the error
}
```
</TabItem>

<TabItem value="kotlin" label="Android (Kotlin)" default>
Adapty SDK'yı etkinleştirirken `withAdIdCollectionDisabled` özelliğini kullanarak AAID/GAID toplamayı devre dışı bırakabilirsiniz:

```swift showLineNumbers
override fun onCreate() {
    super.onCreate()
    Adapty.activate(
      applicationContext,
      AdaptyConfig.Builder("PUBLIC_SDK_KEY")
      // highlight-start
          .withAdIdCollectionDisabled(true) // set to `true`
      // highlight-end
          .build()
    )  
}
```

</TabItem>

<TabItem value="java" label="Android (Java)" default>
Adapty SDK'yı etkinleştirirken `withAdIdCollectionDisabled` özelliğini kullanarak AAID/GAID toplamayı devre dışı bırakabilirsiniz:

```swift showLineNumbers 
@Override
public void onCreate() {
    super.onCreate();
    Adapty.activate(
      applicationContext,
      new AdaptyConfig.Builder("PUBLIC_SDK_KEY")
      // highlight-start
          .withAdIdCollectionDisabled(true) // set to `true`
      // highlight-end
          .build()
    );
}
```

</TabItem>

<TabItem value="flutter" label="Flutter" default>
`withAppleIdfaCollectionDisabled` özelliğiyle IDFA toplamayı, `withGoogleAdvertisingIdCollectionDisabled` özelliğiyle de Google/Android Reklam ID'si toplamayı devre dışı bırakabilirsiniz. Adapty SDK'yı etkinleştirirken bunları `true` olarak ayarlayın:

```dart showLineNumbers
try {
    await Adapty().activate(
        configuration: AdaptyConfiguration(apiKey: 'YOUR_API_KEY')
 // highlight-start
          ..withGoogleAdvertisingIdCollectionDisabled(true), // set to `true`
          ..withAppleIdfaCollectionDisabled(true), // set to `true`
// highlight-end
    );
} catch (e) {
    // handle the error
}
```
</TabItem>

<TabItem value="unity" label="Unity" default>
Adapty SDK'yı etkinleştirirken `SetIDFACollectionDisabled` özelliğini kullanarak IDFA toplamayı devre dışı bırakabilirsiniz. AAID/GAID toplama şu an devre dışı bırakılamamaktadır.

```dart showLineNumbers
var builder = new AdaptyConfiguration.Builder("YOUR_API_KEY")
 // highlight-start
    .SetIDFACollectionDisabled(true); // set to `true`
 // highlight-end

Adapty.Activate(builder.Build(), (error) => {
    // handle the error
}
```

</TabItem>

<TabItem value="rn" label="React Native" default>
Adapty SDK'yı etkinleştirirken `idfaCollectionDisabled` özelliğiyle IDFA toplamayı veya `adIdCollectionDisabled` özelliğiyle AAID/GAID toplamayı devre dışı bırakabilirsiniz.

```typescript showLineNumbers
adapty.activate('PUBLIC_SDK_KEY', {
  // highlight-start 
  ios: {
      idfaCollectionDisabled: true, // set to `true`
  }, 
  android: {
      adIdCollectionDisabled: true,
  },
  // highlight-end
});
```
</TabItem>
</Tabs>