Module: NCore::Associations

Defined in:
lib/ncore/associations.rb

Instance Method Summary collapse

Instance Method Details

#belongs_to(assoc, klass = nil) ⇒ Object



84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
# File 'lib/ncore/associations.rb', line 84

def belongs_to(assoc, klass=nil)
  assoc = assoc.to_s
  klass ||= "#{module_name}::#{assoc.camelize}"
  class_eval "    attr :\#{assoc}_id\n    def \#{assoc}(params={})\n      return nil unless \#{assoc}_id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      if params.except(:credentials, :request).empty?\n        # only cache unfiltered, default api call\n        @attribs[:\#{assoc}] ||= \#{klass}.find(\#{assoc}_id, params)\n      else\n        \#{klass}.find(\#{assoc}_id, params)\n      end\n    end\n  M1\n  class_eval <<-M2, __FILE__, __LINE__+1\n    def \#{assoc}_id=(v)\n      @attribs[:\#{assoc}] = nil unless @attribs[:\#{assoc}_id] == v\n      @attribs[:\#{assoc}_id] = v\n    end\n    private :\#{assoc}_id=\n  M2\nend\n", __FILE__, __LINE__+1

#has_many(assoc, klass = nil) ⇒ Object



4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
# File 'lib/ncore/associations.rb', line 4

def has_many(assoc, klass=nil)
  assoc = assoc.to_s
  klass ||= "#{module_name}::#{assoc.camelize.singularize}"
  key = "#{attrib_name}_id"
  class_eval "    def \#{assoc}(params={})\n      return [] unless id\n      reload = params.delete :reload\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      cacheable = params.except(:credentials, :request).empty?\n      params.merge! \#{key}: id\n      if cacheable\n        # only cache unfiltered, default api call\n        @attribs[:\#{assoc}] = (!reload && @attribs[:\#{assoc}]) || \#{klass}.all(params)\n      else\n        \#{klass}.all(params)\n      end\n    end\n  M1\n  class_eval <<-M2, __FILE__, __LINE__+1\n    def find_\#{assoc.singularize}(aid, params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.find(aid, params)\n    end\n  M2\n  # will always return the object; check .errors? or .valid? to see how it went\n  class_eval <<-M3, __FILE__, __LINE__+1\n    def create_\#{assoc.singularize}(params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.create(params)\n    end\n  M3\n  # will always return the object; check .errors? or .valid? to see how it went\n  class_eval <<-M4, __FILE__, __LINE__+1\n    def update_\#{assoc.singularize}(aid, params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.update(aid, params)\n    end\n  M4\n  class_eval <<-M5, __FILE__, __LINE__+1\n    def create_\#{assoc.singularize}!(params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.create!(params)\n    end\n  M5\n  class_eval <<-M6, __FILE__, __LINE__+1\n    def update_\#{assoc.singularize}!(aid, params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.update!(aid, params)\n    end\n  M6\n  # will always return the object; check .errors? or .valid? to see how it went\n  class_eval <<-M7, __FILE__, __LINE__+1\n    def delete_\#{assoc.singularize}(aid, params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.delete(aid, params)\n    end\n  M7\n  class_eval <<-M8, __FILE__, __LINE__+1\n    def delete_\#{assoc.singularize}!(aid, params={})\n      raise UnsavedObjectError unless id\n      params = parse_request_params(params).reverse_merge credentials: api_creds\n      params.merge! \#{key}: id\n      \#{klass}.delete!(aid, params)\n    end\n  M8\nend\n", __FILE__, __LINE__+1