Socket
Book a DemoInstallSign in
Socket

gatsby-source-firestore-saphi

Package Overview
Dependencies
Maintainers
1
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install
Package was removed
Sorry, it seems this package was removed from the registry

gatsby-source-firestore-saphi

Gatsby source plugin for building websites using the Firestore as a data source

unpublished
latest
Source
npmnpm
Version
1.0.4
Version published
Maintainers
1
Created
Source

FORKED FROM gatsby-source-firestore

npm version

Gatsby source plugin for building websites using Firebase Firestore as a data source

Usage

  • Generate and download a Firebase Admin SDK private key by accessing the Firebase Project Console > Settings > Service Accounts

  • Rename and put the downloaded .json crendtial file somewhere in the GatsbyJS project (e.g. ./credentials.json)

  • Add gatsby-source-firestore as a dependency by running using npm or yarn:

    npm i gatsby-source-firestore-saphi
    # or
    yarn add gatsby-source-firestore-saphi
    
  • Configure settings at gatsby-config.js, for example:

    module.exports = {
       plugins: [
         {
           resolve: `gatsby-source-firestore`,
           options: {
             // credential or appConfig
             credential: require(`./credentials.json`),
             appConfig: {
               apiKey: "api-key",
               authDomain: "project-id.firebaseapp.com",
               databaseURL: "https://project-id.firebaseio.com",
               projectId: "project-id",
               storageBucket: "project-id.appspot.com",
               messagingSenderId: "sender-id",
               appID: "app-id",
    
             },
             types: [
               {
                 type: `Book`,
                 collection: `books`,
                 //custom query..
                 query: ref=>ref.limit(10),
                 map: doc => ({
                   title: doc.title,
                   isbn: doc.isbn,
                   author___NODE: doc.author.id,
                 }),
               },
               {
                 type: `Author`,
                 collection: `authors`,
                 map: doc => ({
                   name: doc.name,
                   country: doc.country,
                   books___NODE: doc.books.map(book => book.id),
                 }),
               },
             ],
           },
         },
       ],
     }
    

    Note that you will need to have books and authors in Firestore matching this schema before Gatsby can query correctly, e.g books__NODE on author needs to be an array with books as a key of reference types to book documents.

  • Test GraphQL query:

    {
      allBooks {
        edges {
          node {
            title
            isbn
            author {
              name
            }
          }
        }
      }
    }
    

Configurations

KeyDescription
credentialCredential configurations from downloaded private key
typesArray of types, which require the following keys (type, collection, map)
types.typeThe type of the collection, which will be used in GraphQL queries, e.g. when type = Book, the GraphQL types are named book and allBook
types.collectionThe name of the collections in Firestore. Nested collections are not tested
types.mapA function to map your data in Firestore to Gatsby nodes, utilize the undocumented ___NODE to link between nodes

Acknowledgement

Keywords

firebase

FAQs

Package last updated on 02 Sep 2019

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

About

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.

  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc

U.S. Patent No. 12,346,443 & 12,314,394. Other pending.