Начало работы с Cloud Storage для C++

Облачное хранилище для Firebase позволяет загружать и делиться созданным пользователем контентом, таким как изображения и видео, что позволяет встраивать мультимедийный контент в ваши приложения. Ваши данные хранятся в корзине Google Cloud Storage — объектном хранилище эксабайтного масштаба с высокой доступностью и глобальной избыточностью. Облачное хранилище для Firebase позволяет безопасно загружать эти файлы непосредственно с мобильных устройств и веб-браузеров, с легкостью обрабатывая нестабильные сети.

Прежде чем вы начнете

Прежде чем вы сможете использовать облачное хранилище , вам необходимо:

  • Зарегистрируйте свой проект C++ и настройте его для использования Firebase.

    Если ваш проект C++ уже использует Firebase, значит, он уже зарегистрирован и настроен для Firebase.

  • Добавьте Firebase C++ SDK в свой проект C++.

Обратите внимание, что добавление Firebase в ваш проект C++ включает задачи как в консоли Firebase , так и в вашем открытом проекте C++ (например, вы загружаете файлы конфигурации Firebase из консоли, а затем перемещаете их в свой проект C++).

Создание корзины Cloud Storage по умолчанию

  1. На панели навигации консоли Firebase выберите «Хранилище» , затем нажмите «Начать» .

  2. Ознакомьтесь с сообщениями о защите ваших данных в облачном хранилище с помощью правил безопасности. Во время разработки подумайте о настройке правил для общего доступа .

  3. Выберите расположение для корзины Cloud Storage по умолчанию.

    • Этот параметр местоположения является расположением ресурса Google Cloud Platform (GCP) по умолчанию для вашего проекта . Обратите внимание, что это местоположение будет использоваться для сервисов GCP в вашем проекте, для которых требуется настройка местоположения, в частности, для вашей базы данных Cloud Firestore и вашего приложения App Engine (что требуется, если вы используете Cloud Scheduler).

    • Если вы не можете выбрать местоположение, значит, в вашем проекте уже есть местоположение ресурса GCP по умолчанию. Он был установлен либо при создании проекта, либо при настройке другого сервиса, требующего настройки местоположения.

    Если вы пользуетесь тарифным планом Blaze, вы можете создать несколько сегментов , каждый из которых будет иметь собственное местоположение .

  4. Щелкните Готово .

Настроить публичный доступ

Облачное хранилище для Firebase предоставляет язык декларативных правил, который позволяет вам определять, как ваши данные должны быть структурированы, как они должны индексироваться и когда ваши данные могут быть прочитаны и записаны. По умолчанию доступ к облачному хранилищу для чтения и записи ограничен, поэтому только пользователи, прошедшие проверку подлинности, могут читать или записывать данные. Чтобы начать работу без настройки аутентификации , вы можете настроить свои правила для общего доступа .

Это делает облачное хранилище открытым для всех, даже для людей, не использующих ваше приложение, поэтому не забудьте снова ограничить свое облачное хранилище при настройке аутентификации.

Создайте и инициализируйте firebase::App

Прежде чем вы сможете получить доступ к облачному хранилищу, вам необходимо создать и инициализировать firebase::App .

Включите заголовочный файл для firebase::App :

#include "firebase/app.h"

Андроид

Создайте firebase::App , передав среду JNI и jobject на проект Java Activity в качестве аргументов:

app = App::Create(AppOptions(), jni_env, activity);

iOS+

Создайте firebase::App :

app = App::Create(AppOptions());

Доступ к классу firebase::storage::Storage

Класс firebase::storage::Storage — это точка входа для Cloud Storage C++ SDK.

Storage* storage = Storage::GetInstance(app);

Вы готовы начать использовать облачное хранилище!

Во-первых, давайте узнаем, как создать ссылку на облачное хранилище .

Advanced Setup

Есть несколько вариантов использования, которые требуют дополнительной настройки:

Первый вариант использования идеален, если у вас есть пользователи по всему миру и вы хотите хранить их данные рядом с ними. Например, вы можете создавать корзины в США, Европе и Азии для хранения данных для пользователей в этих регионах, чтобы уменьшить задержку.

Второй вариант использования полезен, если у вас есть данные с разными шаблонами доступа. Например: вы можете настроить многорегиональную или региональную корзину, в которой хранятся изображения или другое часто используемое содержимое, а также корзину ближней или холодной линии, в которой хранятся резервные копии пользователей или другое редко используемое содержимое.

В любом из этих вариантов использования вам понадобится несколько сегментов Cloud Storage .

Третий вариант использования полезен, если вы создаете приложение, такое как Google Диск, которое позволяет пользователям иметь несколько учетных записей (например, личную учетную запись и рабочую учетную запись). Вы можете использовать собственный экземпляр приложения Firebase для аутентификации каждой дополнительной учетной записи.

Используйте несколько сегментов облачного хранилища

Если вы хотите использовать ведро Cloud Storage, отличное от указанного выше по умолчанию, или использовать несколько сегментов Cloud Storage в одном приложении, вы можете создать экземпляр firebase::storage::Storage , который ссылается на ваш пользовательский сегмент:

// Get a non-default Cloud Storage bucket
Storage* storage = Storage::GetInstance("gs://my-custom-bucket");

Работа с импортированными сегментами

При импорте существующей корзины Cloud Storage в Firebase вам нужно будет предоставить Firebase возможность доступа к этим файлам с помощью инструмента gsutil , включенного в Google Cloud SDK :

gsutil -m acl ch -r -u service-<project number>@gcp-sa-firebasestorage.iam.gserviceaccount.com gs://<your-cloud-storage-bucket>

Вы можете найти номер своего проекта, как описано во введении к проектам Firebase .

Это не влияет на вновь созданные сегменты, так как для них установлен контроль доступа по умолчанию, разрешающий использование Firebase. Это временная мера, и в будущем она будет выполняться автоматически.

Используйте собственное приложение Firebase

Если вы создаете более сложное приложение с помощью пользовательского firebase::App , вы можете создать экземпляр firebase::storage::Storage инициализированный этим приложением:

// Get the default bucket from a custom firebase::App
Storage* storage = Storage::GetInstance(customApp);

// Get a non-default bucket from a custom firebase::App
Storage* storage = Storage::GetInstance(customApp, "gs://my-custom-bucket");

Следующие шаги