Project

finerworks

0.0
No commit activity in last 3 years
No release in over 3 years
This gem wraps the FinerWorks Web API in order to provide an easy way to utilize the API in Ruby apps.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 5.8
~> 10.0
~> 0.10
~> 1.21

Runtime

~> 3.4
~> 1.4
 Project Readme

FinerWorks Ruby Gem

Build Status Gem Version

A Ruby interface for the FinerWorks Web API.

Installation

gem install finerworks

Usage

First, obtain a FinerWorks account API key.

All API calls take place through the client:

require 'finerworks'
client = FinerWorks::Client.new(account_api_key: YOUR_ACCOUNT_API_KEY)
# => #<FinerWorks::Client:0x007f9b0a922190 @account_api_key="...">

Account Information

You can retrieve and update your account information.

account = client.account
# => #<FinerWorks::Account bio="" business_address1="" ... >
account.phone = "123-456-7890"
# => "123-456-7890"
client.update_account(account)
# => #<FinerWorks::Response:0x007fd94719cfa8 @code="200", @message="OK", ... >

Prints

Access your "My Prints Inventory". Optionally, filter by Image GUID and/or Gallery GUID. Prints are based on images, and images may be part of a gallery.

client.prints
# => [#<FinerWorks::Print ...>, #<FinerWorks::Print ...>, ...]
client.prints(ImageGUID: "12345678-abcd-abcd-abcd-12345678abcd")
# => [#<FinerWorks::Print ...>, #<FinerWorks::Print ...>, ...]
client.prints(GalleryGUID: "12345678-abcd-abcd-abcd-12345678abcd")
# => [#<FinerWorks::Print ...>, #<FinerWorks::Print ...>, ...]
client.prints(ImageGUID: "12345678-abcd-abcd-abcd-12345678abcd", GalleryGUID: "12345678-abcd-abcd-abcd-12345678abcd")
# => [#<FinerWorks::Print ...>, #<FinerWorks::Print ...>, ...]

Galleries

You can retrieve a list of your galleries.

client.galleries
# => [#<FinerWorks::Gallery active=true guid="..." title="My Gallery">, ...]

Images

You can retrieve a list of images in a given gallery. Optionally, filter by Gallery GUID and sort by upload date (ASC or DESC; default is descending).

client.images
# => [#<FinerWorks::Image ...>, #<FinerWorks::Image ...>, ...]
client.images(GalleryGUID: "12345678-abcd-abcd-abcd-12345678abcd", sort: "ASC")
# => [#<FinerWorks::Image ...>, #<FinerWorks::Image ...>, ...]

Orders

You can retrieve a list of your orders. Optionally, filter by a date/time range, by order status ID, or a specific order ID. Also, optionally sort by order ID (ASC or DESC; default is descending).

Options

  • OrderDateTime_Start - Search for orders in the range starting at the specified date/time. Possible formats: MM/DD/YYYY or YYYY-MM-DD.
  • OrderDateTime_End - Search for orders in the range ending at the specified date/time. Possible formats: MM/DD/YYYY or YYYY-MM-DD.
  • OrderStatusID - Search for orders with a specific status.
  • OrderID - Find a specific order by ID.
  • Sort - Sort orders by ID in ascending or descending order. Possible values are ASC and DESC. Default is descending.
client.orders
# => [#<FinerWorks::Order ...>, #<FinerWorks::Order ...>, ...]
client.orders(OrderDateTime_Start: "2015-05-01")
# => [#<FinerWorks::Order ...>, #<FinerWorks::Order ...>, ...]
client.orders(OrderID: 12345)
# => [#<FinerWorks::Order id=12345 ...>]

Order Details

You can retrieve details for a specific order.

client.order_details(12345)
# => [#<FinerWorks::OrderDetails cart_id="20150831211231123" ...>]

Order Submission (Shopping Carts)

You can create new shopping carts, which can then be used to submit orders. Optionally, create multiple shopping carts at the same time (up to 100).

client.order_submission
# => [#<FinerWorks::Cart expiration=2015-10-31 02:10:24 UTC guid="12345678-abcd-abcd-abcd-12345678abcd">]
client.order_submission(5)
# => [#<FinerWorks::Cart ...>, #<FinerWorks::Cart ...>, ...]