Trang này giải thích cách bạn có thể xuất bản một tiện ích trên Extensions Hub.
Trước khi bắt đầu
Để xuất bản một tiện ích, trước tiên, bạn cần đăng ký làm nhà xuất bản tiện ích.
Nguồn có thể xác minh
Tất cả tiện ích được xuất bản trên Extensions Hub đều phải có nguồn có thể xác minh công khai. Thay vì tải trực tiếp mã nguồn tiện ích lên Extension Hub, bạn chỉ cần chỉ định vị trí nguồn và Extension Hub sẽ tải mã nguồn xuống rồi tạo tiện ích từ đó.
Hiện tại, điều này có nghĩa là bạn phải cung cấp mã nguồn tiện ích của mình trên một kho lưu trữ GitHub công khai.
Việc tải lên từ một nguồn có thể xác minh được mang lại một số lợi ích:
- Người dùng có thể kiểm tra mã nguồn của bản sửa đổi cụ thể của tiện ích sẽ được cài đặt.
- Bạn có thể đảm bảo chỉ tải những nội dung bạn muốn tải lên, chứ không phải, ví dụ: công việc đang tiến hành hoặc các tệp còn sót lại trong quá trình phát triển.
Chu kỳ phát triển được đề xuất
Các công cụ phát triển Tiện ích Firebase hỗ trợ việc tải các phiên bản trước khi phát hành của tiện ích lên. Nhờ đó, bạn có thể dễ dàng kiểm thử tiện ích và quy trình cài đặt tiện ích trong cùng một môi trường mà tiện ích sẽ được phát hành.
Khả năng này giúp bạn có thể thực hiện một chu kỳ phát triển như sau:
Phát triển và nhanh chóng lặp lại tiện ích của bạn bằng Bộ mô phỏng Firebase.
Kiểm thử tiện ích trong một dự án thực bằng cách cài đặt tiện ích đó từ nguồn cục bộ:
firebase ext:install /path/to/extension
firebase deploy --only extensions
Tải một phiên bản phát hành trước lên Trung tâm tiện ích (xem bên dưới). Phân phối đường liên kết cài đặt để thử nghiệm trên diện rộng và lặp lại bằng cách tải thêm các phiên bản phát hành trước lên nếu cần.
Tải phiên bản cuối cùng, ổn định lên Extensions Hub (xem bên dưới) rồi gửi để xem xét. Nếu vượt qua quy trình xem xét, tiện ích sẽ được xuất bản trên Extension Hub.
Tăng số phiên bản trong
extension.yaml
và lặp lại chu kỳ này cho phiên bản tiếp theo của tiện ích.
Tải tiện ích mới lên
Cách tải một tiện ích lên lần đầu tiên:
Không bắt buộc: Xác nhận mã của bạn vào một kho lưu trữ GitHub công khai.
Chạy lệnh
ext:dev:upload
của Giao diện dòng lệnh (CLI) của Firebase:GitHub
firebase ext:dev:upload your_publisher_id/your_extension_id
Nguồn địa phương
cd /path/to/extension
firebase ext:dev:upload your_publisher_id/your_extension_id --local
Trong lệnh gọi, bạn chỉ định những thông tin sau:
Mã nhà xuất bản mà bạn đã đăng ký.
Một chuỗi mã nhận dạng sẽ xác định tiện ích. Đặt tên cho tiện ích theo định dạng sau:
firebase-product-description-of-tasks-performed
. Ví dụ:firestore-bigquery-export
Lệnh này sẽ nhắc bạn cung cấp thêm thông tin:
Nếu bạn đang tải lên từ GitHub:
URL đến kho lưu trữ của tiện ích trên GitHub. Xin lưu ý rằng một kho lưu trữ có thể chứa nhiều tiện ích miễn là mỗi tiện ích có một thư mục gốc riêng biệt.
Khi bạn tải một tiện ích mới lên lần đầu tiên, kho lưu trữ sẽ được đăng ký làm nguồn chính tắc cho tiện ích của bạn.
Thư mục trong kho lưu trữ chứa tiện ích của bạn.
Tham chiếu Git của cam kết mà bạn muốn tạo nguồn phiên bản tiện ích. Đây có thể là một hàm băm cam kết, thẻ hoặc tên nhánh.
Giai đoạn phát hành của phiên bản mà bạn đang tải lên.
Các giai đoạn
alpha
,beta
vàrc
(bản phát hành dùng thử) là để tải các phiên bản trước khi phát hành lên để người kiểm thử cài đặt. Sử dụng một trong các giai đoạn này để tải lên phần mở rộng mới lần đầu.Giai đoạn
stable
được dùng cho các bản phát hành công khai sẽ được xuất bản trên Trung tâm tiện ích. Việc tải bản phát hànhstable
lên sẽ tự động bắt đầu quy trình xem xét và nếu vượt qua, bản phát hành đó sẽ xuất bản tiện ích.
Lưu ý rằng bạn không chỉ định số phiên bản – giá trị này lấy từ tệp
extension.yaml
. Khi bạn tải một phiên bản tiện ích phát hành trước lên, giai đoạn và số lượt tải lên sẽ được thêm vào phiên bản đó. Ví dụ: nếuextension.yaml
chỉ định phiên bản 1.0.1 và bạn tải một bản phát hành thử nghiệm lên, thì phiên bản đó sẽ là1.0.1-rc.0
; việc tải một bản phát hành thử nghiệm khác của cùng phiên bản lên sẽ tự động tăng số lượng, dẫn đến1.0.1-rc.1
, v.v.
Giờ đây, sau khi tải một phiên bản phát hành trước của tiện ích lên, bạn có thể chia sẻ phiên bản đó với người khác để kiểm thử. Người dùng có thể cài đặt tiện ích của bạn theo một trong hai cách sau:
Với bảng điều khiển: Người dùng có thể cài đặt tiện ích bằng cách nhấp vào một đường liên kết có định dạng sau:
https://console.firebase.google.com/project/_/extensions/install?ref=your_publisher_id/your_extension_id@version
Bạn có thể chia sẻ đường liên kết trực tiếp với người kiểm thử.
Với CLI: Người dùng có thể cài đặt tiện ích bằng cách truyền chuỗi mã nhận dạng tiện ích đến lệnh
ext:install
:firebase ext:install your_publisher_id/your_extension_id@version \ --project=destination_project_id
Tải phiên bản mới lên
Sau khi tải phiên bản đầu tiên của một tiện ích lên, bạn có thể tải các bản cập nhật lên để khắc phục vấn đề, thêm tính năng hoặc chuyển sang giai đoạn phát hành tiếp theo. Khi bạn tải một phiên bản mới lên, những người dùng đã cài đặt phiên bản cũ hơn của tiện ích sẽ được nhắc nâng cấp trong bảng điều khiển Firebase.
Cách tải nội dung cập nhật lên:
Không bắt buộc: Xác nhận mã của bạn vào một kho lưu trữ Git công khai.
Chạy lệnh
ext:dev:upload
của Giao diện dòng lệnh (CLI) của Firebase:GitHub
firebase ext:dev:upload your_publisher_id/your_extension_id
Lần này, bạn sẽ không được nhắc chỉ định kho lưu trữ GitHub hoặc thư mục gốc của tiện ích vì chúng đã được định cấu hình cho tiện ích của bạn. Nếu đã tái cấu trúc cấu trúc kho lưu trữ hoặc di chuyển sang một kho lưu trữ mới, bạn có thể thay đổi các kho lưu trữ đó bằng các đối số lệnh
--root
và--repo
.Nguồn địa phương
cd /path/to/extension
firebase ext:dev:upload your_publisher_id/your_extension_id --local
Gửi tiện ích để xuất bản
Khi bạn đã sẵn sàng phát hành công khai tiện ích:
Xác nhận mã của bạn vào một kho lưu trữ Git công khai. (Bắt buộc đối với bản phát hành công khai.)
Chạy lệnh
ext:dev:upload
của Firebase CLI, chỉ địnhstable
làm giai đoạn phát hành:firebase ext:dev:upload your_publisher_id/your_extension_id
Nếu trước đây bạn đã xuất bản một phiên bản của tiện ích, thì việc tải một bản phát hành ổn định mới lên sẽ tự động gửi tiện ích đó đi xem xét.
Nếu bạn đã tải bản phát hành ổn định đầu tiên của tiện ích lên, hãy tìm tiện ích đó trên trang tổng quan dành cho nhà xuất bản rồi nhấp vào Xuất bản lên Trung tâm tiện ích.
Sau khi bạn gửi, quá trình xem xét có thể mất vài ngày. Nếu được chấp nhận, tiện ích sẽ được xuất bản lên Trung tâm tiện ích. Nếu bị từ chối, bạn sẽ nhận được thông báo giải thích lý do. Sau đó, bạn có thể giải quyết các vấn đề được báo cáo và gửi lại để chúng tôi xem xét.
Để đẩy nhanh quy trình xem xét và tăng cơ hội vượt qua ngay lần đầu tiên, trước khi gửi, hãy kiểm tra kỹ những nội dung sau:
- Bạn đã kiểm thử kỹ lưỡng tiện ích và quy trình cài đặt.
- Tài liệu của bạn đầy đủ và chính xác, đồng thời hiển thị tốt trong bảng điều khiển Firebase.
- Tên và thương hiệu của nhà xuất bản phải xác định rõ ràng và chính xác bạn là nhà xuất bản.
- Tên, nội dung mô tả và biểu tượng của tiện ích thể hiện rõ ràng và chính xác mục đích của tiện ích.
- Bạn đã áp dụng các thẻ hữu ích và chính xác.
- Bạn đã khai báo trong
extension.yaml
tất cả các API của Google và không phải của Google mà bạn sử dụng, cũng như tất cả các loại sự kiện mà tiện ích của bạn phát ra. - Bạn chỉ yêu cầu quyền truy cập vào những vai trò cần thiết để tiện ích hoạt động và bạn đã giải thích rõ ràng cho người dùng lý do bạn cần quyền truy cập đó.
- Các tệp nguồn của bạn được cấp phép rõ ràng theo các điều khoản của
Apache-2.0
.
Quản lý tiện ích đã tải lên và đã xuất bản
Liệt kê các tiện ích bạn đã tải lên
Để liệt kê các tiện ích mà bạn đã tải lên theo mã nhà xuất bản của mình, hãy thực hiện một trong những thao tác sau:
Trang tổng quan dành cho nhà xuất bản
Xem các chỉ số này trên trang tổng quan dành cho nhà xuất bản.
Giao diện dòng lệnh (CLI) của Firebase
Chạy lệnh ext:dev:list
:
firebase ext:dev:list your_publisher_id
Xem mức sử dụng của các tiện ích bạn đã tải lên
Để xem mức sử dụng của các tiện ích mà bạn đã tải lên theo mã nhà xuất bản của mình, hãy làm một trong những việc sau:
Trang tổng quan dành cho nhà xuất bản
Trang tổng quan dành cho nhà xuất bản có các chỉ số sử dụng tích luỹ cho tất cả các tiện ích của bạn và các chỉ số riêng lẻ cho từng tiện ích.
Giao diện dòng lệnh (CLI) của Firebase
Chạy lệnh ext:dev:usage
:
firebase ext:dev:usage your_publisher_id
Ngừng cung cấp một phiên bản của tiện ích
Tại một thời điểm nào đó, bạn có thể muốn ngừng sử dụng một phiên bản cũ của tiện ích. Ví dụ: nếu bạn phát hành một phiên bản mới để khắc phục một lỗi nghiêm trọng hoặc cập nhật một phần phụ thuộc bằng một bản cập nhật bảo mật quan trọng, thì bạn cần ngăn người dùng mới cài đặt phiên bản cũ và khuyến khích người dùng hiện tại nâng cấp.
Để ngừng cung cấp một phiên bản của tiện ích, hãy làm theo một trong những cách sau:
Trang tổng quan dành cho nhà xuất bản
- Trên trang tổng quan dành cho nhà xuất bản, hãy nhấp vào tiện ích để mở chế độ xem chi tiết của tiện ích đó.
- Chọn phiên bản bạn muốn ngừng cung cấp.
- Nhấp vào Ngừng cung cấp phiên bản.
Giao diện dòng lệnh (CLI) của Firebase
Chạy lệnh ext:dev:deprecate
:
firebase ext:dev:deprecate your_publisher_id/your_extension_id versions \
[--message "deprecation_message"]
Bạn có thể chỉ định một phiên bản hoặc một dải phiên bản. Ví dụ:
1.0.2
1.1.0-1.1.7
<1.2.0
1.1.*
Các phiên bản không dùng nữa của một tiện ích sẽ không xuất hiện trên Trung tâm tiện ích và không thể cài đặt. Những người dùng đã cài đặt phiên bản không dùng nữa cho dự án của mình sẽ thấy một thông báo khuyến khích họ nâng cấp; trong thời gian chờ đợi, họ vẫn có thể sử dụng và định cấu hình lại tiện ích này.
Nếu mọi phiên bản của một tiện ích đều không được dùng nữa, thì tiện ích đó sẽ được coi là không được dùng nữa và sẽ bị xoá khỏi Trung tâm tiện ích. Việc tải một phiên bản mới của tiện ích không dùng nữa lên sẽ tự động bắt đầu quy trình xem xét và sau khi được chấp nhận, tiện ích đó sẽ được xuất bản lại trên Trung tâm tiện ích.
Để huỷ bỏ một quy trình ngừng sử dụng, hãy sử dụng trang tổng quan dành cho nhà xuất bản hoặc chạy lệnh ext:dev:undeprecate
của Firebase CLI:
firebase ext:dev:undeprecate your_publisher_id/your_extension_id versions
Phụ lục: Khắc phục lỗi bản dựng
Khi bạn tải tiện ích lên, trước tiên, hệ thống phụ trợ sẽ tạo mã nguồn của bạn bằng quy trình sau:
Sao chép kho lưu trữ GitHub của bạn và kiểm tra nguồn được chỉ định.
Cài đặt các phần phụ thuộc NPM bằng cách chạy
npm clean-install
trong mọi thư mục nguồn hàm được chỉ định trongextension.yaml
(xemsourceDirectory
trong tài nguyên Cloud Functions).Lưu ý những điều sau:
Mỗi tệp
package.json
phải có một tệppackage-lock.json
tương ứng. Để biết thêm thông tin, hãy xem npm-ci.Tập lệnh sau khi cài đặt sẽ không chạy trong quá trình cài đặt phần phụ thuộc. Nếu bản dựng mã nguồn của bạn dựa vào các tập lệnh sau khi cài đặt, hãy tái cấu trúc bản dựng đó trước khi tải lên.
Tạo mã bằng cách chạy
npm run build
trong mọi thư mục nguồn hàm được chỉ định trongextension.yaml
.
Chỉ thư mục gốc của tiện ích mới được lưu trong gói tiện ích cuối cùng sẽ được chia sẻ.
Nếu bạn gặp lỗi khi tạo trong quá trình tải tiện ích lên, hãy sao chép các bước tạo ở trên vào một thư mục mới trên máy cho đến khi không còn lỗi, sau đó thử tải lên lại.