Class: JIRA::Resource::Issue
Instance Attribute Summary
Attributes inherited from Base
#attrs, #client, #deleted, #expanded
Class Method Summary collapse
Instance Method Summary collapse
Methods inherited from Base
belongs_to, belongs_to_relationships, build, collection_attributes_are_nested, collection_path, #collection_path, #delete, endpoint_name, #fetch, find, #has_errors?, has_many, has_one, #id, #initialize, key_attribute, #key_value, nested_collections, #new_record?, parse_json, #path_component, #save, #save!, #set_attrs, #set_attrs_from_response, singular_path, #to_json, #to_s, #to_sym, #url
Constructor Details
This class inherits a constructor from JIRA::Base
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method_name, *args, &block) ⇒ Object
61 62 63 64 65 66 67 |
# File 'lib/jira/resource/issue.rb', line 61 def method_missing(method_name, *args, &block) if attrs.keys.include?('fields') && attrs['fields'].keys.include?(method_name.to_s) attrs['fields'][method_name.to_s] else super(method_name) end end |
Class Method Details
.all(client) ⇒ Object
36 37 38 39 40 41 42 |
# File 'lib/jira/resource/issue.rb', line 36 def self.all(client) response = client.get(client.[:rest_base_path] + "/search") json = parse_json(response.body) json['issues'].map do |issue| client.Issue.build(issue) end end |
.jql(client, jql) ⇒ Object
44 45 46 47 48 49 50 51 |
# File 'lib/jira/resource/issue.rb', line 44 def self.jql(client, jql) url = client.[:rest_base_path] + "/search?jql=" + CGI.escape(jql) response = client.get(url) json = parse_json(response.body) json['issues'].map do |issue| client.Issue.build(issue) end end |
Instance Method Details
#respond_to?(method_name) ⇒ Boolean
53 54 55 56 57 58 59 |
# File 'lib/jira/resource/issue.rb', line 53 def respond_to?(method_name) if attrs.keys.include?('fields') && attrs['fields'].keys.include?(method_name.to_s) true else super(method_name) end end |