Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/CodeForPhilly/jawn

'Git for Tabular Data'
https://github.com/CodeForPhilly/jawn

Last synced: 3 months ago
JSON representation

'Git for Tabular Data'

Awesome Lists containing this project

README

        

# dat jawn: 'Git for Tabular Data'

[![Build Status](https://travis-ci.org/CfABrigadePhiladelphia/jawn.svg?branch=master)](https://travis-ci.org/CfABrigadePhiladelphia/jawn)

[![NPM](https://nodei.co/npm/jawn.png)](https://nodei.co/npm/jawn/)

Jawn is a node.js module that allows _distributed version control of Tabular Data_. It's connected to the [dat](https://github.com/maxogden/dat) project. It allows you to import tabular data (rows and columns like CSV or TSV) and track how those data change over time. _Do you have non-tabular data? read this:_ [What about Non Tabular Data?](https://github.com/CfABrigadePhiladelphia/jawn/wiki/What-about-Non-Tabular-Data%3F)

The key features for jawn are to:
* **manage and track change history** in tabular data
* **create historical checkpoints** with metadata (e.g., message, timestamp, author)

Jawn relies on [hypercore](https://github.com/mafintosh/hypercore) to handle the core functions around creating merkle chains, which allows us to

* **supply access points to data** across the network with a peer-to-peer model
* **sync incrementally** between machines

This is where jawn connects with the current work of the dat team, who created hypercore and are using it to do the same things with directories of files. For more background info, read our [Technical Background and Reference Code Bases](https://github.com/CfABrigadePhiladelphia/jawn/wiki/Technical-Background-and-Reference-Code-Bases) wiki page.

## Project Team

jawn is maintained by a [Code for Philly](https://codeforphilly.org) project that aims to be a model for mentorship and collaborative learning. For full information about the project go to the [jawn project page](https://codeforphilly.org/projects/dat_tables)

We welcome contributions from anyone.

## Usage

_work in progress_

## Contributing

_work in progress_

If you want to work on the jawn code, first clone the repository and cd into that directory, then install the node dependencies and run the tests with these commands:

```
npm install
npm test
```