Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nhogs/nestjs-firebase
Firebase plugin for NestJs
https://github.com/nhogs/nestjs-firebase
firebase nestjs
Last synced: 3 months ago
JSON representation
Firebase plugin for NestJs
- Host: GitHub
- URL: https://github.com/nhogs/nestjs-firebase
- Owner: Nhogs
- License: mit
- Created: 2021-12-20T12:50:07.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-06-29T14:06:50.000Z (8 months ago)
- Last Synced: 2024-10-02T13:08:50.304Z (5 months ago)
- Topics: firebase, nestjs
- Language: TypeScript
- Homepage:
- Size: 1.19 MB
- Stars: 7
- Watchers: 1
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# @nhogs/nestjs-firebase
[data:image/s3,"s3://crabby-images/fda89/fda89d832625c293c95c8f1d51f73ff8e5f76263" alt="npm peer dependency version Firebase"](https://firebase.google.com/)
[data:image/s3,"s3://crabby-images/16152/1615213c4ed58e86f417f57581e8275e0009ee98" alt="npm peer dependency version NestJS)"](https://github.com/nestjs/nest)## [Firebase](https://firebase.google.com/) module for [NestJS](https://github.com/nestjs/nest).
[data:image/s3,"s3://crabby-images/4d3cc/4d3cc9f260f5afb7fed3bd066ad613f315721c66" alt="CI"](https://github.com/Nhogs/nestjs-firebase/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/e7aeb/e7aeb08847d5bebbf22f4258852427b516221cc2" alt="Maintainability"](https://codeclimate.com/github/Nhogs/nestjs-firebase/maintainability)
[data:image/s3,"s3://crabby-images/d63d0/d63d0abb7a87d9b597f22ce262244b67a7ab416f" alt="Test Coverage"](https://codeclimate.com/github/Nhogs/nestjs-firebase/test_coverage)Continuous Integration tests with [Github Action](https://github.com/Nhogs/nestjs-firebase/actions/workflows/ci.yml) on [Firebase Emulator Suite](https://firebase.google.com/docs/emulator-suite)
## Installation
[data:image/s3,"s3://crabby-images/03415/03415ec30ad5c502580678e526f9c1543a2d29b2" alt="npm"](https://www.npmjs.com/package/@nhogs/nestjs-firebase)
```bash
$ npm i --save @nhogs/nestjs-firebase
```First you need to have a running firebase project.
See [Add Firebase to your JavaScript project](https://firebase.google.com/docs/web/setup):warning: This module only uses Firebase client API
- [x] Use [Firebase client API](https://firebase.google.com/docs/web/setup)
- [ ] Use [Firebase admin SDK](https://firebase.google.com/docs/admin/setup)### Module
Add the module in app imports with project settings
```javascript
@Module({
imports: [
FirebaseModule.forRoot({
apiKey: "API_KEY",
authDomain: "PROJECT_ID.firebaseapp.com",
projectId: "PROJECT_ID",
storageBucket: "PROJECT_ID.appspot.com",
// Optional name of the app to initialize. Custom name for the Firebase App. The default value is "[DEFAULT]"
// appName: "APP_NAME",
}),
CatsModule,
],
})
export class AppModule {}
```[Check here for an e2e test with real example on Cat module](e2e/src)
This module is a simple wrapper on Firebase API and export 3 services.
- Cloud Firestore
- Storage
- Authentication### Cloud Firestore
Exposes most of [Firebase firestore web api](https://firebase.google.com/docs/firestore) in the service.
```javascript
// Add document exampleit("should addDoc", async () => {
const users =
firestoreService.collection("users").withConverter < User > userConverter;const doc = (await firestoreService.addDoc) < User > (users, u1);
const snapshot = await firestoreService.getDoc(doc);
expect(snapshot.data()).toMatchInlineSnapshot(`
User {
"age": 1,
"firstName": "fn1",
"lastName": "ln1",
}
`);
});
```See [firestore.service.spec.ts](lib/service/firestore/firestore.service.spec.ts) for detailed usage.
### Storage
Exposes most of [Firebase storage web api](https://firebase.google.com/docs/storage/web/start) in the service.
```javascript
// Upload string and get download url example
it(`should upload string`, async () => {
const fileName = "file.txt";
await storageService
.uploadString(fileName, "text content", "raw", {
contentType: "text/plain",
})
.then((snapshot) => {
expect(snapshot.metadata.contentType).toMatchInlineSnapshot(
`"text/plain"`
);
});const downloadUrl = await storageService.getDownloadURL(fileName);
expect(downloadUrl).toMatchInlineSnapshot(
`"http://localhost:9199/v0/b/default-bucket/o/file.txt?alt=media&token=86739ce5-a96e-41ad-b807-e05b12e36516"`
);
});
```See [storage.service.spec.ts](lib/service/storage/storage.service.spec.ts) for detailed usage.
### Authentication
See [auth.service.spec.ts](lib/service/auth/auth.service.spec.ts) for detailed usage.
## License
[data:image/s3,"s3://crabby-images/8a631/8a631cf1c2d1b3f08a052a4fbadaeffbe5e26e53" alt="MIT license"](LICENSE)