marty 0.5.15 → 0.5.16

Sign up to get free protection for your applications and to get access to all the features.
Files changed (212) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +27 -0
  3. data/.rspec +3 -0
  4. data/.travis.yml +23 -0
  5. data/Gemfile +23 -0
  6. data/INDEPENDENCE_ISSUES.md +23 -0
  7. data/app/assets/images/marty/.gitkeep +0 -0
  8. data/app/components/marty/report_form.rb +9 -4
  9. data/gemini_deprecations.md +6 -0
  10. data/lib/marty/data_change.rb +99 -0
  11. data/lib/marty/data_conversion.rb +11 -3
  12. data/lib/marty/data_exporter.rb +9 -0
  13. data/lib/marty/version.rb +1 -1
  14. data/marty.gemspec +35 -0
  15. data/script/rails +8 -0
  16. data/spec/controllers/application_controller_spec.rb +52 -0
  17. data/spec/controllers/job_controller_spec.rb +226 -0
  18. data/spec/controllers/rpc_controller_spec.rb +379 -0
  19. data/spec/controllers/rpc_import_spec.rb +45 -0
  20. data/spec/dummy/README.rdoc +261 -0
  21. data/spec/dummy/Rakefile +7 -0
  22. data/spec/dummy/app/assets/javascripts/application.js +15 -0
  23. data/spec/dummy/app/assets/stylesheets/application.css +13 -0
  24. data/spec/dummy/app/controllers/application_controller.rb +3 -0
  25. data/spec/dummy/app/controllers/components_controller.rb +7 -0
  26. data/spec/dummy/app/helpers/application_helper.rb +2 -0
  27. data/spec/dummy/app/mailers/.gitkeep +0 -0
  28. data/spec/dummy/app/models/.gitkeep +0 -0
  29. data/spec/dummy/app/models/gemini/amortization_type.rb +5 -0
  30. data/spec/dummy/app/models/gemini/bud_category.rb +7 -0
  31. data/spec/dummy/app/models/gemini/entity.rb +2 -0
  32. data/spec/dummy/app/models/gemini/extras/data_import.rb +5 -0
  33. data/spec/dummy/app/models/gemini/extras/settlement_import.rb +28 -0
  34. data/spec/dummy/app/models/gemini/fannie_bup.rb +29 -0
  35. data/spec/dummy/app/models/gemini/grouping.rb +8 -0
  36. data/spec/dummy/app/models/gemini/grouping_head_version.rb +14 -0
  37. data/spec/dummy/app/models/gemini/head.rb +7 -0
  38. data/spec/dummy/app/models/gemini/head_version.rb +14 -0
  39. data/spec/dummy/app/models/gemini/helper.rb +44 -0
  40. data/spec/dummy/app/models/gemini/loan_program.rb +11 -0
  41. data/spec/dummy/app/models/gemini/mortgage_type.rb +5 -0
  42. data/spec/dummy/app/models/gemini/simple.rb +6 -0
  43. data/spec/dummy/app/models/gemini/streamline_type.rb +16 -0
  44. data/spec/dummy/app/views/layouts/application.html.erb +14 -0
  45. data/spec/dummy/config.ru +4 -0
  46. data/spec/dummy/config/application.rb +82 -0
  47. data/spec/dummy/config/boot.rb +10 -0
  48. data/spec/dummy/config/database.yml.example +10 -0
  49. data/spec/dummy/config/environment.rb +5 -0
  50. data/spec/dummy/config/environments/development.rb +35 -0
  51. data/spec/dummy/config/environments/production.rb +69 -0
  52. data/spec/dummy/config/environments/test.rb +39 -0
  53. data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
  54. data/spec/dummy/config/initializers/delayed_job.rb +5 -0
  55. data/spec/dummy/config/initializers/inflections.rb +15 -0
  56. data/spec/dummy/config/initializers/mime_types.rb +5 -0
  57. data/spec/dummy/config/initializers/secret_token.rb +7 -0
  58. data/spec/dummy/config/initializers/session_store.rb +8 -0
  59. data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
  60. data/spec/dummy/config/locales/en.yml +5 -0
  61. data/spec/dummy/config/routes.rb +12 -0
  62. data/spec/dummy/db/migrate/20140801000000_create_groupings.rb +11 -0
  63. data/spec/dummy/db/migrate/20150406171536_create_categories.rb +27 -0
  64. data/spec/dummy/db/migrate/20150408200916_create_loan_programs.rb +26 -0
  65. data/spec/dummy/db/migrate/20150408201429_create_types.rb +21 -0
  66. data/spec/dummy/db/migrate/20150420000001_create_heads.rb +14 -0
  67. data/spec/dummy/db/migrate/20150420000002_create_head_versions.rb +15 -0
  68. data/spec/dummy/db/migrate/20150420000003_create_grouping_head_versions.rb +12 -0
  69. data/spec/dummy/db/migrate/20151023000001_create_simple.rb +12 -0
  70. data/spec/dummy/db/seeds.rb +8 -0
  71. data/spec/dummy/delorean/blame_report.dl +171 -0
  72. data/spec/dummy/delorean/data_report.dl +105 -0
  73. data/spec/dummy/delorean/fields.dl +52 -0
  74. data/spec/dummy/delorean/styles.dl +134 -0
  75. data/spec/dummy/lib/assets/.gitkeep +0 -0
  76. data/spec/dummy/lib/class_list.rb +3 -0
  77. data/spec/dummy/log/.gitkeep +0 -0
  78. data/spec/dummy/public/404.html +26 -0
  79. data/spec/dummy/public/422.html +26 -0
  80. data/spec/dummy/public/500.html +25 -0
  81. data/spec/dummy/public/favicon.ico +0 -0
  82. data/spec/dummy/public/icons/READ.txt +3 -0
  83. data/spec/dummy/public/icons/application_cascade.png +0 -0
  84. data/spec/dummy/public/icons/application_delete.png +0 -0
  85. data/spec/dummy/public/icons/application_put.png +0 -0
  86. data/spec/dummy/public/icons/application_view_detail.png +0 -0
  87. data/spec/dummy/public/icons/arrow_in.png +0 -0
  88. data/spec/dummy/public/icons/arrow_refresh.png +0 -0
  89. data/spec/dummy/public/icons/database_save.png +0 -0
  90. data/spec/dummy/public/icons/door_in.png +0 -0
  91. data/spec/dummy/public/icons/door_out.png +0 -0
  92. data/spec/dummy/public/icons/group.png +0 -0
  93. data/spec/dummy/public/icons/page_lightning.png +0 -0
  94. data/spec/dummy/public/icons/printer.png +0 -0
  95. data/spec/dummy/public/icons/report_disk.png +0 -0
  96. data/spec/dummy/public/icons/report_go.png +0 -0
  97. data/spec/dummy/public/icons/report_magnify.png +0 -0
  98. data/spec/dummy/public/icons/script.png +0 -0
  99. data/spec/dummy/public/icons/script_add.png +0 -0
  100. data/spec/dummy/public/icons/script_go.png +0 -0
  101. data/spec/dummy/public/icons/script_key.png +0 -0
  102. data/spec/dummy/public/icons/table_go.png +0 -0
  103. data/spec/dummy/public/icons/time.png +0 -0
  104. data/spec/dummy/public/icons/time_add.png +0 -0
  105. data/spec/dummy/public/icons/time_go.png +0 -0
  106. data/spec/dummy/public/icons/timeline_marker.png +0 -0
  107. data/spec/dummy/public/icons/user_add.png +0 -0
  108. data/spec/dummy/public/icons/user_delete.png +0 -0
  109. data/spec/dummy/public/icons/user_edit.png +0 -0
  110. data/spec/dummy/public/icons/wrench.png +0 -0
  111. data/spec/dummy/script/delayed_job +6 -0
  112. data/spec/dummy/script/rails +6 -0
  113. data/spec/features/javascripts/job_dashboard_live_search.js.coffee +8 -0
  114. data/spec/features/javascripts/login.js.coffee +8 -0
  115. data/spec/features/jobs_dashboard_netzke_spec.rb +24 -0
  116. data/spec/features/jobs_dashboard_spec.rb +49 -0
  117. data/spec/fixtures/scripts/load_tests/script1.dl +2 -0
  118. data/spec/fixtures/scripts/load_tests/script2.dl +2 -0
  119. data/spec/job_helper.rb +102 -0
  120. data/spec/lib/data_exporter_spec.rb +71 -0
  121. data/spec/lib/data_importer_spec.rb +461 -0
  122. data/spec/lib/xl_spec.rb +198 -0
  123. data/spec/lib/xl_styles_spec.rb +115 -0
  124. data/spec/models/api_auth_spec.rb +187 -0
  125. data/spec/models/posting_spec.rb +107 -0
  126. data/spec/models/promise_spec.rb +65 -0
  127. data/spec/models/script_spec.rb +187 -0
  128. data/spec/models/user_spec.rb +68 -0
  129. data/spec/requests/routes_spec.rb +12 -0
  130. data/spec/spec_helper.rb +61 -0
  131. data/spec/support/clean_db_helpers.rb +18 -0
  132. data/spec/support/delayed_job_helpers.rb +12 -0
  133. data/spec/support/user_helpers.rb +12 -0
  134. metadata +139 -89
  135. data/app/components/marty/auth_app.rb~ +0 -51
  136. data/app/components/marty/auth_app/javascripts/auth_app.js~ +0 -91
  137. data/app/components/marty/cm_form_panel.rb~ +0 -5
  138. data/app/components/marty/cm_grid_panel.rb~ +0 -35
  139. data/app/components/marty/data_import_view.rb~ +0 -142
  140. data/app/components/marty/extras/layout.rb~ +0 -46
  141. data/app/components/marty/live_search_grid_panel.rb~ +0 -49
  142. data/app/components/marty/main_auth_app.rb~ +0 -238
  143. data/app/components/marty/mcfly_grid_panel.rb~ +0 -80
  144. data/app/components/marty/new_posting_form.rb~ +0 -46
  145. data/app/components/marty/new_posting_window.rb~ +0 -21
  146. data/app/components/marty/pivot_grid.rb +0 -52
  147. data/app/components/marty/pivot_grid/endpoints.rb +0 -45
  148. data/app/components/marty/pivot_grid/javascripts/extensions.js +0 -150
  149. data/app/components/marty/pivot_grid/javascripts/pivot_grid.js +0 -86
  150. data/app/components/marty/pivot_grid/services.rb +0 -44
  151. data/app/components/marty/posting_grid.rb~ +0 -140
  152. data/app/components/marty/promise_view.rb~ +0 -157
  153. data/app/components/marty/promise_view/stylesheets/promise_view.css~ +0 -15
  154. data/app/components/marty/report_form.rb~ +0 -217
  155. data/app/components/marty/report_select.rb~ +0 -133
  156. data/app/components/marty/reporting.rb~ +0 -39
  157. data/app/components/marty/script_detail.rb~ +0 -430
  158. data/app/components/marty/script_form.rb~ +0 -233
  159. data/app/components/marty/script_form/javascripts/Ext.ux.form.field.CodeMirror.js~ +0 -909
  160. data/app/components/marty/script_grid.rb~ +0 -99
  161. data/app/components/marty/script_tester.rb~ +0 -213
  162. data/app/components/marty/scripting.rb~ +0 -124
  163. data/app/components/marty/select_report.rb~ +0 -143
  164. data/app/components/marty/simple_app.rb~ +0 -101
  165. data/app/components/marty/tag_grid.rb~ +0 -89
  166. data/app/components/marty/tree_panel.rb~ +0 -256
  167. data/app/components/marty/tree_panel/javascripts/tree_panel.js~ +0 -317
  168. data/app/components/marty/user_pivot.rb +0 -128
  169. data/app/components/marty/user_view.rb~ +0 -188
  170. data/app/controllers/marty/application_controller.rb~ +0 -133
  171. data/app/controllers/marty/components_controller.rb~ +0 -37
  172. data/app/controllers/marty/job_controller.rb~ +0 -28
  173. data/app/controllers/marty/rpc_controller.rb~ +0 -61
  174. data/app/helpers/marty/script_set.rb~ +0 -59
  175. data/app/models/marty/api_auth.rb~ +0 -48
  176. data/app/models/marty/data_change.rb~ +0 -141
  177. data/app/models/marty/enum.rb~ +0 -16
  178. data/app/models/marty/import_type.rb~ +0 -48
  179. data/app/models/marty/poop.rb~ +0 -169
  180. data/app/models/marty/posting.rb~ +0 -86
  181. data/app/models/marty/posting_type.rb~ +0 -21
  182. data/app/models/marty/promise.rb~ +0 -196
  183. data/app/models/marty/role.rb~ +0 -10
  184. data/app/models/marty/script.rb~ +0 -62
  185. data/app/models/marty/tag.rb~ +0 -91
  186. data/app/models/marty/user.rb~ +0 -148
  187. data/app/models/marty/user_role.rb~ +0 -13
  188. data/app/views/layouts/marty/application.html.erb~ +0 -11
  189. data/config/routes.rb~ +0 -10
  190. data/db/migrate/019_create_marty_postings.rb~ +0 -19
  191. data/db/migrate/095_create_marty_tags.rb~ +0 -19
  192. data/lib/marty.rb~ +0 -13
  193. data/lib/marty/content_handler.rb~ +0 -93
  194. data/lib/marty/data_exporter.rb~ +0 -137
  195. data/lib/marty/data_importer.rb~ +0 -114
  196. data/lib/marty/data_row_processor.rb~ +0 -206
  197. data/lib/marty/drop_folder_hook.rb~ +0 -17
  198. data/lib/marty/folder_hook.rb~ +0 -9
  199. data/lib/marty/lazy_column_loader.rb~ +0 -47
  200. data/lib/marty/mcfly_query.rb~ +0 -188
  201. data/lib/marty/migrations.rb~ +0 -65
  202. data/lib/marty/monkey.rb~ +0 -160
  203. data/lib/marty/permissions.rb~ +0 -69
  204. data/lib/marty/promise.rb~ +0 -41
  205. data/lib/marty/promise_job.rb~ +0 -121
  206. data/lib/marty/promise_proxy.rb~ +0 -69
  207. data/lib/marty/util.rb~ +0 -80
  208. data/lib/marty/version.rb~ +0 -3
  209. data/lib/marty/xl.rb~ +0 -526
  210. data/lib/pyxll/README.txt~ +0 -16
  211. data/lib/pyxll/gemini.py~ +0 -110
  212. data/lib/pyxll/pyxll.cfg~ +0 -12
@@ -1,17 +0,0 @@
1
- class Marty::DropFolderHook
2
- def initialize(login)
3
- @login = login
4
- end
5
-
6
- def run(res)
7
- p 'H.'*10, res
8
- drop_path = "/tmp/#{@login}"
9
-
10
- begin
11
- Dir.mkdir(drop_path) unless File.directory?(drop_path)
12
- rescue => exc
13
- Marty::Util.logger.error "Can't create
14
-
15
-
16
- end
17
- end
@@ -1,9 +0,0 @@
1
- class Marty::FolderHook
2
- def initialize
3
- end
4
-
5
- def run(res)
6
- p 'H.'*10, res
7
- end
8
-
9
- end
@@ -1,47 +0,0 @@
1
- module Marty
2
- module LazyColumnLoader
3
- extend ActiveSupport::Concern
4
-
5
- module ClassMethods
6
- def lazy_load(*columns)
7
- return unless table_exists?
8
- columns = columns.collect(&:to_s)
9
- exclude_columns_from_default_scope columns
10
- define_lazy_accessors_for columns
11
- end
12
-
13
- private
14
- def exclude_columns_from_default_scope(columns)
15
- default_scope select((
16
- column_names - columns).map {
17
- |column_name|
18
- "#{table_name}.#{column_name}"
19
- })
20
- end
21
-
22
- def define_lazy_accessors_for(columns)
23
- columns.each { |column| define_lazy_accessor_for column }
24
- end
25
-
26
- def define_lazy_accessor_for(column)
27
- define_method column do
28
- unless has_attribute?(column)
29
- changes_before_reload = self.changes.clone
30
- self.reload
31
- changes_before_reload.each{|attribute_name, values|
32
- self.send("#{attribute_name}=", values[1])}
33
- end
34
- read_attribute column
35
- end
36
- end
37
- end
38
- end
39
- end
40
-
41
- if ActiveRecord::Base.respond_to?(:lazy_load)
42
- $stderr.puts "ERROR: Method `.lazy_load` already defined in " +
43
- "`ActiveRecord::Base`. This is incompatible with LazyColumnLoader " +
44
- "and the module will be disabled."
45
- else
46
- ActiveRecord::Base.send :include, Marty::LazyColumnLoader
47
- end
@@ -1,188 +0,0 @@
1
- require 'mcfly'
2
-
3
- module Mcfly
4
- module Model
5
-
6
- def self.included(base)
7
- base.send :extend, ClassMethods
8
- end
9
-
10
- module ClassMethods
11
- def clear_cache
12
- @LOOKUP_CACHE.clear if @LOOKUP_CACHE
13
- end
14
-
15
- # Implements a VERY HACKY class-based caching mechanism for
16
- # database lookup results. Issues include: cached values are
17
- # ActiveRecord objects. Not sure if these should be shared
18
- # across connections. Query results can potentially be very
19
- # large lists which we simply count as one item in the cache.
20
- # Caching mechanism will result in large processes. Caches are
21
- # not sharable across different Ruby processes.
22
- def cached_delorean_fn(name, options = {}, &block)
23
- @LOOKUP_CACHE ||= {}
24
-
25
- delorean_fn(name, options) do |ts, *args|
26
- cache_key = [name, ts] + args.map{ |a|
27
- a.is_a?(ActiveRecord::Base) ? a.id : a
28
- } unless Mcfly.is_infinity(ts)
29
-
30
- next @LOOKUP_CACHE[cache_key] if
31
- cache_key && @LOOKUP_CACHE.has_key?(cache_key)
32
-
33
- res = block.call(ts, *args)
34
-
35
- if cache_key
36
- # Cache has >1000 items, clear out the oldest 200. FIXME:
37
- # hard-coded, should be configurable. Cache
38
- # size/invalidation should be per lookup and not class.
39
- # We're invalidating cache items simply based on age and
40
- # not usage. This is faster but not as fair.
41
- if @LOOKUP_CACHE.count > 1000
42
- @LOOKUP_CACHE.keys[0..200].each{|k| @LOOKUP_CACHE.delete(k)}
43
- end
44
- @LOOKUP_CACHE[cache_key] = res
45
-
46
- # Since we're caching this object and don't want anyone
47
- # changing it. FIXME: ideally should freeze this object
48
- # recursively.
49
- res.freeze unless res.is_a?(ActiveRecord::Relation)
50
- end
51
- res
52
- end
53
- end
54
-
55
- # FIXME: duplicate code from Mcfly's mcfly_lookup.
56
- def cached_mcfly_lookup(name, options = {}, &block)
57
- cached_delorean_fn(name, options) do |ts, *args|
58
- raise "time cannot be nil" if ts.nil?
59
-
60
- ts = Mcfly.normalize_infinity(ts)
61
-
62
- where("obsoleted_dt >= ? AND created_dt < ?", ts, ts).scoping do
63
- block.call(ts, *args)
64
- end
65
- end
66
- end
67
-
68
- # FIXME: for validation purposes, this mechanism should make
69
- # sure that the allable attrs are not required.
70
- def gen_mcfly_lookup(name, attrs, options={})
71
- raise "bad options" unless options.is_a?(Hash)
72
-
73
- # FIXME: mode should be sent later, not as a part of
74
- # gen_mcfly_lookup. i.e. we just generate the search and the
75
- # mode is applied at runtime by delorean code. That would
76
- # allow lookups to be used in either mode dynamically.
77
- mode = options.fetch(:mode, :first)
78
-
79
- assoc = Set.new(self.reflect_on_all_associations.map(&:name))
80
- attr_names = attrs.keys
81
-
82
- allables = attrs.select {|k, v| v}
83
-
84
- order = allables.keys.reverse.map { |k|
85
- k = "#{k}_id" if assoc.member?(k)
86
- "#{k} NULLS LAST"
87
- }.join(", ")
88
-
89
- qstr = attrs.map {|k, v|
90
- k = "#{k}_id" if assoc.member?(k)
91
- v ? "(#{k} = ? OR #{k} IS NULL)" : "(#{k} = ?)"
92
- }.join(" AND ")
93
-
94
- cached_mcfly_lookup(name, sig: attrs.length+1) do
95
- |t, *attr_list|
96
-
97
- attr_list_ids = attr_list.each_with_index.map {|x, i|
98
- assoc.member?(attr_names[i]) ?
99
- (attr_list[i] && attr_list[i].id) : attr_list[i]
100
- }
101
-
102
- q = self.where(qstr, *attr_list_ids)
103
- q = q.order(order) unless order.empty?
104
- mode ? q.send(mode) : q
105
- end
106
- end
107
-
108
- ######################################################################
109
-
110
- # Generates Gemini categorization lookups. For instance,
111
- # suppose we have the following in class GFee:
112
- #
113
- # gen_mcfly_lookup_cat :lookup_q,
114
- # [:security_instrument,
115
- # 'Gemini::SecurityInstrumentCategorization',
116
- # :g_fee_category],
117
- # {
118
- # entity: true,
119
- # security_instrument: true,
120
- # coupon: true,
121
- # },
122
- # nil
123
-
124
- # In the above case,
125
- # rel_attr = :security_instrument
126
- # cat_assoc_klass = Gemini::SecurityInstrumentCategorization
127
- # cat_attr = :g_fee_category
128
- # name = :lookup_q
129
- # pc_name = :pc_lookup_q
130
- # pc_attrs = {entity: true, security_instrument: true,
131
- # g_fee_category: true, coupon: true}
132
-
133
- def gen_mcfly_lookup_cat(name, catrel, attrs, options={})
134
- rel_attr, cat_assoc_name, cat_attr = catrel
135
-
136
- raise "#{rel_attr} should be mapped in attrs" if
137
- attrs[rel_attr].nil?
138
-
139
- cat_assoc_klass = cat_assoc_name.constantize
140
-
141
- raise "need lookup method on #{cat_assoc_klass}" unless
142
- cat_assoc_klass.respond_to? :lookup
143
-
144
- # replace rel_attr with cat_attr in attrs
145
- pc_attrs = attrs.each_with_object({}) {|(k, v), h|
146
- h[k == rel_attr ? cat_attr : k] = v
147
- }
148
-
149
- pc_name = "pc_#{name}".to_sym
150
- gen_mcfly_lookup(pc_name, pc_attrs, options)
151
-
152
- lpi = attrs.keys.index rel_attr
153
-
154
- raise "should not include #{cat_attr}" if
155
- attrs.member?(cat_attr)
156
-
157
- raise "need #{rel_attr} argument" unless lpi
158
-
159
- delorean_fn(name, sig: attrs.length+1) do |ts, *args|
160
- # Example: rel is a Gemini::SecurityInstrument instance.
161
- rel = args[lpi]
162
- raise "#{rel_attr} can't be nil" unless rel
163
-
164
- # Assumes there's a mcfly :lookup function on
165
- # cat_assoc_klass.
166
- categorizing_obj = cat_assoc_klass.lookup(ts, rel)
167
- raise "no categorization #{cat_assoc_klass} for #{rel}" unless
168
- categorizing_obj
169
-
170
- pc = categorizing_obj.send(cat_attr)
171
- raise ("#{categorizing_obj} must have assoc." +
172
- " #{cat_attr}/#{rel.inspect}") unless pc
173
-
174
- args[lpi] = pc
175
- self.send(pc_name, ts, *args)
176
- end
177
- end
178
-
179
- end
180
- end
181
- end
182
-
183
- module Mcfly::Controller
184
- # define mcfly user to be Flowscape's current_user.
185
- def user_for_mcfly
186
- find_current_user rescue nil
187
- end
188
- end
@@ -1,65 +0,0 @@
1
- require 'digest/md5'
2
-
3
- module Marty::Migrations
4
- def tb_prefix
5
- "marty_"
6
- end
7
-
8
- def fk_opts(from, to, column)
9
- name = "fk_#{from}_#{to}_#{column}"
10
- if name.length > 63
11
- s = Digest::MD5.hexdigest("#{to}_#{column}").slice(0..9)
12
- name = "fk_#{from}_#{s}"
13
- end
14
- {name: name}
15
- end
16
-
17
- def add_fk(from_table, to_table, options = {})
18
- options[:column] ||= "#{to_table.to_s.singularize}_id"
19
-
20
- from_table = "#{tb_prefix}#{from_table}" unless
21
- from_table.to_s.start_with?(tb_prefix)
22
-
23
- # FIXME: so hacky to specifically check for "marty_"
24
- to_table = "#{tb_prefix}#{to_table}" unless
25
- to_table.to_s.start_with?(tb_prefix) ||
26
- to_table.to_s.start_with?("marty_")
27
-
28
- add_foreign_key(from_table,
29
- to_table,
30
- fk_opts(from_table,
31
- to_table,
32
- options[:column]).update(options),
33
- )
34
- end
35
-
36
- def index_opts(tb, a)
37
- name = "index_#{tb}_on_#{a}"
38
- name.length > 63 ? {
39
- name: "index_#{tb}_#{Digest::MD5.hexdigest(a.to_s).slice(0..9)}",
40
- } : {}
41
- end
42
-
43
- # created_dt/obsoleted_dt need to be indexed since they appear in
44
- # almost all queries.
45
- MCFLY_INDEX_COLUMNS = [
46
- :created_dt,
47
- :obsoleted_dt,
48
- ]
49
-
50
- def add_mcfly_index(tb, *attrs)
51
- tb = "#{tb_prefix}#{tb}" unless
52
- tb.to_s.start_with?(tb_prefix)
53
-
54
- attrs.each { |a|
55
- options = index_opts(tb, a)
56
- options[:order] = {a.to_sym => "NULLS LAST"}
57
- add_index tb.to_sym, a, options
58
- }
59
-
60
- MCFLY_INDEX_COLUMNS.each { |a|
61
- add_index tb.to_sym, a, index_opts(tb, a)
62
- }
63
- end
64
-
65
- end
data/lib/marty/monkey.rb~ DELETED
@@ -1,160 +0,0 @@
1
- # Various monkey patches go here
2
-
3
- ######################################################################
4
-
5
- require 'delorean_lang'
6
-
7
- # Very hacky to overwrite delorean's whitelist. But, there's no
8
- # better way now.
9
-
10
- Delorean::RUBY_WHITELIST.
11
- merge!({
12
- })
13
-
14
- ######################################################################
15
-
16
- # Be able to access Enums from Delorean
17
- class Delorean::BaseModule::BaseClass
18
- class << self
19
- alias_method :old_get_attr, :_get_attr
20
-
21
- def _get_attr(obj, attr, _e)
22
- Marty::Enum === obj ? obj[attr] : old_get_attr(obj, attr, _e)
23
- end
24
- end
25
- end
26
-
27
- ######################################################################
28
- # FIXME: not sure why the following is needed. Otherwise, the monkey
29
- # patch doesn't work.
30
- ActiveSupport::JSON.encode([Date.today])
31
-
32
- class Date
33
- # Very Hacky: The date JSON encoding format doesn't include TZ info.
34
- # Therefore, the ExtJS client interprets it as GMT. This causes
35
- # dates to be displayed as previous day on Pacific TZ clients. So,
36
- # we just tack on 12:00 time to force the client to use the correct
37
- # date (at least in the US).
38
- def as_json(options = nil)
39
- strftime("%Y-%m-%dT12:00:00-00:00")
40
- end
41
- end
42
-
43
- ######################################################################
44
-
45
- class Hash
46
- # define addition on hashes -- useful in Delorean code.
47
- def +(x)
48
- self.merge(x)
49
- end
50
-
51
- # define hash slice (similar to node slice in Delorean)
52
- def %(x)
53
- x.each_with_object({}) { |k, h|
54
- h[k] = self[k]
55
- }
56
- end
57
- end
58
-
59
- ######################################################################
60
-
61
- require 'netzke-basepack'
62
-
63
- class Netzke::Base
64
- # get root component session
65
- def root_sess(component=nil)
66
- component ||= self
67
- component.parent ? root_sess(component.parent) : component.component_session
68
- end
69
- end
70
-
71
- ######################################################################
72
-
73
- # The following is a hack to get around postgres_ext's broken handling
74
- # of PostgreSQL ranges. Essentially, postgres_ext doesn't allow
75
- # numranges to exlude the range start e.g. anything like: "(1.1,2.2]".
76
- # This hack turns off the casting of PostgreSQL ranges to ruby
77
- # ranges. i.e. we keep them as strings. Note that this hack would be
78
- # quite different for Rails 4.0.
79
-
80
- require 'active_record/connection_adapters/postgresql_adapter'
81
-
82
-
83
- [:numrange,:int4range,:int8range,:daterange,:tsrange,:tstzrange].each {|t|
84
- ActiveRecord::ConnectionAdapters::PostgreSQLAdapter::OID.
85
- alias_type t.to_s, 'text'
86
- }
87
-
88
- # The following is a hack to work around a bug in Rails4 array
89
- # handling which doesn't currently support multidimensional arrays.
90
- module ActiveRecord::ConnectionAdapters::PostgreSQLColumn::Cast
91
- def string_to_array(string, oid)
92
- type_cast_array parse_pg_array(string), oid
93
- end
94
-
95
- private
96
- def type_cast_array(value, oid)
97
- Array === value ?
98
- value.map {|val| type_cast_array val, oid} : oid.type_cast(value)
99
- end
100
- end
101
-
102
- ######################################################################
103
-
104
- def pg_range_to_human(r)
105
- m = /\A(?<open>\[|\()(?<start>.*?),(?<end>.*?)(?<close>\]|\))\z/.match(r)
106
-
107
- raise "bad pg range #{r}" unless m
108
-
109
- if m[:start] == ""
110
- res = ""
111
- else
112
- op = m[:open] == "(" ? ">" : ">="
113
- res = "#{op}#{m[:start]}"
114
- end
115
-
116
- if m[:end] != ""
117
- op = m[:close] == ")" ? "<" : "<="
118
- res += "#{op}#{m[:end]}"
119
- end
120
-
121
- res
122
- end
123
-
124
- def human_to_pg_range(r)
125
- m = /\A
126
- ((?<op0>\>|\>=)(?<start>[^\<\>\=]*?))?
127
- ((?<op1>\<|\<=)(?<end>[^\<\>\=]*?))?
128
- \z/x.match(r)
129
-
130
- raise "bad range '#{r}'" unless m
131
-
132
- if m[:op0]
133
- open = m[:op0] == ">" ? "(" : "["
134
- start = "#{open}#{m[:start]}"
135
- else
136
- start = "["
137
- end
138
-
139
- if m[:op1]
140
- close = m[:op1] == "<" ? ")" : "]"
141
- ends = "#{m[:end]}#{close}"
142
- else
143
- ends = "]"
144
- end
145
-
146
- "#{start},#{ends}"
147
- end
148
-
149
- ######################################################################
150
-
151
- # Rails 4 doesn't handle 'infinity' datetime correctly properly due to
152
- # in_time_zone conversion. Ergo this hack.
153
-
154
- class String
155
- alias_method :old_in_time_zone, :in_time_zone
156
-
157
- def in_time_zone(zone = ::Time.zone)
158
- self == 'infinity' ? self : old_in_time_zone(zone)
159
- end
160
- end