Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pgollangi/firestore-grafana-datasource
Google Firestore data source plugin for Grafana
https://github.com/pgollangi/firestore-grafana-datasource
firestore firestore-database gcp-firestore google-firestore grafana grafana-datasource grafana-plugin
Last synced: 4 months ago
JSON representation
Google Firestore data source plugin for Grafana
- Host: GitHub
- URL: https://github.com/pgollangi/firestore-grafana-datasource
- Owner: pgollangi
- License: mit
- Created: 2022-12-22T13:59:02.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-05-06T09:00:13.000Z (9 months ago)
- Last Synced: 2024-09-27T15:41:03.861Z (4 months ago)
- Topics: firestore, firestore-database, gcp-firestore, google-firestore, grafana, grafana-datasource, grafana-plugin
- Language: Go
- Homepage: https://grafana.com/grafana/plugins/pgollangi-firestore-datasource/
- Size: 2.3 MB
- Stars: 11
- Watchers: 3
- Forks: 3
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
[![CI](https://github.com/pgollangi/firestore-grafana-datasource/actions/workflows/ci.yml/badge.svg)](https://github.com/pgollangi/firestore-grafana-datasource/actions/workflows/ci.yml)
[![Release](https://github.com/pgollangi/firestore-grafana-datasource/actions/workflows/release.yml/badge.svg)](https://github.com/pgollangi/firestore-grafana-datasource/actions/workflows/release.yml)
# firestore-grafana-datasource[Google Firestore](https://cloud.google.com/firestore) Data Source Plugin for [Grafana](https://grafana.com/).
Grafana Firestore Data Source Plugin enables integrating data on Firestore into Grafana dashboards.
It uses [FireQL](https://github.com/pgollangi/FireQL) to capture user query that translated to issue queries on Firestore and construct results.
> [FireQL](https://github.com/pgollangi/FireQL) is a Go library to query Google Firestore database using SQL syntax.
![](assets/firestore-grafana-datasource.svg)
## Features
- [x] Use Google Firestore as a data source for Grafana dashboards
- [x] Configure Firestore data source with GCP `Project Id` and [`Service Account`](https://cloud.google.com/firestore/docs/security/iam) for authentication
- [x] Store `Service Account` data source configuration in Grafana encrypted storage [Secure JSON Data](https://grafana.com/docs/grafana/latest/developers/plugins/create-a-grafana-plugin/extend-a-plugin/add-authentication-for-data-source-plugins/#encrypt-data-source-configuration)
- [x] Query Firestore [collections](https://firebase.google.com/docs/firestore/data-model#collections) and path to collections
- [x] Auto detect data types: `string`, `number`, `boolean`, `json`, `time.Time`
- [x] Query selected fields from the collection
- [x] Order query results
- [x] Limit query results
- [x] Query [Collection Groups](https://firebase.blog/posts/2019/06/understanding-collection-group-queries)
- [ ] Count query results
- [ ] Use of [Grafafa global variables](https://grafana.com/docs/grafana/latest/dashboards/variables/add-template-variables/#global-variables) in queries.### Firestore data source configuration
![](src/screenshots/firestore-datasource-configuration.png)
### Using datasource
![](src/screenshots/query-with-firestore-datasource.png)## Getting started
### Frontend
1. Install dependencies
```bash
yarn install
```2. Build plugin in development mode or run in watch mode
```bash
yarn dev# or
yarn watch
```3. Build plugin in production mode
```bash
yarn build
```4. Run the tests (using Jest)
```bash
# Runs the tests and watches for changes
yarn test
# Exists after running all the tests
yarn lint:ci
```5. Spin up a Grafana instance and run the plugin inside it (using Docker)
```bash
yarn server
```6. Run the E2E tests (using Cypress)
```bash
# Spin up a Grafana instance first that we tests against
yarn server
# Start the tests
yarn e2e
```7. Run the linter
```bash
yarn lint
# oryarn lint:fix
```### Backend
1. Update [Grafana plugin SDK for Go](https://grafana.com/docs/grafana/latest/developers/plugins/backend/grafana-plugin-sdk-for-go/) dependency to the latest minor version:
```bash
go get -u github.com/grafana/grafana-plugin-sdk-go
go mod tidy
```2. Build backend plugin binaries for Linux, Windows and Darwin:
```bash
mage -v
```3. List all available Mage targets for additional commands:
```bash
mage -l
```#### Push a version tag
To trigger the workflow we need to push a version tag to github. This can be achieved with the following steps:
1. Run `npm version `
2. Run `git push origin main --follow-tags`## Contributing
Thanks for considering contributing to this project!Please read the [Contributions](CONTRIBUTING.md) and [Code of conduct](CODE_OF_CONDUCT.md).
Feel free to open an issue or submit a pull request!
## License
[MIT](LICENSE)