יצירת תיעוד למשתמשים עבור התוסף

לכל תוסף צריכה להיות תיעוד שמסביר למשתמשים מה התוסף עושה ואיך משתמשים בו.

המסמכים המינימליים הנדרשים הם שלושת קובצי ה-Markdown הבאים:

  • PREINSTALL.md
  • POSTINSTALL.md
  • CHANGELOG.md

בנוסף, כדאי לייצר גם:

  • קובץ README למאגר הציבורי של התוסף.
  • מדריכים, הדרכות ומקורות מידע ארוכים יותר שפורסמו באתר שלכם וקישור אליהם מופיע ב-PREINSTALL.md.

כדי ללמוד כמה שיטות מומלצות וביטויים ומבנים נפוצים, מומלץ לעיין בקבצים שזמינים עם התוספים הרשמיים של Firebase.

יצירת קובץ README

ספריית התוספים יכולה לכלול קובץ README. חשוב לזכור שהפקודה firebase ext:dev:init לא יוצרת לכם נושא באופן אוטומטי.

עם זאת, ה-CLI של Firebase תומך בפקודה הנוחה הבאה ליצירה אוטומטית של קובץ README שמכיל תוכן שנשלף מהקובץ extension.yaml ומהקובץ PREINSTALL.md:

firebase ext:info ./path/to/extension --markdown > README.md

כל קובצי ה-README של התוספים הרשמיים של Firebase נוצרים באמצעות הפקודה הזו.

הוספת פרטי ההתקנה

אחרי שכותבים או יוצרים קובץ README, מוסיפים אליו את פרטי ההתקנה. אפשר להשתמש בקטע הקוד הבא כתבנית:

---

## 🧩 Install this extension

### Console

[![Install this extension in your Firebase project](https://www.gstatic.com/mobilesdk/210513_mobilesdk/install-extension.png "Install this extension in your Firebase project")][install-link]

[install-link]: https://console.firebase.google.com/project/_/extensions/install?ref=publisher_id/extension_name

### Firebase CLI

```bash
firebase ext:install publisher_id/extension_name --project=[your-project-id]
```

> Learn more about installing extensions in the Firebase Extensions documentation:
> [console](https://firebase.google.com/docs/extensions/install-extensions?platform=console),
> [CLI](https://firebase.google.com/docs/extensions/install-extensions?platform=cli)

---

כתיבת קובץ PREINSTALL

קובץ PREINSTALL הוא הסקירה הכללית של התוסף, סוג של דף 'שיווק'.

מהו התוכן בקובץ הזה?

  • תיאור מקיף של הפונקציונליות של התוסף
  • רשימה של תנאים מוקדמים, כמו הגדרת מסד נתונים או גישה לשירות שאינו של Google (דוגמה)
  • תיאור קצר של המשימות שצריך לבצע לפני ההתקנה והוראות לביצוען
  • תיאור קצר של משימות לאחר ההתקנה (דוגמה) (הוראות מפורטות מופיעות בקטע POSTINSTALL)
  • תיאור קצר של ההשלכות על החיוב (מתחילים בטקסט סטנדרטי)

איפה התוכן הזה מוצג למשתמש?

תמונה של תוכן שמותקן מראש ב-<span class=מסוף Firebase">
התקנה מראש של תוכן במסוף Firebase

תמונה גדולה של תוכן שמותקן מראש ב-<span class=מסוף Firebase">

  • בדף של התוסף בכתובת extensions.dev.
  • מאגר קוד המקור של התוסף (בתוך ספריית התוסף)
  • כחלק מ-README של התוסף (אם משתמשים בדגל Firebase CLI --markdown > README.md)

לא ניתן לגשת לערכים של הפרמטרים של התוסף בקובצי PREINSTALL, לכן לא צפוי שההפניה לפרמטרים תתבצע עם ערכים בפועל.

מהן כמה שיטות מומלצות?

  • אם אפשר, כדאי שהתוכן המלא של הקובץ PREINSTALL יעמוד בדף אחד.
  • מציינים את רמת הפירוט שחשוב מאוד שלקוח הקצה ידע לפני התקנת התוסף
  • מוסיפים הוראות מפורטות לקובץ POSTINSTALL או לקבצים משניים אחרים
  • אם אתם מספקים כלים או סקריפטים אחרים לתמיכה בתוסף, כדאי לציין זאת בקצרה

כתיבת קובץ POSTINSTALL

קובץ POSTINSTALL הוא דף ההוראות המפורט של התוסף לאחר ההתקנה.

מהו התוכן בקובץ הזה?

  • הוראות מפורטות לכל המשימות הנדרשות לאחר ההתקנה, כמו הגדרת כללי אבטחה של Firebase או הוספת קוד בצד הלקוח (דוגמה)
  • הוראות כלליות לניסיון מיידי של התוסף החדש (לדוגמה, 'נכנסים למסוף ואז מבצעים את הפעולה הזו')
  • מידע בסיסי על הפעלת התוסף, במיוחד לגבי תוספים שמופעלים על ידי בקשת HTTP
  • הוראות קצרות למעקב אחרי התוסף שהותקן (מתחילים עם טקסט סטנדרטי)

איפה התוכן הזה מוצג למשתמש?

תמונה של תוכן לאחר ההתקנה ב-<span class=מסוף Firebase">
תוכן לאחר ההתקנה במסוף Firebase

תמונה גדולה של תוכן לאחר ההתקנה ב-<span class=מסוף Firebase">

  • במסוף Firebase אחרי שמשתמש מתקין את התוסף (בכרטיס הפרטים של התוסף החדש)

  • מאגר קוד המקור של התוסף (בתוך ספריית התוסף)

קבצים מסוג POSTINSTALL יכולים לגשת לערכים של הפרמטרים ולמספר משתנים שקשורים לפונקציה של התוסף. כשהתוכן של POSTINSTALL מוצג במסוף Firebase, מוצגים הערכים בפועל ולא הפניות למשתנה או לפרמטר. בהמשך מוסבר איך להפנות לפרמטרים ולמשתנים בקובץ POSTINSTALL.

מהן כמה שיטות מומלצות?

  • התוכן המלא של הקובץ POSTINSTALL צריך להיות תמציתי אבל תיאורי.
  • כדאי לפצל את התוכן באמצעות כותרות כדי להפריד בין משימות או מושגים נפרדים.
  • כדאי לפרסם הוראות מפורטות לגבי תהליך עבודה או משימה ספציפיים באתר שלכם (דוגמה) או בקובצי markdown משלימים במאגר התוספים (דוגמה).
  • הפניה לפרמטרים ולמשתנים שקשורים לפונקציות כדי שהמשתמש יראה את הערכים שהוגדרו בהם בהקשר של ההוראות

הפניה לפרמטרים ולמשתנים

אחרי ההתקנה, במסוף Firebase יוצג התוכן של הקובץ POSTINSTALL של התוסף. אם מפנים לקובץ POSTINSTALL פרמטרים ומשתנים שקשורים לפונקציות (ראו טבלה בהמשך), מסוף ה-CLI מאכלס את ההפניות האלה בערכים האמיתיים של המכונה המותקנת.

כדי לגשת לערכים של פרמטרים שהוגדרו בקובץ POSTINSTALL, משתמשים בתחביר הבא: ${param:PARAMETER_NAME}

אפשר גם להפנות למשתנים הבאים שקשורים לפונקציה בקובץ POSTINSTALL בלבד. Firebase תומך במשתנים האלה כדי שתוכלו לספק למשתמשים הנחיות בקלות רבה יותר לאחר ההתקנה. אפשר להשתמש בהם רק בקובץ POSTINSTALL כי הערכים של המשתנים האלה זמינים רק אחרי ההתקנה.

בטבלה הזו, הערך של השדה name באובייקט המשאב של הפונקציה ב-extension.yaml הוא function-name.

הפניה למשתנה שקשור לפונקציה תיאור ערך משתנה (מערכת Firebase מאכלסת אותו באופן אוטומטי אחרי התקנת התוסף)
${function:function-name.location}
המיקום שבו הפונקציה פרוסה ערך לדוגמה:
us-central1
${function:function-name.name}
השם של הפונקציה שפורסה בסוף, שכולל את מזהה המכונה של התוסף

פורמט כללי:
ext-extension-instance-id-function-name

ערך לדוגמה:
ext-my-awesome-extension-6m31-yourFunctionName

${function:function-name.url} (רלוונטי רק לפונקציות HTTP)
כתובת ה-URL של הפונקציה שפרוסה, שאליה קוד הלקוח יכול לשלוח בקשות HTTP

פורמט כללי:
https://deployment-location-project-id.cloudfunctions.net/name-of-final-deployed-function

ערך לדוגמה:
https://us-central1-project-123.cloudfunctions.net/ext-my-awesome-extension-6m31-yourFunctionName

תיעוד של האופן שבו מפעילים תוסף

במסמכי העזרה של התוסף, צריך להנחות את המשתמשים איך להפעיל אותו. ההוראות האלה יכולות להיות מפורטות ככל הצורך, אבל חשוב לזכור את השיטות המומלצות לכתיבת קובץ POSTINSTALL. כדי לקבל הנחיות לגבי אופן ההוספה של ההוראות האלה, אפשר להרחיב את הקטע הבא שרלוונטי לתוסף שלכם.

כתיבת קובץ CHANGELOG

מהו התוכן בקובץ הזה?

לכל תוסף חייב להיות קובץ CHANGELOG.md שמתעד את השינויים שכלולים בכל גרסה חדשה של התוסף שאתם מפרסמים. צריך להציב כל גרסה מתחת לכותרת ברמה 2 (##). אחרת, אפשר להשתמש בכל עיצוב Markdown שרוצים.

הדוגמה הבאה היא קטע מאחד מהתוספים הרשמיים:

## Version 0.1.3

feature - Support deletion of directories (issue #148).

## Version 0.1.2

feature - Add a new param for recursively deleting subcollections in Cloud
Firestore (issue #14).

fixed - Fixed "cold start" errors experienced when the extension runs after a
period of inactivity (issue #48).

## Version 0.1.1

Initial release of the _Delete User Data_ extension.

איפה התוכן הזה מוצג למשתמש?

  • במסוף Firebase וב-CLI, כשמשתמשים משדרגים לגרסאות חדשות של התוסף. במסוף Firebase וב-CLI מוצגים רק השינויים שיחולו אם המשתמש ישלים את השדרוג.
  • מאגר קוד המקור של התוסף (בתוך ספריית התוסף).