Bắt đầu sử dụng Cấu hình từ xa Firebase


Bạn có thể sử dụng Firebase Remote Config để xác định các tham số trong ứng dụng và cập nhật giá trị của các tham số đó trên đám mây, cho phép bạn sửa đổi giao diện và hành vi 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 Remote Config dùng để lưu trữ các giá trị thông số mặc định trong ứng dụng, tìm nạp các giá trị thông số đã cập nhật từ phần phụ trợ Remote Config và kiểm soát thời điểm cung cấp các giá trị đã tìm nạp cho ứng dụng. Để 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ó thể sử dụng Remote Config, bạn cần:

  • Đăng ký dự án C++ và định cấu hình dự á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++.

Xin lưu ý rằng việc thêm Firebase vào dự án C++ liên quan đến các tác vụ trong cả bảng điều khiển Firebase và trong dự án C++ đang mở (ví dụ: bạn tải các tệp cấu hình Firebase xuống từ bảng điều khiển, sau đó di chuyển các tệp đó vào dự án C++).

Bước 2: Thêm Remote Config vào ứng dụng

Android

Sau khi bạn thêm Firebase vào ứng dụng:

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

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

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

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

iOS trở lên

Sau khi bạn thêm Firebase vào ứng dụng:

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

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

  2. Khởi chạy 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 giá trị tham số mặc định trong ứng dụng trong đối tượng Remote Config để ứng dụng của bạn hoạt động như dự kiến trước khi kết nối với phần phụ trợ Remote Config và để có giá trị mặc định 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 tên tham số và giá trị tham số mặc định bằng cách sử dụng đối tượng ConfigKeyValue* hoặc đối tượng ConfigKeyValueVariant* có kích thước của mảng.

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

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

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

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

Để lấy các giá trị này, hãy gọi phương thức được liệt kê bên dưới ánh xạ đến loại dữ liệu mà ứng dụng của bạn dự kiến, cung cấp khoá 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 Remote Config trong trình đơn để xem trang tổng quan Remote Config.
  3. Xác định các tham số có tên giống với các tham số mà bạn đã xác định trong ứng dụng. Đối với mỗi tham số, bạn có thể đặt mộ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 phần các tham số và điều kiện của Remote Config.

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

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

Bước 7: Theo dõi thông tin 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 Remote Config theo thời gian thực để nghe thông tin cập nhật từ phần phụ trợ Remote Config. Tín hiệu Remote Config theo thời gian thực cho các thiết bị đã 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 phát hành phiên bản Remote Config mới.

SDK Firebase C++ phiên bản 11.0.0 trở lên hỗ trợ tính năng cập nhật theo thời gian thực cho các nền tảng Android và Apple.

  1. Trong ứng dụng, hãy gọi AddOnConfigUpdateListener để bắt đầu nghe thông tin 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 đây sẽ theo dõi nội dung cập nhật và khi Activate được gọi, sẽ sử dụng các giá trị mới tìm nạp để hiển thị thông báo chào mừng đã 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);
      }
    });

Trong lần tiếp theo bạn phát hành phiên bản mới của Remote Config, các thiết bị đang chạy ứng dụng và theo dõi các thay đổi sẽ gọi trình nghe cập nhật cấu hình.

Các bước tiếp theo

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