관리 메뉴

김종권의 iOS 앱 개발 알아가기

[iOS - swift] Firebase Remote Config 사용 방법 (FirebaseRemoteConfig) 본문

iOS 응용 (swift)

[iOS - swift] Firebase Remote Config 사용 방법 (FirebaseRemoteConfig)

jake-kim 2023. 4. 15. 01:02

Firebase 연동

  • cocoapod으로 firebase remote config 설치
pod 'Firebase/RemoteConfig'

콘솔에서 Remote config 설정

  • Firebase console > 모든 제품 > Remote Config 선택

  • 구성 만들기 선택

  • 매개변수 추가

  • 변경사항 게시 버튼 클릭하면 클라 앱에 반영 (앱에서 테스트가 필요하므로 바로 클릭)

Remote Config 사용

  • AppDelegate의 didFinishLaunchingWithOptions에서 remote config 세팅
    • minimimFetchInterval 값 설정: 0으로 설정하면 가능한 빠르게 config값을 firebase에서 가져오고, 만약 debug가 아닌 production에서는 빠르게 가져올경우, firebase 대역폭을 넘을 수 있으므로 적절한 값을 사용할것
    • Firebase에서 권장하는 값은 12시간(default 값)
// Firebase 연동
FirebaseApp.configure()

// singleton을 얻어서 세팅
let remoteConfig = RemoteConfig.remoteConfig()
let settings = RemoteConfigSettings()

// fetchInterval 값 설정: https://firebase.google.com/docs/remote-config/get-started?platform=ios&hl=ko#throttling
settings.minimumFetchInterval = 0
remoteConfig.configSettings = settings
  • fetch(completionHandler:)와 activate() 메소드를 통해 config 획득이 가능
// 1. fetch (firebase 캐싱 - activate 메소드에서 changed 값을 내려줄수 있는 원리)
remoteConfig.fetch() { (status, error) -> Void in
    if status == .success {
        
        // 2. activate (컨피그 값 가져오기)
        remoteConfig.activate() { (changed, error) in
            print(changed, error)
            let resultValue = remoteConfig["MyKey"].stringValue
            print("resultValue=", resultValue)
        }
    } else {
        print("Error: \(error?.localizedDescription ?? "No error available.")")
    }
}

/*
 Config fetched!
 false nil
 resultValue= Optional("MyValue")
*/
  • fetch(completionHandler:)를 사용하여 remote config 
    • 앱이 실행되거나 사용자가 앱을 다시 켤 때나 주기적으로 firebase쪽에 현재까지 불러온 config 데이터를 전달하며, 앱에서 어떤 config를 받았는지 체크하기 위함 (아래 activate 메소드를 호출하면 changed 되었는지 확인해주는 값을 내려주는데 이 때 사용)
  • activate(completion:)
    • closure로 들어오는 값인 changed가 true이면 firebase 콘솔에서 config값이 변경된 경우임을 알 수 있고, 이 변화에 따라서 앱에 반영이 가능

* 전체 코드: https://github.com/JK0369/ExConfig

Comments