Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jackcuthbert/firetype
ORM for TypeScript and Google Cloud Firestore (Native mode)
https://github.com/jackcuthbert/firetype
google-cloud-firestore orm typescript
Last synced: 22 days ago
JSON representation
ORM for TypeScript and Google Cloud Firestore (Native mode)
- Host: GitHub
- URL: https://github.com/jackcuthbert/firetype
- Owner: JackCuthbert
- License: mit
- Created: 2020-07-24T05:35:42.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-08-06T00:23:49.000Z (over 4 years ago)
- Last Synced: 2024-11-08T23:30:42.558Z (3 months ago)
- Topics: google-cloud-firestore, orm, typescript
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/firetype
- Size: 270 KB
- Stars: 3
- Watchers: 0
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# firetype
[![NPM Version](https://img.shields.io/npm/v/firetype)](https://www.npmjs.com/package/firetype)
[![Release](https://github.com/JackCuthbert/firetype/workflows/Release/badge.svg)](https://github.com/JackCuthbert/firetype/actions?query=workflow%3ARelease)
[![Test](https://github.com/JackCuthbert/firetype/workflows/Test/badge.svg)](https://github.com/JackCuthbert/firetype/actions?query=workflow%3ATest)
[![JavaScript Style Guide](https://img.shields.io/badge/code_style-standard-brightgreen.svg)](https://standardjs.com)ORM for TypeScript and Google Cloud Firestore.
## Usage
Firetype requires TypeScript to work as intended.
```
npm install -D typescript
```Install the `firetype` and `@google-cloud/firestore` packages.
```
npm install firetype @google-cloud/firestore
```Create an interface that describes your document and extends the `Entity` type.
```ts
import { Entity } from 'firetype'interface User extends Entity {
firstName: string
lastName: string
}
```The `Entity` type adds an `id` property with type `string`. This is used as the
Document ID in Cloud Firestore and inserted into the document as `id`.Use the base repository with built-in methods.
```ts
import { Repository } from 'firetype'
import { User } from './entity/User'const userRepository = new Repository('root_collection_name')
await userRepository.find('123')
await userRepository.createOrUpdate({
id: uuidv4(),
firstName: 'Jack',
lastName: 'Cuthbert'
})
```### Custom repository
Use a customm repository to add additional methods to the ORM. `this.firestore`
and `this.collection` are available for creating custom queries and operations.```ts
import { Firestore } from '@google-cloud/firestore'
import { Repository } from 'firetype'
import { User } from './entity/User'class TeamRepository extends Repository {
constructor (firestore?: Firestore) {
super('root_collection_name', firestore) {
}async setPremiumStatus(user: User, isPremium: boolean): Promise {
const ref = this.firestore.doc(this.createDocRef(user.id))
const update: Partial = { isPremium }
await ref.set(update, { merge: true })
return { ...user, ...update }
}
}
```