---
title: "Aplicaciones Firebase"
description: "Integra Firebase con Adapty para mejorar el análisis de usuarios y el seguimiento de suscripciones en tu app móvil."
---

Esta página explica cómo integrar Adapty en tu app si funciona con Firebase.

:::note
Primeros pasos

Estos no son todos los pasos necesarios para que Adapty funcione, solo algunos consejos útiles para la integración con Firebase. Si quieres integrar Adapty en tu app, lee primero la [Guía de inicio rápido](quickstart).
:::

## Identificación de usuarios \{#user-identification\}

Si usas Firebase Auth, este fragmento de código puede ayudarte a mantener tus usuarios sincronizados entre Firebase y Adapty. Ten en cuenta que es solo un ejemplo y debes considerar las particularidades de autenticación de tu app.

<Tabs groupId="current-os" queryString>
<TabItem value="swift" label="iOS with Firebase" default>
```swift showLineNumbers
 
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
 
    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        // Configure Adapty before Firebase
        Adapty.activate("YOUR_API_KEY")
        Adapty.delegate = self
        
        // Configure Firebase
        FirebaseApp.configure()
        
        // Add state change listener for Firebase Authentication
        Auth.auth().addStateDidChangeListener { (auth, user) in
            if let uid = user?.uid {
                // identify Adapty SDK with new Firebase user
                Adapty.identify(uid) { error in
                    if let e = error {
                        print("Sign in error: \(e.localizedDescription)")
                    } else {
                        print("User \(uid) signed in")
                    }
                }
            }
        }
 
        return true
    }
 
}
 
extension AppDelegate: AdaptyDelegate {
 
    // MARK: - Adapty delegate
    func didReceiveUpdatedPurchaserInfo(_ purchaserInfo: PurchaserInfoModel) {
        // You can optionally post to the notification center whenever
        // purchaser info changes.
 
        // You can subscribe to this notification throughout your app
        // to refresh tableViews or change the UI based on the user's
        // subscription status
        
        NotificationCenter.default.post(name: NSNotification.Name(rawValue: "com.Adapty.PurchaserInfoUpdatedNotification"), object: purchaserInfo)
    }
 
}
```
</TabItem>
<TabItem value="kotlin" label="Android with Firebase" default>
```kotlin showLineNumbers
class App : Application() {

    override fun onCreate() {
        super.onCreate()
        // Configure Adapty
        Adapty.activate(this, "YOUR_API_KEY")

        Adapty.setOnPurchaserInfoUpdatedListener(object : OnPurchaserInfoUpdatedListener {
            override fun onPurchaserInfoReceived(purchaserInfo: PurchaserInfoModel) {
                // handle any changes to subscription state
            }
        })

        // Add state change listener for Firebase Authentication
        FirebaseAuth.getInstance().addAuthStateListener { auth ->
            val currentUserId = auth.currentUser?.uid

            if (currentUserId != null) {
                // identify Adapty SDK with new Firebase user
                Adapty.identify(currentUserId) { error ->
                    if (error == null) {
                        //success
                    }
                }
            } else {
                Adapty.logout { }
            }
        }
    }
}
```
</TabItem>
</Tabs>