From 9e7100bf3545eeed5270974286d57382525ea412 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ivan=20Verg=C3=A9s?= Date: Wed, 20 Dec 2023 12:49:46 +0100 Subject: [PATCH] readme for the bulletin_board api client --- bulletin_board/ruby-client/README.md | 34 ++++++++++++++++++++++------ 1 file changed, 27 insertions(+), 7 deletions(-) diff --git a/bulletin_board/ruby-client/README.md b/bulletin_board/ruby-client/README.md index f79fc683..7121b1c4 100644 --- a/bulletin_board/ruby-client/README.md +++ b/bulletin_board/ruby-client/README.md @@ -1,15 +1,16 @@ # Decidim::BulletinBoard -Welcome to your new gem! In this directory, you'll find the files you need to be able to package up your Ruby library into a gem. Put your Ruby code in the file `lib/decidim/bulletin_board`. To experiment with that code, run `bin/console` for an interactive prompt. +The Bulletin Board is a service composed by an Encryption Engine and an Append-Only Log. External queries to the Encryption Engine are allowed through a GraphQL API (see https://github.com/decidim/decidim-bulletin-board). + +This gem provides a collection of commands to interact with such API using Ruby. Mainly for it's use in a backend service. -TODO: Delete this and the text above, and describe your gem ## Installation Add this line to your application's Gemfile: ```ruby -gem 'decidim-bulletin_board' +gem 'decidim-bulletin_board', "~> 0.24.4" ``` And then execute: @@ -22,13 +23,32 @@ Or install it yourself as: ## Usage -TODO: Write usage instructions here +Basic usage involves creating a client and using it to perform the desired operations: + +```ruby +# Instantiate a client +bulletin_board = Decidim::BulletinBoard::Client.new + +# Perform operations +bulletin_board.cast_vote(election_id, voter_id, encrypted_data) do |message_id| + # Do something else with the message_id +end +``` + +See a list of available operations here: https://github.com/decidim/decidim-bulletin-board/blob/develop/bulletin_board/ruby-client/lib/decidim/bulletin_board/client.rb + + +This module is used by the module Decidim Elections, check it out here: + +- https://github.com/decidim/decidim/tree/develop/decidim-elections -## Development +Usage examples: -After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment. +- https://github.com/decidim/decidim/blob/develop/decidim-elections/lib/decidim/elections.rb +- https://github.com/decidim/decidim/blob/develop/decidim-elections/app/commands/decidim/elections/voter/cast_vote.rb +- https://github.com/decidim/decidim/blob/develop/decidim-elections/app/commands/decidim/elections/voter/update_vote_status.rb +- https://github.com/decidim/decidim/blob/develop/decidim-elections/app/commands/decidim/elections/admin/setup_election.rb -To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org). ## Contributing