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!
@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
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.
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..."}
]
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'})
$ gem install gaga
Once you've made your great commits:
- Fork Gaga
- Create a topic branch - git checkout -b my_branch
- Push to your branch - git push origin my_branch
- Create a Pull Request from your branch
- That's it!
Matt Sears :: @mattsears