Skip to content

mattsears/gaga

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Gaga

Gaga is a fun experiment with key/value store written in Ruby and use Git. Built with Grit, it supports SET, GET, KEYS, and DELETE operations. And since it's Git, we can easily enhance it to include other awesome Git features such as branches, diffs, reverting, and more!

Usage

@gaga = Gaga.new(:repo => File.expand_path('..', __FILE__))

# SET
@gaga['lady'] = "gaga"

# GET
@gaga['lady'] #=> "gaga"

# KEYS
@gaga.keys  #=> ['lady']

# DELETE
@gaga.delete('lady') #=> 'gaga'

# Remove all items from the store
@gaga.clear

Branches

You can always store key/values in separate branches. Just specify the branch option parameter:

@gaga = Gaga.new(:repo => path_to_repo, :branch => 'config')

Though not recommended, Gaga can store the identical key in different branches.

Logs

Gaga keeps a history of key/value saves.

@gaga.log('key')

Returns an array of commit messages along with meta data about each key/value save.

[
 {"message"=>"all clear","committer"=>{"name"=>"Matt Sears", "email"=>"[email protected]"}, "committed_date"=>"2011-09-05..."},
 {"message"=>"set 'lady' ", "committer"=>{"name"=>"Matt Sears", "email"=>"[email protected]"}, "committed_date"=>"2011-09-05..."}
 {"message"=>"delete 'lady' ", "committer"=>{"name"=>"Matt Sears", "email"=>"[email protected]"}, "committed_date"=>"2011-09-05..."}
]

Options

Custom commit options can be set globally when creating a new Gaga instance, or passed in with calls to #set, #delete, or #clear.

Examples:

# Global options
store1 = Gaga.new(
	:repo => '/path/to/repo/',
	:branch => :example,
	:author => {
		:name => 'Jim Bob',
		:email => '[email protected]'
	},
	:committer => {
		:name => 'Jane Doe',
		:email => '[email protected]'
	}
)

# Custom message when storing a key/value
store1.set('key_1', 'Hello World', {:message => 'This is a custom commit log message'})

store2 = Gaga.new(:repo => '/path/to/repo/', :branch => :example)

# Assigns an author when storing a key/value
store2.set('key_1', 'Goodbye', {
	:message => 'Another custom log message',
	:author => {
		:name => 'Sally',
		:email => '[email protected]'
	}
})

# Delete operations can also have a custom message
store2.delete('key_1', {:message => 'Farewell message'})

Installing Gaga

$ gem install gaga

Contributing

Once you've made your great commits:

  1. Fork Gaga
  2. Create a topic branch - git checkout -b my_branch
  3. Push to your branch - git push origin my_branch
  4. Create a Pull Request from your branch
  5. That's it!

Author

Matt Sears :: @mattsears

About

A Git-Backed Key/Value Store

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages