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
|