फायरबेस परियोजना और ऐप प्रबंधन घटनाओं की एक विस्तृत श्रृंखला के लिए अलर्ट प्रदान करता है। यहां कुछ उदाहरण दिए गए हैं जब फायरबेस आपको इस प्रकार का अलर्ट भेज सकता है:
- क्रैशलिटिक्स के लिए, यदि आपके ऐप में क्रैश की संख्या में नाटकीय वृद्धि हुई है तो हम आपको सचेत कर सकते हैं।
- प्रदर्शन निगरानी के लिए, यदि आपके ऐप का स्टार्ट-अप समय आपकी कॉन्फ़िगर की गई सीमा को पार कर जाता है तो हम आपको सचेत कर सकते हैं।
- ऐप वितरण के लिए, यदि आपका कोई परीक्षक एक नया iOS डिवाइस पंजीकृत करता है तो हम आपको सचेत कर सकते हैं।
प्रोजेक्ट सदस्य द्वारा निर्धारित अलर्ट और प्राथमिकताओं के आधार पर, फायरबेस इस प्रकार के अलर्ट फायरबेस कंसोल में दिखाता है या उन्हें ईमेल के माध्यम से भेजता है।
यह पृष्ठ बताता है कि फायरबेस (दूसरी पीढ़ी) के लिए क्लाउड फ़ंक्शंस में फ़ंक्शंस कैसे लिखें जो अलर्ट घटनाओं को संभालते हैं।
यह कैसे काम करता है?
आप इन स्रोतों द्वारा उत्सर्जित चेतावनी घटनाओं के जवाब में फ़ंक्शन ट्रिगर कर सकते हैं:
- ऐप डिस्ट्रीब्यूशन अलर्ट इवेंट को संभालें
- क्रैशलिटिक्स अलर्ट इवेंट को संभालें
- एक प्रदर्शन निगरानी चेतावनी घटना को संभालें
एक सामान्य जीवनचक्र में, एक अलर्ट इवेंट द्वारा ट्रिगर किया गया फ़ंक्शन निम्नलिखित कार्य करता है:
- फायरबेस से उत्सर्जित होने वाले एक विशिष्ट अलर्ट प्रकार को सुनता/प्रतीक्षा करता है।
- अलर्ट उत्सर्जित होने पर ट्रिगर होता है, और ईवेंट पेलोड प्राप्त करता है जिसमें ईवेंट के बारे में विशिष्ट जानकारी होती है।
- ईवेंट पेलोड को संभालने के लिए आपके फ़ंक्शन के कोड को आमंत्रित करता है।
अलर्ट इवेंट पर फ़ंक्शन ट्रिगर करें
अलर्ट इवेंट को संभालने वाले फ़ंक्शन को लिखने के लिए firebase-functions/v2/alerts
सबपैकेज का उपयोग करें। निम्नलिखित उत्पाद-विशिष्ट उदाहरण एक वर्कफ़्लो प्रदर्शित करते हैं जहां एक फ़ंक्शन डिस्कॉर्ड चैनल पर एक संदेश पोस्ट करने के लिए एक वेबहुक का उपयोग करता है जब उस उत्पाद के लिए फायरबेस से अलर्ट उत्सर्जित होता है।
क्रैशलिटिक्स अलर्ट इवेंट को संभालें
निम्नलिखित क्रैशलिटिक्स उदाहरण के लिए, आप एक नए घातक क्रैश मुद्दे की चेतावनी घटना को संभालने के लिए फायरबेस के लिए क्लाउड फ़ंक्शंस का उपयोग करते हैं। यह फ़ंक्शन एक संदेश में अलर्ट जानकारी को डिस्कॉर्ड चैनल पर पोस्ट करता है।
फ़ंक्शन फ़ायरबेस द्वारा एक नई घातक समस्या प्रकाशित करने से संबंधित ईवेंट को सुनता है:
नोड.जे.एस
exports.postfatalissuetodiscord = onNewFatalIssuePublished(async (event) => {
अजगर
@crashlytics_fn.on_new_fatal_issue_published(secrets=["DISCORD_WEBHOOK_URL"])
def post_fatal_issue_to_discord(event: crashlytics_fn.CrashlyticsNewFatalIssueEvent) -> None:
"""Publishes a message to Discord whenever a new Crashlytics fatal issue occurs."""
फिर फ़ंक्शन लौटाए गए ईवेंट ऑब्जेक्ट को पार्स करता है, ईवेंट पेलोड से उपयोगी जानकारी पार्स करता है और डिस्कॉर्ड चैनल पर पोस्ट करने के लिए एक संदेश बनाता है:
नोड.जे.एस
// construct a helpful message to send to Discord
const appId = event.appId;
const {id, title, subtitle, appVersion} = event.data.payload.issue;
const message = `
🚨 New fatal issue for ${appId} in version ${appVersion} 🚨
**${title}**
${subtitle}
id: \`${id}\`
`;
अजगर
# Construct a helpful message to send to Discord.
app_id = event.app_id
issue = event.data.payload.issue
message = f"""
🚨 New fatal issue for {app_id} in version {issue.app_version} 🚨
# {issue.title}
{issue.subtitle}
ID: `{issue.id}`
""".strip()
अंत में, फ़ंक्शन एक HTTP अनुरोध के माध्यम से निर्मित संदेश को डिस्कॉर्ड को भेजता है:
नोड.जे.एस
const response = await postMessageToDiscord("Crashlytics Bot", message);
if (response.ok) {
logger.info(
`Posted fatal Crashlytics alert ${id} for ${appId} to Discord`,
event.data.payload,
);
} else {
throw new Error(response.error);
}
अजगर
response = post_message_to_discord("Crashlytics Bot", message, DISCORD_WEBHOOK_URL.value)
if response.ok:
print(f"Posted fatal Crashlytics alert {issue.id} for {app_id} to Discord.")
pprint.pp(event.data.payload)
else:
response.raise_for_status()
उन सभी क्रैशलिटिक्स अलर्ट ईवेंट के बारे में जानने के लिए जिन्हें आप कैप्चर कर सकते हैं, क्रैशलाइटिक्स अलर्ट के संदर्भ दस्तावेज़ पर जाएं।
एक प्रदर्शन निगरानी चेतावनी घटना को संभालें
यह उदाहरण एक फ़ंक्शन निर्यात करता है जो प्रदर्शन सीमा चेतावनी घटनाओं को सुनता है:
नोड.जे.एस
exports.postperformancealerttodiscord = onThresholdAlertPublished(
async (event) => {
अजगर
@performance_fn.on_threshold_alert_published(secrets=["DISCORD_WEBHOOK_URL"])
def post_performance_alert_to_discord(event: performance_fn.PerformanceThresholdAlertEvent) -> None:
"""Publishes a message to Discord whenever a performance threshold alert is fired."""
फिर फ़ंक्शन लौटाए गए ईवेंट ऑब्जेक्ट को पार्स करता है, ईवेंट पेलोड से उपयोगी जानकारी पार्स करता है और डिस्कॉर्ड चैनल पर पोस्ट करने के लिए एक संदेश बनाता है:
नोड.जे.एस
// construct a helpful message to send to Discord
const appId = event.appId;
const {
eventName,
metricType,
eventType,
numSamples,
thresholdValue,
thresholdUnit,
conditionPercentile,
appVersion,
violationValue,
violationUnit,
investigateUri,
} = event.data.payload;
const message = `
⚠️ Performance Alert for ${metricType} of ${eventType}: **${eventName}** ⚠️
App id: ${appId}
Alert condition: ${thresholdValue} ${thresholdUnit}
Percentile (if applicable): ${conditionPercentile}
App version (if applicable): ${appVersion}
Violation: ${violationValue} ${violationUnit}
Number of samples checked: ${numSamples}
**Investigate more:** ${investigateUri}
`;
अजगर
# Construct a helpful message to send to Discord.
app_id = event.app_id
perf = event.data.payload
message = f"""
⚠️ Performance Alert for {perf.metric_type} of {perf.event_type}: **{perf.event_name}** ⚠️
App ID: {app_id}
Alert condition: {perf.threshold_value} {perf.threshold_unit}
Percentile (if applicable): {perf.condition_percentile}
App version (if applicable): {perf.app_version}
Violation: {perf.violation_value} {perf.violation_unit}
Number of samples checked: {perf.num_samples}
**Investigate more:** {perf.investigate_uri}
""".strip()
अंत में, फ़ंक्शन एक HTTP अनुरोध के माध्यम से निर्मित संदेश को डिस्कॉर्ड को भेजता है:
नोड.जे.एस
const response = await postMessageToDiscord(
"Firebase Performance Bot", message);
if (response.ok) {
logger.info(
`Posted Firebase Performance alert ${eventName} to Discord`,
event.data.payload,
);
} else {
throw new Error(response.error);
}
अजगर
response = post_message_to_discord("App Performance Bot", message,
DISCORD_WEBHOOK_URL.value)
if response.ok:
print(f"Posted Firebase Performance alert {perf.event_name} to Discord.")
pprint.pp(event.data.payload)
else:
response.raise_for_status()
उन सभी प्रदर्शन चेतावनी घटनाओं के बारे में जानने के लिए जिन्हें आप कैप्चर कर सकते हैं, प्रदर्शन निगरानी अलर्ट के संदर्भ दस्तावेज़ पर जाएँ।
ऐप डिस्ट्रीब्यूशन अलर्ट इवेंट को संभालें
इस अनुभाग का उदाहरण आपको दिखाता है कि नए परीक्षक iOS डिवाइस अलर्ट के लिए फ़ंक्शन कैसे लिखें।
इस उदाहरण में, फ़ंक्शन उन घटनाओं को सुनता है जो हर बार एक परीक्षक द्वारा एक नए iOS डिवाइस को पंजीकृत करने पर भेजी जाती हैं। जब एक नया iOS डिवाइस पंजीकृत होता है, तो आपको उस डिवाइस के UDID के साथ अपनी प्रोविज़निंग प्रोफ़ाइल को अपडेट करना होगा और फिर ऐप को फिर से वितरित करना होगा।
नोड.जे.एस
exports.postnewduuidtodiscord = onNewTesterIosDevicePublished(async (event) => {
अजगर
@app_distribution_fn.on_new_tester_ios_device_published(secrets=["DISCORD_WEBHOOK_URL"])
def post_new_udid_to_discord(event: app_distribution_fn.NewTesterDeviceEvent) -> None:
"""Publishes a message to Discord whenever someone registers a new iOS test device."""
फिर फ़ंक्शन लौटाए गए ऑब्जेक्ट को पार्स करता है, इवेंट पेलोड से उपयोगी जानकारी पार्स करता है और डिस्कॉर्ड चैनल पर पोस्ट करने के लिए एक संदेश बनाता है:
नोड.जे.एस
// construct a helpful message to send to Discord
const appId = event.appId;
const {
testerDeviceIdentifier,
testerDeviceModelName,
testerEmail,
testerName,
} = event.data.payload;
const message = `
📱 New iOS device registered by ${testerName} <${testerEmail}> for ${appId}
UDID **${testerDeviceIdentifier}** for ${testerDeviceModelName}
`;
अजगर
# Construct a helpful message to send to Discord.
app_id = event.app_id
app_dist = event.data.payload
message = f"""
📱 New iOS device registered by {app_dist.tester_name} <{app_dist.tester_email}> for {app_id}
UDID **{app_dist.tester_device_identifier}** for {app_dist.tester_device_model_name}
""".strip()
अंत में, फ़ंक्शन एक HTTP अनुरोध के माध्यम से निर्मित संदेश को डिस्कॉर्ड को भेजता है:
नोड.जे.एस
const response = await postMessageToDiscord("AppDistribution Bot", message);
if (response.ok) {
logger.info(
`Posted iOS device registration alert for ${testerEmail} to Discord`,
);
} else {
throw new Error(response.error);
}
अजगर
response = post_message_to_discord("App Distro Bot", message, DISCORD_WEBHOOK_URL.value)
if response.ok:
print(f"Posted iOS device registration alert for {app_dist.tester_email} to Discord.")
pprint.pp(event.data.payload)
else:
response.raise_for_status()
उन सभी ऐप वितरण अलर्ट ईवेंट के बारे में जानने के लिए जिन्हें आप कैप्चर कर सकते हैं, ऐप वितरण अलर्ट के संदर्भ दस्तावेज़ पर जाएं।
ऐप डिस्ट्रीब्यूशन से इन-ऐप फीडबैक फायरबेस अलर्ट द्वारा ट्रिगर किए गए फ़ंक्शन का उपयोग करने का तरीका जानने के लिए, जीरा को इन-ऐप फीडबैक भेजें देखें।