מבוא ל-Admin Cloud Storage API

Cloud Storage for Firebase שומר את הנתונים בקטגוריה Google Cloud Storage – פתרון לאחסון אובייקטים בקנה מידה של אקסה-בייט עם זמינות גבוהה ויתירות גלובלית. ה-SDK של Firebase Admin מאפשר לך לגשת ישירות Cloud Storage קטגוריות מסביבות בעלות הרשאות. ואז אפשר להשתמש ממשקי API של Google Cloud Storage כדי לבצע מניפולציות על האובייקטים שמאוחסנים בקטגוריות.

באמצעות Admin SDK אפשר גם ליצור כתובות URL שניתן לשתף, כדי שהמשתמשים יוכלו להוריד אובייקטים בקטגוריות שלכם.

שימוש בקטגוריית ברירת מחדל

אפשר לציין שם ברירת מחדל לקטגוריה כשמפעילים את Admin SDK. לאחר מכן תוכלו לאחזר הפניה מאומתת לקטגוריה הזו. שם הקטגוריה לא יכול להכיל את הערך gs:// או תחילית פרוטוקול אחרת. לדוגמה, אם הקטגוריה בכתובת ה-URL שמוצגת מסוף Firebase הוא gs://bucket-name.appspot.com, צריך להעביר את המחרוזת bucket-name.appspot.com על ה-Admin SDK.

Node.js

const { initializeApp, cert } = require('firebase-admin/app');
const { getStorage } = require('firebase-admin/storage');

const serviceAccount = require('./path/to/serviceAccountKey.json');

initializeApp({
  credential: cert(serviceAccount),
  storageBucket: '<BUCKET_NAME>.appspot.com'
});

const bucket = getStorage().bucket();

// 'bucket' is an object defined in the @google-cloud/storage library.
// See https://googlecloudplatform.github.io/google-cloud-node/#/docs/storage/latest/storage/bucket
// for more details.

Java

FileInputStream serviceAccount = new FileInputStream("path/to/serviceAccountKey.json");

FirebaseOptions options = FirebaseOptions.builder()
    .setCredentials(GoogleCredentials.fromStream(serviceAccount))
    .setStorageBucket("<BUCKET_NAME>.appspot.com")
    .build();
FirebaseApp.initializeApp(options);

Bucket bucket = StorageClient.getInstance().bucket();

// 'bucket' is an object defined in the google-cloud-storage Java library.
// See http://googlecloudplatform.github.io/google-cloud-java/latest/apidocs/com/google/cloud/storage/Bucket.html
// for more details.

Python

import firebase_admin
from firebase_admin import credentials
from firebase_admin import storage

cred = credentials.Certificate('path/to/serviceAccountKey.json')
firebase_admin.initialize_app(cred, {
    'storageBucket': '<BUCKET_NAME>.appspot.com'
})

bucket = storage.bucket()

# 'bucket' is an object defined in the google-cloud-storage Python library.
# See https://googlecloudplatform.github.io/google-cloud-python/latest/storage/buckets.html
# for more details.

Go

import (
	"context"
	"log"

	firebase "firebase.google.com/go/v4"
	"firebase.google.com/go/v4/auth"
	"google.golang.org/api/option"
)

config := &firebase.Config{
	StorageBucket: "<BUCKET_NAME>.appspot.com",
}
opt := option.WithCredentialsFile("path/to/serviceAccountKey.json")
app, err := firebase.NewApp(context.Background(), config, opt)
if err != nil {
	log.Fatalln(err)
}

client, err := app.Storage(context.Background())
if err != nil {
	log.Fatalln(err)
}

bucket, err := client.DefaultBucket()
if err != nil {
	log.Fatalln(err)
}
// 'bucket' is an object defined in the cloud.google.com/go/storage package.
// See https://godoc.org/cloud.google.com/go/storage#BucketHandle
// for more details.

אפשר להשתמש בהפניות לקטגוריות שחוזרות מה-SDK של Admin בשילוב עם ספריות הלקוח הרשמיות של Google Cloud Storage כדי להעלות, להוריד ולשנות תוכן בקטגוריות שמשויכות לפרויקטים ב-Firebase. לתשומת ליבכם: אין צורך באימות Google Cloud Storage ספריות כשמשתמשים ב-Firebase Admin SDK. ההפניות לקטגוריות שמוחזרות על ידי Admin SDK כבר מאומתות באמצעות פרטי הכניסה ששימשו להפעלה של אפליקציית Firebase.

שימוש בקטגוריות בהתאמה אישית

אם רוצים להשתמש בקטגוריית Cloud Storage שאינה ברירת המחדל שצוינה למעלה, או להשתמש בכמה קטגוריות Cloud Storage באפליקציה אחת, אפשר לאחזר הפניה לקטגוריה בהתאמה אישית באופן הבא:

Node.js

const bucket = getStorage().bucket('my-custom-bucket');

Java

Bucket bucket = StorageClient.getInstance().bucket("my-custom-bucket");

Python

bucket = storage.bucket('my-custom-bucket')

Go

 bucket, err := client.Bucket("my-custom-bucket")

שימוש באפליקציית Firebase בהתאמה אישית

אם אתם מפתחים אפליקציה מורכבת יותר שמקיימת אינטראקציה עם מספר אפליקציות Firebase, תוכלו לגשת לקטגוריות Cloud Storage שמשויכות לאפליקציית Firebase ספציפית באופן הבא:

Node.js

const bucket = getStorage(customApp).bucket();

Java

Bucket bucket = StorageClient.getInstance(customApp).bucket();

Python

bucket = storage.bucket(app=custom_app)

Go

otherClient, err := otherApp.Storage(context.Background())
bucket, err := otherClient.Bucket("other-app-bucket")

קבלת כתובת URL להורדה שניתנת לשיתוף

אפשר להשתמש ב-Admin SDK כדי ליצור כתובת URL להורדה שלא עומדת לפוג עבור הקבצים שמאוחסנים בקטגוריות שלכם. כל מי שיש לו את כתובת ה-URL הזו יכול לגשת לקובץ באופן קבוע.

Node.js

const { getStorage, getDownloadURL } = require('firebase-admin/storage');

const fileRef = getStorage().bucket('my-bucket').file('my-file');
const downloadURL= await getDownloadURL(fileRef);

Google Cloud Storage ספריות לקוח

ערכות ה-SDK של Firebase Admin תלויות בספריות הלקוח של Google Cloud Storage כדי לספק גישה ל-Cloud Storage. הפניות לקטגוריות שמוחזרות על ידי Admin SDK הן אובייקטים שמוגדרים בספריות האלה. אפשר לעיין במסמכי התיעוד הפניות API של ספריות הלקוח ב-Google Cloud Storage כדי ללמוד איך משתמשים בהפניות לקטגוריות שמוחזרות בתרחישים לדוגמה, כמו upload וגם הורדה.