Skip to content

Financial-Times/dj-sheet-reader

Repository files navigation

dj-sheet-reader

Node.js CI

Provides the core spreadsheet processing functionality inside Bertha.

What does it do?

  • Fetches data from a google spreadsheet
  • transforms all the cells values to types (eg booleans, numbers and arrays)
  • outputs the result as an object.

Bertha wraps this functionality into a service, providing also a cache and a background queue for that helps managing large spreadsheets and frequent edits.

Installation

$ npm install @financial-times/sheet-reader

Usage

First, you'll need a Google API Service Account email and key. A service account reads/writes data from the Google API on behalf of a Google user/email. See the auth configuration options below.

const SheetReader = require('@financial-times/sheet-reader')

const auth = {
	key: process.env.KEY,
	email: process.env.EMAIL,
	subject: process.env.SUBJECT,
	scopes: ['https://www.googleapis.com/auth/example.scope'],
}

const spreadsheetId = '__your__sheet__id__'
const sheetNames = ['Sheet1', '+my Optional Sheet']

const data = await SheetReader({ auth }).fetchSheet(spreadsheetId, sheetNames)

process.stdout.write(JSON.stringify(data))

API

SheetReader(options: object):SheetReaderInstance

options:

  • auth.email: is the Email/ID of the service account. It looks like 367017482409-ki8573gid665t1ee2m8t2omwvj3dbt2mj@developer.gserviceaccount.com
  • auth.key: is a key that's generated for the service account that's used authenticate with the Google API
  • auth.subject: a Google Email account (e.g a person or email group) who is the subject of the API request and is used for authorisation. This package will be making requests to the Google API on behalf of this user and can only fetch data for a spreadsheet when the subject has read access.
  • auth.scopes: An optional array of scopes that have been setup for the key when connecting to the Spreadsheet API in Google Cloud console . The default scopes (show below) are the most common configuation.
scopes: [
	'https://www.googleapis.com/auth/drive.readonly',
	'https://www.googleapis.com/auth/spreadsheets.readonly'
],

fetchSheet(spreadsheetId: string, sheetNames: string[], options: object):Promise<object>

  • spreadsheetId: The ID of the Google Spreadsheet
  • sheetNames: An array of sheet names (as they appear on the tabbed sheets)
    • It's possible for sheets to be optional
  • options
    • reserved for future use.

fetchSheetWithCallback(spreadsheetId: string, sheetNames: string[], options: object, callback: Function(error, data)):SheetReaderInstance

Same as fetchSheet but uses the older callback pattern, rather than returning a promise.

SheetReader({ auth }).fetchSheet(spreadsheetId, sheetNames, {}, function (error, data) {
	if (error) {
		console.error(error)
		return
	}
	process.stdout.write(JSON.stringify(data))
})

refreshAuth():void

Refreshes the JWT token in case it's expired.

Licence

This software is published by the Financial Times under the MIT licence.

About

Reads Google Spreadsheets and transforms them into a simple data structure. Used inside Bertha.

Resources

License

Stars

Watchers

Forks

Packages

No packages published