The Firebase Hosting REST API enables programmatic and customizable management and deployments to your Firebase-hosted sites. Use this REST API to create and manage channels and sites as well as to deploy new or updated hosting configurations and content files. For detailed description please check documentation.
Install typings for Firebase Hosting API:
npm install @types/gapi.client.firebasehosting-v1beta1 --save-dev
You need to initialize Google API client in your code:
gapi.load('client', () => {
// now we can use gapi.client
// ...
});
Then load api client wrapper:
gapi.client.load(
'https://firebasehosting.googleapis.com/$discovery/rest?version=v1beta1',
() => {
// now we can use:
// gapi.client.firebasehosting
}
);
// Deprecated, use discovery document URL, see https://github.com/google/google-api-javascript-client/blob/master/docs/reference.md#----gapiclientloadname----version----callback--
gapi.client.load('firebasehosting', 'v1beta1', () => {
// now we can use:
// gapi.client.firebasehosting
});
Don't forget to authenticate your client before sending any request to resources:
// declare client_id registered in Google Developers Console
var client_id = '',
scope = [
// See, edit, configure, and delete your Google Cloud data and see the email address for your Google Account.
'https://www.googleapis.com/auth/cloud-platform',
// View your data across Google Cloud services and see the email address of your Google Account
'https://www.googleapis.com/auth/cloud-platform.read-only',
// View and administer all your Firebase data and settings
'https://www.googleapis.com/auth/firebase',
// View all your Firebase data and settings
'https://www.googleapis.com/auth/firebase.readonly',
],
immediate = true;
// ...
gapi.auth.authorize(
{client_id: client_id, scope: scope, immediate: immediate},
authResult => {
if (authResult && !authResult.error) {
/* handle successful authorization */
} else {
/* handle authorization error */
}
}
);
After that you can use Firebase Hosting API resources:
/*
Gets the Hosting metadata for a specific site.
*/
await gapi.client.firebasehosting.sites.getConfig({name: 'name'});
/*
Sets the Hosting metadata for a specific site.
*/
await gapi.client.firebasehosting.sites.updateConfig({name: 'name'});