Bắt đầu với Cấu hình từ xa Firebase


Bạn có thể sử dụng Cấu hình từ xa Firebase để xác định các tham số trong ứng dụng của mình và cập nhật giá trị của chúng trên đám mây, cho phép bạn sửa đổi giao diện và hoạt động của ứng dụng mà không cần phân phối bản cập nhật ứng dụng.

Thư viện Cấu hình từ xa được dùng để lưu trữ các giá trị tham số mặc định trong ứng dụng, tìm nạp các giá trị tham số được cập nhật từ phần phụ trợ Cấu hình từ xa và kiểm soát thời điểm cung cấp các giá trị được tìm nạp cho ứng dụng của bạn. Để tìm hiểu thêm, hãy xem Chiến lược tải cấu hình từ xa .

Bước 1: Thêm Firebase vào ứng dụng của bạn

Trước khi có thể sử dụng Remote Config , bạn cần:

  • Đăng ký dự án C++ của bạn và định cấu hình nó để sử dụng Firebase.

    Nếu dự án C++ của bạn đã sử dụng Firebase thì dự án đó đã được đăng ký và định cấu hình cho Firebase.

  • Thêm SDK Firebase C++ vào dự án C++ của bạn.

Lưu ý rằng việc thêm Firebase vào dự án C++ của bạn bao gồm các tác vụ trong cả bảng điều khiển Firebase và trong dự án C++ mở của bạn (ví dụ: bạn tải xuống tệp cấu hình Firebase từ bảng điều khiển, sau đó chuyển chúng vào dự án C++ của bạn).

Bước 2: Thêm cấu hình từ xa vào ứng dụng của bạn

Android

Sau khi bạn đã thêm Firebase vào ứng dụng của mình:

  1. Tạo Ứng dụng Firebase, chuyển vào môi trường JNI và Hoạt động:

    app = ::firebase::App::Create(::firebase::AppOptions(), jni_env, activity);

  2. Khởi tạo thư viện Remote Config như sau:

    ::firebase::remote_config::Initialize(app);

iOS+

Sau khi bạn đã thêm Firebase vào ứng dụng của mình:

  1. Tạo ứng dụng Firebase:

    app = ::firebase::App::Create(::firebase::AppOptions());

  2. Khởi tạo thư viện Remote Config như sau:

    ::firebase::remote_config::Initialize(app);

Bước 3: Đặt giá trị tham số mặc định trong ứng dụng

Bạn có thể đặt các giá trị tham số mặc định trong ứng dụng trong đối tượng Cấu hình từ xa để ứng dụng của bạn hoạt động như dự định trước khi kết nối với phần phụ trợ Cấu hình từ xa và để các giá trị mặc định khả dụng nếu không có giá trị nào được đặt trên phần phụ trợ.

  1. Xác định một tập hợp các tên tham số và các giá trị tham số mặc định bằng cách sử dụng đối tượng std::map<const char*, const char*> hoặc đối tượng std::map<const char*, firebase::Variant> .

    Nếu đã định cấu hình các giá trị tham số phụ trợ Cấu hình từ xa, bạn có thể tải xuống tệp chứa các cặp khóa/giá trị này và sử dụng tệp đó để xây dựng đối tượng map của mình. Để biết thêm thông tin, hãy xem Tải xuống mặc định mẫu Cấu hình từ xa .

  2. Thêm các giá trị này vào đối tượng Remote Config bằng SetDefaults() .

Bước 4: Nhận các giá trị tham số để sử dụng trong ứng dụng của bạn

Bây giờ bạn có thể nhận các giá trị tham số từ đối tượng Remote Config. Nếu bạn đặt các giá trị trong phần phụ trợ Cấu hình từ xa, tìm nạp chúng rồi kích hoạt chúng thì những giá trị đó sẽ có sẵn cho ứng dụng của bạn. Nếu không, bạn sẽ nhận được các giá trị tham số trong ứng dụng được định cấu hình bằng SetDefaults() .

Để có được những giá trị này, hãy gọi phương thức được liệt kê bên dưới để ánh xạ tới loại dữ liệu mà ứng dụng của bạn mong đợi, cung cấp khóa tham số làm đối số:

Bước 5: Đặt giá trị tham số

  1. Trong bảng điều khiển Firebase , hãy mở dự án của bạn.
  2. Chọn Cấu hình từ xa từ menu để xem bảng thông tin Cấu hình từ xa.
  3. Xác định các tham số có cùng tên với các tham số mà bạn đã xác định trong ứng dụng của mình. Đối với mỗi tham số, bạn có thể đặt giá trị mặc định (cuối cùng sẽ ghi đè giá trị mặc định trong ứng dụng) và các giá trị có điều kiện. Để tìm hiểu thêm, hãy xem các thông số và điều kiện Cấu hình từ xa .

Bước 6: Tìm nạp và kích hoạt các giá trị

  1. Để tìm nạp các giá trị tham số từ phần phụ trợ Cấu hình từ xa, hãy gọi phương thức Fetch() . Mọi giá trị bạn đặt trên chương trình phụ trợ đều được tìm nạp và lưu vào bộ đệm trong đối tượng Cấu hình từ xa.
  2. Để cung cấp các giá trị tham số đã tìm nạp cho ứng dụng của bạn, hãy gọi ActivateFetched()

Bước 7: Nghe cập nhật theo thời gian thực

Sau khi tìm nạp các giá trị tham số, bạn có thể sử dụng Cấu hình từ xa theo thời gian thực để lắng nghe các bản cập nhật từ chương trình phụ trợ Cấu hình từ xa. Tín hiệu Cấu hình từ xa theo thời gian thực tới các thiết bị được kết nối khi có bản cập nhật và tự động tìm nạp các thay đổi sau khi bạn xuất bản phiên bản Cấu hình từ xa mới.

Các bản cập nhật theo thời gian thực được hỗ trợ bởi SDK Firebase C++ v11.0.0+ trở lên dành cho nền tảng Android và Apple.

  1. Trong ứng dụng của bạn, hãy gọi AddOnConfigUpdateListener để bắt đầu lắng nghe các bản cập nhật và tự động tìm nạp mọi giá trị thông số mới hoặc cập nhật. Ví dụ sau lắng nghe các bản cập nhật và khi Activate được gọi, sử dụng các giá trị mới được tìm nạp để hiển thị thông báo chào mừng được cập nhật.
remote_config->AddOnConfigUpdateListener(
    [](firebase::remote_config::ConfigUpdate&& config_update,
       firebase::remote_config::RemoteConfigError remote_config_error) {
      if (remote_config_error != firebase::remote_config::kRemoteConfigErrorNone) {
        printf("Error listening for config updates: %d", remote_config_error);
      }
      // Search the `updated_keys` set for the key "welcome_message."
      // `updated_keys` represents the keys that have changed since the last
      // fetch.
      if (std::find(config_update.updated_keys.begin(),
                    config_update.updated_keys.end(),
                    "welcome_message") != config_update.updated_keys.end()) {
        remote_config->Activate().OnCompletion(
            [&](const firebase::Future& completed_future,
               void* user_data) {
              // The key "welcome_message" was found within `updated_keys` and
              // can be activated.
              if (completed_future.error() == 0) {
                DisplayWelcomeMessage();
              } else {
                printf("Error activating config: %d", completed_future.error());
              }
            },
            nullptr);
      }
    });

Lần tới khi bạn xuất bản phiên bản mới của Cấu hình từ xa, các thiết bị đang chạy ứng dụng của bạn và lắng nghe các thay đổi sẽ gọi trình nghe cập nhật cấu hình.

Bước tiếp theo

Nếu bạn chưa có, hãy khám phá các trường hợp sử dụng cấu hình từ xa và xem xét một số khái niệm chính và tài liệu chiến lược nâng cao, bao gồm: