Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Roll your own Disqus-like comments solution powered by Firebase.
This is a bloddy pre-alpha. Use with care!
Download the firelogue
-binary for your system:
Unpack the Zip-file and store the binary in a folder on your system, e.g. named ./firelogue
.
First of all you need a project on Firebase — so create one. After that go to the project settings
and enter "Service accounts"-tab. Click the button "Generate new private key" and store the
resulting file as firebase-admin.json
in the previously created ./firelogue
folder besides the
firelogue
binary.
First of all open the ./firelogue
folder in your Terminal and run …
$ ./firelogue login
This will open an OAuth screen in the browser, that authenticates the Terminal session on Firebase.
To check whether you're already in or with which user, run …
$ ./firelogue whoami
To be able to log into the Firelogue Management Console, you need to create a user. To do that, run the following command in the Terminal …
$ ./firelogue create-user
There'll be prompts asking for an email address, a username and a password. Enter all the information and you're done.
When you're logged in with Firebase and you've created the admin user, you're almost prepared for installing Firelogue to your Firebase app. But there's still one piece missing: the Web API key. To obtain that, go back to the project settings of your Firebase app. The Web API key is displayed in the General settings. Copy it and pass it to the following command in the Terminal …
$ ./firelogue install --apiKey <the Web API key>
There's another, optional parameter to this command: the --region
. By default the cloud functions,
Fireloque uses to read and write comments, are located in europe-west1
. If you want to choose
a different location, pass the code to the install
-command.
$ ./firelogue install --apiKey <the Web API key> --region <key of the code>
Find a list of available region codes here.
After the command has finished, Firelogue is ready for use! The URL to the Maagement Console is printed into the Terminal output as well as the URL of the script, that brings the comment widget on your sites.
Take the URL to the Management Console from the Terminal output of the installation and log into the console in your browser. Then use the form to add a website. Firelogue will only store comments for websites, that have been set up in the Management Console in beforehand.
From the list of websites in the console, copy the website ID. You'll need that one, to include the comment widget into the site.
To include the widget into your site, paste the following snippet into the HTML of your website:
<script>
window.firelogue = window.firelogue || [];
window.firelogue.push((init) => {
var options = {
root: document.getElementById('comments'), // Empty <div /> that'll hold the widget
websiteId: '<ID of current website>', // Get this from the Management Console
pagePath: '/foo/bar/', // optional; Firelogue will use `location.pathname` if pagePath isn't set
}
var api = init(options); // See next section to learn what the API is for
});
</script>
<script src="https://<Project ID>.firebaseapp.com/client/firelogue.js"></script>
Don't forget to replace the <Project ID>
in the URL of the javascript file with the actual ID of
your Firebase app!
The pagePath
-property of the options
object is optional. But be careful: if you can't ensure
that your pages are available by a single URL only (e.g. the page might be served with and without
leading slash), then you better set this property explicitly. Otherwise you might end up with
multiple comment lists for the same content.
If your site relies on history.pushState
for routing, you'll have to take care of
re-initializing the Firelogue widget yourself. That's where the API comes into play, that got
returned by the init
-function.
The API is an object holding an update
-method. If a visitor navigates to a new page of your site,
you have to call this update
-method and pass the pathname of the current page to it.
This might look something like this …
var api;
// Initialize Firelogue to obtain the API ...
function onHistoryChange() {
api.update(location.pathname);
}
That's it. The widget will re-initialize and load the comments of the current page.
The Firelogue widget comes with a very basic styling. To align it visually with your website,
you can use the data-firelogue
-selectors to apply custom CSS styling.
[data-firelogue='app'] {
padding: 16px;
margin: 32px;
border: 4px dotted fuchsia;
}
Beware: Do not use the classnames of the elements, since they're generated based on their
content and might change in the future. Which will break your custom styling. The
data-firelogue
-attributes won't change, so you're on the save side using them.
If you have questions or running into problems, feel free to open an issue.
FAQs
> Roll your own Disqus-like comments solution powered by Firebase.
The npm package firelogue receives a total of 1 weekly downloads. As such, firelogue popularity was classified as not popular.
We found that firelogue demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.