Piwigo is open source web application to manage your collection of photos, and other medias. Piwigo provides an API for interacting with it.
This is a ruby-based client for interacting with a Piwigo instance using the Piwigo API.
Add this line to your application's Gemfile:
gem 'piwigo-api'
And then execute:
$ bundle
Or install it yourself as:
$ gem install piwigo-api
Just include 'piwigo/session' and the related classes, then querying Piwigo is fairly quick and straightforward. The latest RubyDocs for piwigo-api can be loacated on rubydoc.info.
require 'piwigo/session'
require 'piwigo/albums'
session = Piwigo::Session.login('mypiwigo.fqdn', 'Adrian', 'mypassword', https: false)
unless session.nil?
albums = Piwigo::Albums.list(session, album_id: 2, recursive: true)
albums.each { |album| p "#{album.id}, #{album.name} - # of photos: #{album.total_nb_images}" }
end
require 'piwigo/session'
require 'piwigo/albums'
session = Piwigo::Session.login('10.100.230.78', 'Adrian', 'mypassword', https: false)
unless session.nil?
album = Piwigo::Albums::Album.new
album.name = "My First Album"
album = Piwigo::Albums.add(session, album)
end
require 'piwigo/session'
require 'piwigo/images'
session = Piwigo::Session.login('mypiwigo.fqdn', 'Adrian', 'mypassword', https: false)
unless session.nil?
results = Piwigo::Images.getImages(session, album_id: 4)
results[:images].each { |image| p "#{image.id}, #{image.name} - #{image.element_url}" }
end
After checking out the repo, run bin/setup
to install dependencies. Then, run rake test
to run the tests. You can also run bin/console
for an interactive prompt that will allow you to experiment.
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.
Bug reports and pull requests are welcome on GitHub at https://github.com/kkdad/piwigo-ruby.
The gem is available as open source under the terms of the MIT License.