# ShotgunApiRuby A gem to integrate with shotgun REST API easily. ## Installation Add this line to your application's Gemfile: ```ruby gem 'shotgun_api_ruby' ``` And then execute: $ bundle Or install it yourself as: $ gem install shotgun_api_ruby ## Usage ### Client instantiation For creating a new client you need to provide two values. - One to identify the shotgun site: - Can be `shotgun_site`: which is the `xxx` part in `https://xxx.shotgunstudio.com` - Can be `site_url`: which is the full url to your site - One to `auth` you see _Authentication_ lower in this guide. Example: ```ruby client = ShotgunApiRuby.new(shotgun_site: 'i-love-shotgun', auth: {client_id: 'my_nice_script', client_secret: 'CantTouchThis'}) ``` ### Authentication Any kind of authentication specified [here](https://developer.shotgunsoftware.com/rest-api/#authentication) is implemented #### Client Credentials ```ruby client = ShotgunApiRuby.new(shotgun_site: 'xxx', auth: {client_id: 'script_name', client_secret: 'script_secret'}) ``` #### Password Credentials ```ruby client = ShotgunApiRuby.new(shotgun_site: 'xxx', auth: {username: 'login', password: 'password'}) ``` #### Session Token **We highly advise not using this for a long term script as this won't be a stable value over time** ```ruby client = ShotgunApiRuby.new(shotgun_site: 'xxx', auth: {session_token: 'session_token'}) ``` #### Refresh Token **We highly advise not using this for a long term script as this won't be a stable value over time** ```ruby client = ShotgunApiRuby.new(shotgun_site: 'xxx', auth: {refresh_token: 'refresh_token'}) ``` ### Server Infos Get general server infos: ```ruby client.server_info.get # # ``` ### Preferences Get some preferences infos: ```ruby prefs = client.preferences.get prefs.to_h.keys # [:format_date_fields, # :date_component_order, # :format_time_hour_fields, # :format_currency_fields_display_dollar_sign, # :format_currency_fields_decimal_options, # :format_currency_fields_negative_options, # :format_number_fields, # :format_float_fields, # :format_float_fields_rounding, # :format_footage_fields, # :support_local_storage, # :view_master_settings, # :duration_units, # :hours_per_day, # :last_day_work_week] ``` ### Entities Querying entities is done by accessing the named method ```ruby client.assets # => ShotgunApiRuby::Entities … ``` As entities can be user defined the client will try to answer to any unknown type with an entity call so any of those calls will returns the same thing: ```ruby client.assets client.asset client.entities("Asset") client.entities(:Assets) ``` Any not yet implemented call can be accessed through the connection: `client.assets.connection` #### Entity Returned entity will try to behave as nicely as possible. An entity will always answer to: - .type : the type of the entity - .id : the id of the entity - .relationships : a hash of relationships - .links : a hash of links to other entities - .attributes : An object answering to any available attributes It will also answer to any method that is present in the attributes: ```ruby assets = client.assets.all(fields: 'code') assets.first.type # => "Asset" assets.first.id # => 726 assets.first.attributes.code # => "Buck" assets.first.code # => "Buck" ``` ### Search #### all The all call will return all possible entities. ```ruby client.assets.all ``` #### search Does the same thing as `all` #### first Will return only the first entity found (same thing as setting the page_size to 1) ``` client.assets.first ``` #### arguments ##### fields This attribute describe the wanted fields in the returned entity Can be a string describing wanted fields: `'code'` or `'code,description'` Or an array for better readability: `[:code, 'description']` Example: ```ruby client.assets.all(fields: [:code, :description]) ``` ##### sort Describe how you want your entities to be sorted. Can be either: - A string: `'code'` or `'code,-description'` (the `-` asking for a descending order) - An array for better readability: `[:code, '-description']` - A hash for ease of use: `{code: 'asc', description: :desc}` Example: ```ruby client.assets.all(fields: [:code, :description], sort: {code: :asc, description: :desc}) ``` ##### filter For simple filters, the filter field is waiting for a hash. Each value is: - A string: then a `is` filter will be used - An array: then a `in` filter will be used Example: ```ruby client.assets.all(fields: [:code, :description], filter: {code: ['Buck', :Darcy], description: 'I LOVE SG'}) ``` For complex filters, see the documentation [here](https://developer.shotgunsoftware.com/rest-api/#searching) The complexity of calling a different route and passing different headers/body/params will be taken care of automatically. ##### page You can ask for any page size or page number. - `page`: set the page number. - `page_size`: set the size of each page. Any of the two can be omited. Their type should be a number but it'll work with a string Example: ```ruby client.assets.all(fields: [:code], page: 3, page_size: 10) client.assets.all(fields: [:code], page: '3') client.assets.all(fields: [:code], page_size: 10) ``` ##### options Special options can be added: - retired: a flag telling if the returned entities should be retired or not - include_archived_projects: a flag telling if the archived projets should be included int the search Example: ```ruby client.assets.all(fields: [:code], retired: true) client.assets.all(fields: [:code], include_archived_projects: true) ``` ### Finding one element `find` function on `entities` allow you to get one element in particular. It accepts (all arguments are optional): - fields: string, symbol or array of fields - retired: boolean specifying if the record is retired - include_archived_projects: boolean specifying if the entity is part of an archived project Example: ```ruby client.assets.find(724, fields: [:code, 'description'], retired: false) ``` #### Create Not implemented yet #### Update Not implemented yet #### Delete Not implemented yet ### Non implemented calls All calls which are not yet implemented can be done through the `connection` method. This method will still take care of the authentication for you. ```ruby client = ShotgunApiRuby.new(…) client.connection.get('/entity/assets') # => #