این سند توضیح میدهد که چگونه میتوانید مجموعهای از پارامترها و شرایط با فرمت JSON را که به عنوان الگوی Remote Config شناخته میشوند، از طریق برنامهنویسی بخوانید و تغییر دهید. این به شما امکان میدهد تغییرات الگو را در backend ایجاد کنید که برنامه کلاینت میتواند با استفاده از کتابخانه کلاینت آن را دریافت کند.
با استفاده از Remote Config REST API یا Admin SDK های شرح داده شده در این راهنما، میتوانید مدیریت قالب در کنسول Firebase را کنار بگذارید تا تغییرات Remote Config را مستقیماً در فرآیندهای خود ادغام کنید. به عنوان مثال، با API های backend Remote Config ، میتوانید:
- زمانبندی بهروزرسانیهای Remote Config . با استفاده از فراخوانیهای API همراه با یک cron job، میتوانید مقادیر Remote Config را در یک برنامه منظم تغییر دهید.
- مقادیر پیکربندی را به صورت دستهای وارد کنید تا بتوانید به طور موثر از سیستم اختصاصی خود به Firebase Remote Config انتقال دهید.
از Remote Config با Cloud Functions for Firebase استفاده کنید و مقادیر برنامه خود را بر اساس رویدادهایی که در سمت سرور اتفاق میافتند تغییر دهید. به عنوان مثال، میتوانید از Remote Config برای تبلیغ یک ویژگی جدید در برنامه خود استفاده کنید و سپس پس از تشخیص تعامل کافی افراد با ویژگی جدید، آن تبلیغ را به طور خودکار خاموش کنید.

بخشهای بعدی این راهنما، عملیاتی را که میتوانید با APIهای backend مربوط به Remote Config انجام دهید، شرح میدهد. برای بررسی برخی از کدهایی که این وظایف را از طریق REST API انجام میدهند، به یکی از این برنامههای نمونه مراجعه کنید:
- پیکربندی از راه دور فایربیس، REST API، جاوا، شروع سریع
- پیکربندی ریموت فایربیس، REST API، شروع سریع Node.js
- شروع سریع در پیکربندی ریموت فایربیس، REST API پایتون
تغییر پیکربندی از راه دور با استفاده از Firebase Admin SDK
Admin SDK مجموعهای از کتابخانههای سرور است که به شما امکان میدهد از محیطهای دارای امتیاز با Firebase تعامل داشته باشید. Admin SDK علاوه بر انجام بهروزرسانیها در Remote Config ، امکان تولید و تأیید توکنهای احراز هویت Firebase، خواندن و نوشتن از Realtime Database و غیره را نیز فراهم میکند. برای کسب اطلاعات بیشتر در مورد پیشنیازها و تنظیمات Admin SDK ، به بخش افزودن Firebase Admin SDK به سرور خود مراجعه کنید.
در یک جریان معمول Remote Config ، ممکن است الگوی فعلی را دریافت کنید، برخی از پارامترها یا گروههای پارامتر و شرایط را تغییر دهید، الگو را اعتبارسنجی کنید و سپس آن را منتشر کنید. قبل از انجام این فراخوانیهای API، باید درخواستها را از SDK تأیید کنید.
مقداردهی اولیه SDK و تأیید درخواستهای API
وقتی Admin SDK بدون هیچ پارامتری مقداردهی اولیه میکنید، SDK از اعتبارنامههای پیشفرض برنامه گوگل استفاده میکند و گزینهها را از متغیر محیطی FIREBASE_CONFIG میخواند. اگر محتوای متغیر FIREBASE_CONFIG با یک { شروع شود، به عنوان یک شیء JSON تجزیه میشود. در غیر این صورت، SDK فرض میکند که رشته، نام یک فایل JSON حاوی گزینهها است.
برای مثال:
نود جی اس
const admin = require('firebase-admin'); admin.initializeApp();
جاوا
FileInputStream serviceAccount = new FileInputStream("service-account.json"); FirebaseOptions options = FirebaseOptions.builder() .setCredentials(GoogleCredentials.fromStream(serviceAccount)) .build(); FirebaseApp.initializeApp(options);
الگوی پیکربندی از راه دور فعلی را دریافت کنید
هنگام کار با قالبهای Remote Config ، به خاطر داشته باشید که آنها نسخهبندی شدهاند و هر نسخه از زمان ایجاد تا زمانی که آن را با یک بهروزرسانی جایگزین میکنید، طول عمر محدودی دارد: ۹۰ روز، با محدودیت کلی ۳۰۰ نسخه ذخیره شده. برای اطلاعات بیشتر به Templates and Versioning مراجعه کنید.
شما میتوانید از APIهای بکاند برای دریافت نسخه فعال فعلی الگوی Remote Config در قالب JSON استفاده کنید.
پارامترها و مقادیر پارامتری که به طور خاص به عنوان گونههای مختلف در یک آزمایش A/B Testing ایجاد شدهاند، در قالبهای صادر شده لحاظ نمیشوند.
برای دریافت الگو:
نود جی اس
function getTemplate() { var config = admin.remoteConfig(); config.getTemplate() .then(function (template) { console.log('ETag from server: ' + template.etag); var templateStr = JSON.stringify(template); fs.writeFileSync('config.json', templateStr); }) .catch(function (err) { console.error('Unable to get template'); console.error(err); }); }
جاوا
Template template = FirebaseRemoteConfig.getInstance().getTemplateAsync().get(); // See the ETag of the fetched template. System.out.println("ETag from server: " + template.getETag());
پارامترهای پیکربندی از راه دور را تغییر دهید
شما میتوانید پارامترها و گروههای پارامتر Remote Config از طریق برنامهنویسی تغییر داده و اضافه کنید. برای مثال، به یک گروه پارامتر موجود با نام "new_menu" میتوانید پارامتری برای کنترل نمایش اطلاعات فصلی اضافه کنید:
نود جی اس
function addParameterToGroup(template) { template.parameterGroups['new_menu'].parameters['spring_season'] = { defaultValue: { useInAppDefault: true }, description: 'spring season menu visibility.', }; }
جاوا
template.getParameterGroups().get("new_menu").getParameters() .put("spring_season", new Parameter() .setDefaultValue(ParameterValue.inAppDefault()) .setDescription("spring season menu visibility.") );
این API به شما امکان میدهد پارامترهای جدید و گروههای پارامتر ایجاد کنید، یا مقادیر پیشفرض، مقادیر شرطی و توضیحات را تغییر دهید. در همه موارد، باید پس از انجام تغییرات، الگو را صریحاً منتشر کنید.
تغییر شرایط پیکربندی از راه دور
شما میتوانید شرایط و مقادیر شرطی Remote Config به صورت برنامهنویسی تغییر داده و اضافه کنید. برای مثال، برای اضافه کردن یک شرط جدید:
نود جی اس
function addNewCondition(template) { template.conditions.push({ name: 'android_en', expression: 'device.os == \'android\' && device.country in [\'us\', \'uk\']', tagColor: 'BLUE', }); }
جاوا
template.getConditions().add(new Condition("android_en", "device.os == 'android' && device.country in ['us', 'uk']", TagColor.BLUE));
در همه موارد، شما باید پس از انجام تغییرات، الگو را صریحاً منتشر کنید.
APIهای بکاند Remote Config چندین شرط و عملگر مقایسهای ارائه میدهند که میتوانید از آنها برای تغییر رفتار و ظاهر برنامه خود استفاده کنید. برای کسب اطلاعات بیشتر در مورد شرطها و عملگرهای پشتیبانی شده برای این شرطها، به مرجع عبارت شرطی مراجعه کنید.
اعتبارسنجی الگوی Remote Config
به صورت اختیاری، میتوانید قبل از انتشار بهروزرسانیهای خود، آنها را اعتبارسنجی کنید، همانطور که نشان داده شده است:
نود جی اس
function validateTemplate(template) { admin.remoteConfig().validateTemplate(template) .then(function (validatedTemplate) { // The template is valid and safe to use. console.log('Template was valid and safe to use'); }) .catch(function (err) { console.error('Template is invalid and cannot be published'); console.error(err); }); }
جاوا
try { Template validatedTemplate = FirebaseRemoteConfig.getInstance() .validateTemplateAsync(template).get(); System.out.println("Template was valid and safe to use"); } catch (ExecutionException e) { if (e.getCause() instanceof FirebaseRemoteConfigException) { FirebaseRemoteConfigException rcError = (FirebaseRemoteConfigException) e.getCause(); System.out.println("Template is invalid and cannot be published"); System.out.println(rcError.getMessage()); } }
این فرآیند اعتبارسنجی، خطاهایی مانند کلیدهای تکراری برای پارامترها و شرایط، نامهای نامعتبر شرایط یا شرایط ناموجود، یا برچسبهای با قالب نادرست را بررسی میکند. برای مثال، درخواستی که حاوی بیش از تعداد مجاز کلیدها - ۲۰۰۰ - باشد، پیام خطای Param count too large برمیگرداند.
الگوی Remote Config را منتشر کنید
پس از بازیابی یک الگو و اعمال بهروزرسانیهای دلخواه، میتوانید آن را منتشر کنید. انتشار یک الگو به روشی که در این بخش توضیح داده شده است، کل الگوی پیکربندی موجود را با فایل بهروزرسانیشده جایگزین میکند و به الگوی فعال جدید، شماره نسخه یک بزرگتر از الگویی که جایگزین آن شده است، اختصاص داده میشود.
در صورت لزوم، میتوانید از REST API برای بازگشت به نسخه قبلی استفاده کنید. برای کاهش خطر خطا در بهروزرسانی، میتوانید قبل از انتشار، اعتبارسنجی کنید .
شخصیسازیها و شرایط Remote Config در قالبهای دانلود شده گنجانده شدهاند، بنابراین مهم است که هنگام تلاش برای انتشار در یک پروژه دیگر، از محدودیتهای زیر آگاه باشید:
شخصیسازیها را نمیتوان از پروژهای به پروژه دیگر وارد کرد.
برای مثال، اگر شخصیسازیها را در پروژه خود فعال کرده باشید و یک قالب را دانلود و ویرایش کنید، میتوانید آن را در همان پروژه منتشر کنید، اما نمیتوانید آن را در پروژه دیگری منتشر کنید، مگر اینکه شخصیسازیها را از قالب حذف کنید.
شرایط را میتوان از پروژهای به پروژه دیگر وارد کرد، اما توجه داشته باشید که هرگونه مقدار شرطی خاص (مانند شناسه برنامه یا مخاطبان) باید قبل از انتشار در پروژه هدف وجود داشته باشد.
برای مثال، اگر یک پارامتر Remote Config دارید که از شرطی استفاده میکند که مقدار پلتفرم
iOSرا مشخص میکند، میتوان این الگو را در پروژه دیگری منتشر کرد، زیرا مقادیر پلتفرم برای هر پروژهای یکسان است. با این حال، اگر حاوی شرطی باشد که به یک شناسه برنامه یا مخاطب کاربر خاص متکی باشد که در پروژه هدف وجود ندارد، اعتبارسنجی با شکست مواجه خواهد شد.اگر قالبی که قصد انتشار آن را دارید حاوی شرایطی است که به Google Analytics متکی است، Analytics باید در پروژه هدف فعال باشد.
نود جی اس
function publishTemplate() { var config = admin.remoteConfig(); var template = config.createTemplateFromJSON( fs.readFileSync('config.json', 'UTF8')); config.publishTemplate(template) .then(function (updatedTemplate) { console.log('Template has been published'); console.log('ETag from server: ' + updatedTemplate.etag); }) .catch(function (err) { console.error('Unable to publish template.'); console.error(err); }); }
جاوا
try { Template publishedTemplate = FirebaseRemoteConfig.getInstance() .publishTemplateAsync(template).get(); System.out.println("Template has been published"); // See the ETag of the published template. System.out.println("ETag from server: " + publishedTemplate.getETag()); } catch (ExecutionException e) { if (e.getCause() instanceof FirebaseRemoteConfigException) { FirebaseRemoteConfigException rcError = (FirebaseRemoteConfigException) e.getCause(); System.out.println("Unable to publish template."); System.out.println(rcError.getMessage()); } }
تغییر پیکربندی از راه دور با استفاده از REST API
این بخش قابلیتهای اصلی Remote Config REST API را در https://firebaseremoteconfig.googleapis.com شرح میدهد. برای جزئیات کامل، به مرجع API مراجعه کنید.
دریافت توکن دسترسی برای احراز هویت و مجوزدهی درخواستهای API
پروژههای فایربیس از حسابهای سرویس گوگل پشتیبانی میکنند که میتوانید از آنها برای فراخوانی APIهای سرور فایربیس از سرور برنامه یا محیط مورد اعتماد خود استفاده کنید. اگر در حال توسعه کد به صورت محلی هستید یا برنامه خود را در محل مستقر میکنید، میتوانید از اعتبارنامههای به دست آمده از طریق این حساب سرویس برای تأیید درخواستهای سرور استفاده کنید.
برای تأیید اعتبار یک حساب کاربری سرویس و اجازه دسترسی آن به سرویسهای Firebase، باید یک فایل کلید خصوصی با فرمت JSON ایجاد کنید.
برای ایجاد یک فایل کلید خصوصی برای حساب سرویس خود:
در کنسول Firebase ، تنظیمات > حسابهای سرویس ( Settings > Service Accounts) را باز کنید.
روی «ایجاد کلید خصوصی جدید» کلیک کنید، سپس با کلیک روی «ایجاد کلید» تأیید کنید.
فایل JSON حاوی کلید را به طور ایمن ذخیره کنید.
هنگام تأیید اعتبار از طریق یک حساب کاربری سرویس، دو گزینه برای ارائه اعتبارنامه به برنامه خود دارید. میتوانید متغیر محیطی GOOGLE_APPLICATION_CREDENTIALS را تنظیم کنید، یا میتوانید مسیر کلید حساب کاربری سرویس را به صورت کد به صراحت ارسال کنید. گزینه اول امنتر است و اکیداً توصیه میشود.
برای تنظیم متغیر محیطی:
متغیر محیطی GOOGLE_APPLICATION_CREDENTIALS را روی مسیر فایل JSON که حاوی کلید حساب سرویس شماست، تنظیم کنید. این متغیر فقط برای جلسه پوسته فعلی شما اعمال میشود، بنابراین اگر یک جلسه جدید باز کردید، دوباره متغیر را تنظیم کنید.
لینوکس یا macOS
export GOOGLE_APPLICATION_CREDENTIALS="/home/user/Downloads/service-account-file.json"
ویندوز
با پاورشل:
$env:GOOGLE_APPLICATION_CREDENTIALS="C:\Users\username\Downloads\service-account-file.json"
پس از تکمیل مراحل فوق، اعتبارنامههای پیشفرض برنامه (ADC) قادر است بهطور ضمنی اعتبارنامههای شما را تعیین کند و به شما امکان میدهد هنگام آزمایش یا اجرا در محیطهای غیر گوگلی، از اعتبارنامههای حساب سرویس استفاده کنید.
از اعتبارنامههای Firebase خود به همراه کتابخانه Google Auth برای زبان مورد نظر خود استفاده کنید تا یک توکن دسترسی OAuth 2.0 کوتاه مدت دریافت کنید:
گره.js
function getAccessToken() {
return admin.credential.applicationDefault().getAccessToken()
.then(accessToken => {
return accessToken.access_token;
})
.catch(err => {
console.error('Unable to get access token');
console.error(err);
});
}
در این مثال، کتابخانه کلاینت API گوگل، درخواست را با یک توکن وب JSON یا JWT احراز هویت میکند. برای اطلاعات بیشتر، به JSON web tokens مراجعه کنید.
پایتون
def _get_access_token():
"""Retrieve a valid access token that can be used to authorize requests.
:return: Access token.
"""
credentials = ServiceAccountCredentials.from_json_keyfile_name(
'service-account.json', SCOPES)
access_token_info = credentials.get_access_token()
return access_token_info.access_token
جاوا
public static String getAccessToken() throws IOException {
GoogleCredentials googleCredentials = GoogleCredentials
.fromStream(new FileInputStream("service-account.json"))
.createScoped(Arrays.asList(SCOPES));
googleCredentials.refreshAccessToken();
return googleCredentials.getAccessToken().getTokenValue();
}
پس از انقضای توکن دسترسی شما، متد بهروزرسانی توکن به طور خودکار فراخوانی میشود تا توکن دسترسی بهروزرسانیشده را بازیابی کند.
برای تأیید دسترسی به Remote Config ، دامنه https://www.googleapis.com/auth/firebase.remoteconfig را درخواست کنید.
الگوی Remote Config را تغییر دهید
هنگام کار با قالبهای Remote Config ، به خاطر داشته باشید که آنها نسخهبندی شدهاند و هر نسخه از زمان ایجاد تا زمانی که آن را با یک بهروزرسانی جایگزین میکنید، طول عمر محدودی دارد: ۹۰ روز، با محدودیت کلی ۳۰۰ نسخه ذخیره شده. برای اطلاعات بیشتر به Templates and Versioning مراجعه کنید.
الگوی پیکربندی از راه دور فعلی را دریافت کنید
شما میتوانید از APIهای بکاند برای دریافت نسخه فعال فعلی الگوی Remote Config در قالب JSON استفاده کنید.
پارامترها و مقادیر پارامتری که به طور خاص به عنوان گونههای مختلف در یک آزمایش A/B Testing ایجاد شدهاند، در قالبهای صادر شده لحاظ نمیشوند.
از دستورات زیر استفاده کنید:
حلقه
curl --compressed -D headers -H "Authorization: Bearer token" -X GET https://firebaseremoteconfig.googleapis.com/v1/projects/my-project-id/remoteConfig -o filenameاین دستور، محتوای JSON را در یک فایل و هدرها (شامل Etag) را در یک فایل جداگانه خروجی میدهد.
درخواست HTTP خام
Host: firebaseremoteconfig.googleapis.com GET /v1/projects/my-project-id/remoteConfig HTTP/1.1 Authorization: Bearer token Accept-Encoding: gzip
این فراخوانی API، JSON زیر را به همراه یک هدر جداگانه که شامل ETag است و شما برای درخواست بعدی استفاده میکنید، برمیگرداند.
اعتبارسنجی الگوی Remote Config
به صورت اختیاری، میتوانید قبل از انتشار، بهروزرسانیهای خود را اعتبارسنجی کنید. با افزودن پارامتر ?validate_only=true به درخواست انتشار، بهروزرسانیهای قالب را اعتبارسنجی کنید. در پاسخ، کد وضعیت ۲۰۰ و یک etag بهروزرسانیشده با پسوند -0 به این معنی است که بهروزرسانی شما با موفقیت اعتبارسنجی شده است. هر پاسخی غیر از ۲۰۰ نشان میدهد که دادههای JSON حاوی خطاهایی هستند که باید قبل از انتشار آنها را اصلاح کنید.
الگوی Remote Config را بهروزرسانی کنید
پس از بازیابی یک الگو و اصلاح محتوای JSON با بهروزرسانیهای دلخواه، میتوانید آن را منتشر کنید. انتشار یک الگو به روشی که در این بخش توضیح داده شده است، کل الگوی پیکربندی موجود را با فایل بهروزرسانیشده جایگزین میکند و به الگوی فعال جدید، شماره نسخه یک بزرگتر از الگویی که جایگزین آن شده است، اختصاص داده میشود.
در صورت لزوم، میتوانید از REST API برای بازگشت به نسخه قبلی استفاده کنید. برای کاهش خطر خطا در بهروزرسانی، میتوانید قبل از انتشار، اعتبارسنجی کنید .
شخصیسازیها و شرایط Remote Config در قالبهای دانلود شده گنجانده شدهاند، بنابراین مهم است که هنگام تلاش برای انتشار در یک پروژه دیگر، از محدودیتهای زیر آگاه باشید:
شخصیسازیها را نمیتوان از پروژهای به پروژه دیگر وارد کرد.
برای مثال، اگر شخصیسازیها را در پروژه خود فعال کرده باشید و یک قالب را دانلود و ویرایش کنید، میتوانید آن را در همان پروژه منتشر کنید، اما نمیتوانید آن را در پروژه دیگری منتشر کنید، مگر اینکه شخصیسازیها را از قالب حذف کنید.
شرایط را میتوان از پروژهای به پروژه دیگر وارد کرد، اما توجه داشته باشید که هرگونه مقدار شرطی خاص (مانند شناسه برنامه یا مخاطبان) باید قبل از انتشار در پروژه هدف وجود داشته باشد.
برای مثال، اگر یک پارامتر Remote Config دارید که از شرطی استفاده میکند که مقدار پلتفرم
iOSرا مشخص میکند، میتوان این الگو را در پروژه دیگری منتشر کرد، زیرا مقادیر پلتفرم برای هر پروژهای یکسان است. با این حال، اگر حاوی شرطی باشد که به یک شناسه برنامه یا مخاطب کاربر خاص متکی باشد که در پروژه هدف وجود ندارد، اعتبارسنجی با شکست مواجه خواهد شد.اگر قالبی که قصد انتشار آن را دارید حاوی شرایطی است که به Google Analytics متکی است، Analytics باید در پروژه هدف فعال باشد.
حلقه
curl --compressed -H "Content-Type: application/json; UTF8" -H "If-Match: last-returned-etag" -H "Authorization: Bearer token" -X PUT https://firebaseremoteconfig.googleapis.com/v1/projects/my-project-id/remoteConfig -d @filenameبرای این دستور curl ، میتوانید محتوا را با استفاده از کاراکتر "@" و به دنبال آن نام فایل مشخص کنید.
درخواست HTTP خام
Host: firebaseremoteconfig.googleapis.com PUT /v1/projects/my-project-id/remoteConfig HTTP/1.1 Content-Length: size Content-Type: application/json; UTF8 Authorization: Bearer token If-Match: expected ETag Accept-Encoding: gzip JSON_HERE
از آنجا که این یک درخواست نوشتن است، ETag توسط این دستور اصلاح میشود و ETag بهروزرسانیشده در هدرهای پاسخ دستور PUT بعدی ارائه میشود.
تغییر شرایط پیکربندی از راه دور
شما میتوانید شرایط و مقادیر شرطی Remote Config از طریق برنامهنویسی تغییر دهید. با REST API، برای تغییر شرایط، قبل از انتشار الگو، باید مستقیماً الگو را ویرایش کنید.
{
"conditions": [{
"name": "android_english",
"expression": "device.os == 'android' && device.country in ['us', 'uk']",
"tagColor": "BLUE"
}, {
"name": "tenPercent",
"expression": "percent <= 10",
"tagColor": "BROWN"
}],
"parameters": {
"welcome_message": {
"defaultValue": {
"value": "Welcome to this sample app"
},
"conditionalValues": {
"tenPercent": {
"value": "Welcome to this new sample app"
}
},
"description": "The sample app's welcome message"
},
"welcome_message_caps": {
"defaultValue": {
"value": "false"
},
"conditionalValues": {
"android_english": {
"value": "true"
}
},
"description": "Whether the welcome message should be displayed in all capital letters."
}
}
}تغییرات فوق ابتدا مجموعهای از شرایط را تعریف میکنند و سپس مقادیر پیشفرض و مقادیر پارامتر مبتنی بر شرایط ( مقادیر شرطی ) را برای هر پارامتر تعریف میکنند. همچنین یک توضیح اختیاری برای هر عنصر اضافه میکند؛ مانند نظرات کد، این توضیحات برای استفاده توسعهدهنده هستند و در برنامه نمایش داده نمیشوند. یک ETag نیز برای اهداف کنترل نسخه ارائه شده است.
APIهای بکاند Remote Config چندین شرط و عملگر مقایسهای ارائه میدهند که میتوانید از آنها برای تغییر رفتار و ظاهر برنامه خود استفاده کنید. برای کسب اطلاعات بیشتر در مورد شرطها و عملگرهای پشتیبانی شده برای این شرطها، به مرجع عبارت شرطی مراجعه کنید.
کدهای خطای HTTP
| کد وضعیت | معنی |
|---|---|
| ۲۰۰ | با موفقیت بهروزرسانی شد |
| ۴۰۰ | یک خطای اعتبارسنجی رخ داده است. برای مثال، درخواستی که حاوی بیش از تعداد مجاز کلیدها - ۲۰۰۰ - باشد، مقدار ۴۰۰ (درخواست نامناسب) را با پیام خطا، Param count too large ، برمیگرداند. همچنین، این کد وضعیت HTTPS میتواند در این دو حالت رخ دهد:
|
| ۴۰۱ | خطایی در مجوزدهی رخ داده است (هیچ توکن دسترسی ارائه نشده است یا API Firebase Remote Config REST در کنسول توسعهدهندگان ابری به پروژه شما اضافه نشده است) |
| ۴۰۳ | خطای احراز هویت رخ داده است (نشانه دسترسی اشتباه ارائه شده است) |
| ۵۰۰ | یک خطای داخلی رخ داده است. در صورت بروز این خطا، یک تیکت پشتیبانی Firebase ثبت کنید. |
کد وضعیت ۲۰۰ به این معنی است که الگوی Remote Config (پارامترها، مقادیر و شرایط پروژه) بهروزرسانی شده و اکنون برای برنامههایی که از این پروژه استفاده میکنند در دسترس است. سایر کدهای وضعیت نشان میدهند که الگوی Remote Config که قبلاً وجود داشته، هنوز معتبر است.
پس از ارسال بهروزرسانیها به قالب خود، به کنسول Firebase بروید تا تأیید کنید که تغییرات شما مطابق انتظار نمایش داده میشوند. این امر بسیار مهم است زیرا ترتیب شرطها بر نحوه ارزیابی آنها تأثیر میگذارد (اولین شرطی که مقدار آن true باشد، اعمال میشود).
استفاده از ETag و بهروزرسانیهای اجباری
رابط برنامهنویسی کاربردی REST Remote Config REST API) از یک تگ موجودیت (ETag) برای جلوگیری از شرایط رقابتی و بهروزرسانیهای همپوشانی منابع استفاده میکند. برای کسب اطلاعات بیشتر در مورد ETagها، به ETag - HTTP مراجعه کنید.
برای REST API، گوگل توصیه میکند که ETag ارائه شده توسط جدیدترین دستور GET ذخیره کنید و هنگام صدور دستورات PUT از مقدار ETag در هدر درخواست If-Match استفاده کنید. اگر دستور PUT شما منجر به کد وضعیت HTTPS 409 شود، باید یک دستور GET جدید صادر کنید تا ETag و الگوی جدیدی برای استفاده با دستور PUT بعدی خود دریافت کنید.
شما میتوانید با مجبور کردن الگوی Remote Config به بهروزرسانی به صورت زیر، ETag و محافظتی که ارائه میدهد را دور بزنید: If-Match: * با این حال، این رویکرد توصیه نمیشود زیرا در صورت بهروزرسانی الگوی Remote Config توسط چندین کلاینت، خطر از دست دادن بهروزرسانیهای الگوی Remote Config شما وجود دارد. این نوع تداخل میتواند با چندین کلاینت که از API استفاده میکنند یا با بهروزرسانیهای متناقض از کلاینتهای API و کاربران کنسول Firebase رخ دهد.
برای راهنمایی در مورد مدیریت نسخههای الگوی Remote Config ، به الگوهای Remote Config و نسخهبندی مراجعه کنید.