Secure Audit Logging
Made by Pangea
Record security critical app events using Pangea Secure Audit Log service by writing to a specified Cloud Firestore collection (uses the Pangea Secure Audit Log API).
- Works with
- Authentication and Cloud Firestore
- Version
- 0.1.0 | Source code
- License
- Apache-2.0
- Publisher
- Pangea
- Report
- Bug
- Abuse
How this extension works
Use this extension to securely log sensitive events using Pangea tamperproof Secure Audit Log service by writing log messages to a Cloud Firestore collection or by emitting an EventArc event.
This extension listens to your specified Cloud Firestore collection. If you add a string or event object map to a specified field in any document within that collection, this extension:
- Securely Logs the string or event using the Pangea Secure Audit Log service. Logs can later be viewed using the Pangea Dashboard Secure Audit Log Viewer.
- Hashes of each log entry will be recorded on a tamperproof blockchain and can be cryptographically verified for authenticity.
You can specify the desired metadata types in addition to the message for each log entry, such as, actor, action, source, target, and status. For more information on the Pangea Secure Audit Log service reference the Documentation.
If the original input field of the document is updated, a new log entry will be automatically created.
Logging messages (Firestore)
Each log is comprised of a set of fields designed to record specific components of the activity being recorded. The only required field is message, with all others being optional.
getFirestore().collection("audit").add({
log: "Record created",
});
Logging messages with optional metadata (Firestore)
To create an entry with optional metadata fields, store a map containing the optional fields as keys and values as strings.
getFirestore()
.collection("audit")
.add({
log: {
message: "Record created with metadata",
actor: "User 1",
action: "Create",
source: "Firebase client",
target: "Database",
status: "Completed",
},
});
Multiple log entries (Firestore)
To log multiple entries, store an array of either maps or strings:
getFirestore()
.collection("audit")
.add({
log: [
{
message: "First record created",
actor: "User 1",
action: "Create",
source: "Firebase client",
target: "Database",
status: "Completed",
},
{
message: "Second record created",
actor: "User 1",
action: "Create",
source: "Firebase client",
target: "Database",
status: "Completed",
},
{
message: "Third record created",
actor: "User 1",
action: "Create",
source: "Firebase client",
target: "Database",
status: "Completed",
},
],
});
Logging messages (EventArc)
getEventarc().channel().publish({
type: "firebase.extensions.pangea-audit-log.v1.log",
data: {
message: "Record created with metadata",
actor: "User 1",
action: "Create",
source: "Firebase client",
target: "Database",
status: "Completed",
}},
});
Additional setup
Before installing this extension, make sure that you have signed up for a free Pangea account and have set up a Cloud Firestore database in your Firebase project.
NOTE: If this extensions fails to install, try installing any other extension that emits an event first, for example the Known Malware Detection. Make sure to enable the event for that extension. This will ensure that the proper event channels are configured in your Firebase application. Then, reinstall this extension. You can uninstall the extension that created the channel and all subsequent installs will continue to work.
Billing
To install an extension, your project must be on the Blaze (pay as you go) plan
- You will be charged a small amount (typically around $0.01/month) for the Firebase resources required by this extension (even if it is not used).
- This extension uses other Firebase and Google Cloud Platform services, which have associated charges if you exceed the service’s no-cost tier:
- Pangea Redact API
- Cloud Firestore
- Cloud Functions (Node.js 18+ runtime. See FAQs)
Usage of this extension also requires you to have a Pangea account. You are responsible for any associated costs with your usage of Pangea.