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
|
# 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 if params.empty?\n # only cache unfiltered, default api call\n @attribs[:\#{assoc}] = (!reload && @attribs[:\#{assoc}]) || \#{klass}.all({\#{key}: id}, api_creds)\n else\n \#{klass}.all(params.merge(\#{key}: id), api_creds)\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 ## \#{assoc}.detect{|o| o.id == aid} || raise(RecordNotFound)\n # @attribs[:\#{assoc}].detect{|o| o.id == aid} || \#{klass}.find(aid, {\#{key}: id}, api_creds)\n \#{klass}.find(aid, {\#{key}: id}.reverse_merge(params), api_creds)\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 \#{klass}.create(params.merge(\#{key}: id), api_creds)\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 obj = find_\#{assoc.singularize}(aid)\n obj.update(params)\n obj\n end\n M4\n class_eval <<-M5, __FILE__, __LINE__+1\n def create_\#{assoc.singularize}!(params={})\n raise UnsavedObjectError unless id\n \#{klass}.create!(params.merge(\#{key}: id), api_creds)\n end\n M5\n class_eval <<-M6, __FILE__, __LINE__+1\n def update_\#{assoc.singularize}!(aid, params={})\n obj = find_\#{assoc.singularize}(aid)\n obj.save!(params)\n end\n M6\nend\n", __FILE__, __LINE__+1
|