Few plugins in the template depend on Firebase Services, i.e. Realtime Database for Post Views Counter, etc. Therefore, if you wish to use any of these plugins, you need to have a Firebase Project configured with the blog template.
Creating a Firebase Project
If you have already an existing Firebase Project created earlier, you can use it and skip the steps for creating newer one which is described below.
- Go to Firebase Console.
- Click + Create a project and follow the prompts to create a project. You can name your project anything you want.
- Once the project is created, navigate to Project settings.
- Under General > Your apps, click on </> Web and follow the prompts to create a Web app in the project.
You have now created a Firebase Project for Web Applications.
Setting up Realtime Database Rules
Adding secure rules to Realtime Database is crucial because insecure rules permits database read
and write
access to anyone on the internet, allowing them to read and modify anything in the database. Therefore, we need to add restrictions in order to make sure one cannot modify data without permission. Follow the steps below to protect your database.
- Go to Firebase Project > Realtime Database.
- Switch to Rules tab.
-
Paste the following JSON by making appropriate changes in the rules editor and click on Publish.
Warning!
The provided rules may update in future by our team in case any critical issue is found or new plugins are made available. It is recommended to update the rules as below regularly (atleast once in a month) by visiting this page.
Rules was last updated on 1st September, 2023 by Deo Kumar.{ "rules": { ".write": false, ".read": false, "blogs": { "$blog_id": { ".validate": "$blog_id.matches(/^\\d{18,22}$/) && ($blog_id === '000000000000000000' || $blog_id === '0000' || $blog_id === '0000')", "posts": { "$post_id": { ".validate": "$post_id.matches(/^\\d{18,22}$/)", "views": { ".read": true, ".write": "newData.exists()", ".validate": "newData.isNumber() && newData.val() % 1 === 0 && newData.val() === (data.exists() ? data.val() + 1 : 1)" } } } } } } }
{ "rules": { ".read": true, ".write": false } }
Getting Firebase Configurations
We now need the configuration object of our Firebase Project Web app. Follow the steps to find it.
- Navigate to your Firebase Project.
- Go to Project Settings.
-
Under General > Your apps tab, select your Web app and click on Config. You will be able to see a Javascript object which looks like the following:
const firebaseConfig = { apiKey: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx-xxxxx", authDomain: "xxxxxxxxxxxxx.firebaseapp.com", databaseURL: "https://xxxxxxxxxxxxx.firebaseio.com", projectId: "xxxxxxxxxxxxx", storageBucket: "xxxxxxxxxxxxx.appspot.com", messagingSenderId: "000000000000", appId: "1:000000000000:web:xxxxxxxxxxxxxxxxxxxxxx", measurementId: "G-XXXXXXXXXX", };
If the field
databaseURL
is not available, that means you have not created a Realtime Database instance yet, create it through Realtime Database section and re-check to make sure the fielddatabaseURL
is available.
Keep the browser tab open as we shall need the information of this object.
Setting up Firebase Configurations
We shall now add the firebase configurations to our blog.
- Go to Blogger dashboard and navigate to Layout.
- Find the Link List gadget with title Firebase Configurations (if you have not renamed it), click on Edit button.
-
Create or edit existing links for every key-value pairs, the key as Site name and the value (content under quotes) as Site URL respectively as shown below.
Your links should look as show belows:const firebaseConfig = { apiKey: "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx-xxxxx", authDomain: "xxxxxxxxxxxxx.firebaseapp.com", databaseURL: "https://xxxxxxxxxxxxx.firebaseio.com", projectId: "xxxxxxxxxxxxx", storageBucket: "xxxxxxxxxxxxx.appspot.com", messagingSenderId: "000000000000", appId: "1:000000000000:web:xxxxxxxxxxxxxxxxxxxxxx", measurementId: "G-XXXXXXXXXX", };
Site name Site URL apiKey
xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx-xxxxx
authDomain
xxxxxxxxxxxxx.firebaseapp.com
databaseURL
https://xxxxxxxxxxxxx.firebaseio.com
projectId
xxxxxxxxxxxxx
storageBucket
xxxxxxxxxxxxx.appspot.com
messagingSenderId
000000000000
appId
1:000000000000:web:xxxxxxxxxxxxxxxxxxxxxx
measurementId
G-XXXXXXXXXX
- Save the gadget to apply changes.
Done! You have successfully configured Firebase Project with your blog.