Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/electron-userland/electron-json-storage
:package: Easily write and read user settings in Electron apps
https://github.com/electron-userland/electron-json-storage
electron json settings storage
Last synced: 1 day ago
JSON representation
:package: Easily write and read user settings in Electron apps
- Host: GitHub
- URL: https://github.com/electron-userland/electron-json-storage
- Owner: electron-userland
- Created: 2016-01-26T00:15:27.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2023-06-12T15:26:15.000Z (over 1 year ago)
- Last Synced: 2024-10-29T15:27:17.904Z (about 1 month ago)
- Topics: electron, json, settings, storage
- Language: JavaScript
- Homepage:
- Size: 681 KB
- Stars: 1,436
- Watchers: 21
- Forks: 80
- Open Issues: 42
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
Awesome Lists containing this project
- awesome-github-star - electron-json-storage - userland | 1415 | (JavaScript)
README
electron-json-storage
=====================> Easily write and read user settings in Electron apps
[![npm version](https://badge.fury.io/js/electron-json-storage.svg)](http://badge.fury.io/js/electron-json-storage)
[![dependencies](https://david-dm.org/jviotti/electron-json-storage.svg)](https://david-dm.org/jviotti/electron-json-storage.svg)
[![Build Status](https://travis-ci.org/electron-userland/electron-json-storage.svg?branch=master)](https://travis-ci.org/electron-userland/electron-json-storage)
[![Build status](https://ci.appveyor.com/api/projects/status/ulwk1nnh7l8209xg/branch/master?svg=true)](https://ci.appveyor.com/project/electron-userland/electron-json-storage/branch/master)[Electron](http://electron.atom.io) lacks an easy way to persist and read user settings for your application. `electron-json-storage` implements an API somewhat similar to [localStorage](https://developer.mozilla.org/en/docs/Web/API/Window/localStorage) to write and read JSON objects to/from the operating system application data directory, as defined by `app.getPath('userData')`.
Related modules:
- [electron-settings](https://github.com/nathanbuchar/electron-settings)
- [electron-store](https://github.com/sindresorhus/electron-store)
- [electron-storage](https://github.com/Cocycles/electron-storage)Installation
------------Install `electron-json-storage` by running:
```sh
$ npm install --save electron-json-storage
```You can require this module from either the **main** or **renderer** process (with and without `remote`).
Running on Electron >10 renderer processes
------------------------------------------When loaded in renderer processes, this module will try to make use of
`electron.remote` in order to fetch the `userData` path.Electron 10 now [defaults `enableRemoteModule` to
false](https://www.electronjs.org/docs/breaking-changes#default-changed-enableremotemodule-defaults-to-false),
which means that `electron-json-storage` will be able to calculate a data path by default.The solution is to manually call `storage.setDataPath()` before reading or
writing any values or setting `enableRemoteModule` to `true`.Documentation
-------------* [storage](#module_storage)
* [.getDefaultDataPath()](#module_storage.getDefaultDataPath) ⇒String
\|Null
* [.setDataPath(directory)](#module_storage.setDataPath)
* [.getDataPath()](#module_storage.getDataPath) ⇒String
* [.get(key, [options], callback)](#module_storage.get)
* [.getSync(key, [options])](#module_storage.getSync)
* [.getMany(keys, [options], callback)](#module_storage.getMany)
* [.getAll([options], callback)](#module_storage.getAll)
* [.set(key, json, [options], callback)](#module_storage.set)
* [.has(key, [options], callback)](#module_storage.has)
* [.keys([options], callback)](#module_storage.keys)
* [.remove(key, [options], callback)](#module_storage.remove)
* [.clear([options], callback)](#module_storage.clear)### storage.getDefaultDataPath() ⇒
String
\|Null
This function will return `null` when running in the
renderer process without support for the `remote` IPC
mechanism. You have to explicitly set a data path using
`.setDataPath()` in these cases.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Get the default data path
**Returns**:String
\|Null
- default data path
**Access**: public
**Example**
```js
const defaultDataPath = storage.getDefaultDataPath()
```### storage.setDataPath(directory)
The default value will be used if the directory is undefined.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Set current data path
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| directory |String
\|Undefined
| directory |**Example**
```js
const os = require('os');
const storage = require('electron-json-storage');storage.setDataPath(os.tmpdir());
```### storage.getDataPath() ⇒
String
Returns the current data path. It defaults to a directory called
"storage" inside Electron's `userData` path.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Get current user data path
**Returns**:String
- the user data path
**Access**: public
**Example**
```js
const storage = require('electron-json-storage');const dataPath = storage.getDataPath();
console.log(dataPath);
```### storage.get(key, [options], callback)
If the key doesn't exist in the user data, an empty object is returned.
Also notice that the `.json` extension is added automatically, but it's
ignored if you pass it yourself.Passing an extension other than `.json` will result in a file created
with both extensions. For example, the key `foo.data` will result in a file
called `foo.data.json`.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Read user data
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| key |String
| key |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error, data) |**Example**
```js
const storage = require('electron-json-storage');storage.get('foobar', function(error, data) {
if (error) throw error;### storage.getSync(key, [options])
See `.get()`.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Read user data (sync)
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| key |String
| key |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |**Example**
```js
const storage = require('electron-json-storage');var data = storage.getSync('foobar');
console.log(data);
```### storage.getMany(keys, [options], callback)
This function returns an object with the data of all the passed keys.
If one of the keys doesn't exist, an empty object is returned for it.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Read many user data keys
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| keys |Array.<String>
| keys |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error, data) |**Example**
```js
const storage = require('electron-json-storage');storage.getMany([ 'foobar', 'barbaz' ], function(error, data) {
if (error) throw error;console.log(data.foobar);
console.log(data.barbaz);
});
```### storage.getAll([options], callback)
This function returns an empty object if there is no data to be read.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Read all user data
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error, data) |**Example**
```js
const storage = require('electron-json-storage');storage.getAll(function(error, data) {
if (error) throw error;### storage.set(key, json, [options], callback)
**Kind**: static method of [storage
](#module_storage)
**Summary**: Write user data
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| key |String
| key |
| json |Object
| json object |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| [options.validate] |String
| validate writes by reading the data back |
| [options.prettyPrinting] |boolean
| adds line breaks and spacing to the written data |
| callback |function
| callback (error) |**Example**
```js
const storage = require('electron-json-storage');storage.set('foobar', { foo: 'bar' }, function(error) {
if (error) throw error;
});
```### storage.has(key, [options], callback)
**Kind**: static method of [storage
](#module_storage)
**Summary**: Check if a key exists
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| key |String
| key |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error, hasKey) |**Example**
```js
const storage = require('electron-json-storage');storage.has('foobar', function(error, hasKey) {
if (error) throw error;if (hasKey) {
console.log('There is data stored as `foobar`');
}
});
```### storage.keys([options], callback)
**Kind**: static method of [storage
](#module_storage)
**Summary**: Get the list of saved keys
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error, keys) |**Example**
```js
const storage = require('electron-json-storage');storage.keys(function(error, keys) {
if (error) throw error;for (var key of keys) {
console.log('There is a key called: ' + key);
}
});
```### storage.remove(key, [options], callback)
Notice this function does nothing, nor throws any error
if the key doesn't exist.**Kind**: static method of [
storage
](#module_storage)
**Summary**: Remove a key
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| key |String
| key |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error) |**Example**
```js
const storage = require('electron-json-storage');storage.remove('foobar', function(error) {
if (error) throw error;
});
```### storage.clear([options], callback)
**Kind**: static method of [storage
](#module_storage)
**Summary**: Clear all stored data in the current user data path
**Access**: public| Param | Type | Description |
| --- | --- | --- |
| [options] |Object
| options |
| [options.dataPath] |String
| data path |
| callback |function
| callback (error) |**Example**
```js
const storage = require('electron-json-storage');storage.clear(function(error) {
if (error) throw error;
});
```Support
-------If you're having any problem, please [raise an issue](https://github.com/electron-userland/electron-json-storage/issues/new) on GitHub and we'll be happy to help.
Tests
-----Run the test suite by doing:
```sh
$ npm test
```Contribute
----------- Issue Tracker: [github.com/electron-userland/electron-json-storage/issues](https://github.com/electron-userland/electron-json-storage/issues)
- Source Code: [github.com/electron-userland/electron-json-storage](https://github.com/electron-userland/electron-json-storage)Before submitting a PR, please make sure that you include tests, and that [jshint](http://jshint.com) runs without any warning:
```sh
$ npm run-script lint
```License
-------The project is licensed under the MIT license.