marty 0.5.15 → 0.5.16
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +27 -0
- data/.rspec +3 -0
- data/.travis.yml +23 -0
- data/Gemfile +23 -0
- data/INDEPENDENCE_ISSUES.md +23 -0
- data/app/assets/images/marty/.gitkeep +0 -0
- data/app/components/marty/report_form.rb +9 -4
- data/gemini_deprecations.md +6 -0
- data/lib/marty/data_change.rb +99 -0
- data/lib/marty/data_conversion.rb +11 -3
- data/lib/marty/data_exporter.rb +9 -0
- data/lib/marty/version.rb +1 -1
- data/marty.gemspec +35 -0
- data/script/rails +8 -0
- data/spec/controllers/application_controller_spec.rb +52 -0
- data/spec/controllers/job_controller_spec.rb +226 -0
- data/spec/controllers/rpc_controller_spec.rb +379 -0
- data/spec/controllers/rpc_import_spec.rb +45 -0
- data/spec/dummy/README.rdoc +261 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/spec/dummy/app/controllers/components_controller.rb +7 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/mailers/.gitkeep +0 -0
- data/spec/dummy/app/models/.gitkeep +0 -0
- data/spec/dummy/app/models/gemini/amortization_type.rb +5 -0
- data/spec/dummy/app/models/gemini/bud_category.rb +7 -0
- data/spec/dummy/app/models/gemini/entity.rb +2 -0
- data/spec/dummy/app/models/gemini/extras/data_import.rb +5 -0
- data/spec/dummy/app/models/gemini/extras/settlement_import.rb +28 -0
- data/spec/dummy/app/models/gemini/fannie_bup.rb +29 -0
- data/spec/dummy/app/models/gemini/grouping.rb +8 -0
- data/spec/dummy/app/models/gemini/grouping_head_version.rb +14 -0
- data/spec/dummy/app/models/gemini/head.rb +7 -0
- data/spec/dummy/app/models/gemini/head_version.rb +14 -0
- data/spec/dummy/app/models/gemini/helper.rb +44 -0
- data/spec/dummy/app/models/gemini/loan_program.rb +11 -0
- data/spec/dummy/app/models/gemini/mortgage_type.rb +5 -0
- data/spec/dummy/app/models/gemini/simple.rb +6 -0
- data/spec/dummy/app/models/gemini/streamline_type.rb +16 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/config/application.rb +82 -0
- data/spec/dummy/config/boot.rb +10 -0
- data/spec/dummy/config/database.yml.example +10 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +35 -0
- data/spec/dummy/config/environments/production.rb +69 -0
- data/spec/dummy/config/environments/test.rb +39 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/delayed_job.rb +5 -0
- data/spec/dummy/config/initializers/inflections.rb +15 -0
- data/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/routes.rb +12 -0
- data/spec/dummy/db/migrate/20140801000000_create_groupings.rb +11 -0
- data/spec/dummy/db/migrate/20150406171536_create_categories.rb +27 -0
- data/spec/dummy/db/migrate/20150408200916_create_loan_programs.rb +26 -0
- data/spec/dummy/db/migrate/20150408201429_create_types.rb +21 -0
- data/spec/dummy/db/migrate/20150420000001_create_heads.rb +14 -0
- data/spec/dummy/db/migrate/20150420000002_create_head_versions.rb +15 -0
- data/spec/dummy/db/migrate/20150420000003_create_grouping_head_versions.rb +12 -0
- data/spec/dummy/db/migrate/20151023000001_create_simple.rb +12 -0
- data/spec/dummy/db/seeds.rb +8 -0
- data/spec/dummy/delorean/blame_report.dl +171 -0
- data/spec/dummy/delorean/data_report.dl +105 -0
- data/spec/dummy/delorean/fields.dl +52 -0
- data/spec/dummy/delorean/styles.dl +134 -0
- data/spec/dummy/lib/assets/.gitkeep +0 -0
- data/spec/dummy/lib/class_list.rb +3 -0
- data/spec/dummy/log/.gitkeep +0 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +25 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/public/icons/READ.txt +3 -0
- data/spec/dummy/public/icons/application_cascade.png +0 -0
- data/spec/dummy/public/icons/application_delete.png +0 -0
- data/spec/dummy/public/icons/application_put.png +0 -0
- data/spec/dummy/public/icons/application_view_detail.png +0 -0
- data/spec/dummy/public/icons/arrow_in.png +0 -0
- data/spec/dummy/public/icons/arrow_refresh.png +0 -0
- data/spec/dummy/public/icons/database_save.png +0 -0
- data/spec/dummy/public/icons/door_in.png +0 -0
- data/spec/dummy/public/icons/door_out.png +0 -0
- data/spec/dummy/public/icons/group.png +0 -0
- data/spec/dummy/public/icons/page_lightning.png +0 -0
- data/spec/dummy/public/icons/printer.png +0 -0
- data/spec/dummy/public/icons/report_disk.png +0 -0
- data/spec/dummy/public/icons/report_go.png +0 -0
- data/spec/dummy/public/icons/report_magnify.png +0 -0
- data/spec/dummy/public/icons/script.png +0 -0
- data/spec/dummy/public/icons/script_add.png +0 -0
- data/spec/dummy/public/icons/script_go.png +0 -0
- data/spec/dummy/public/icons/script_key.png +0 -0
- data/spec/dummy/public/icons/table_go.png +0 -0
- data/spec/dummy/public/icons/time.png +0 -0
- data/spec/dummy/public/icons/time_add.png +0 -0
- data/spec/dummy/public/icons/time_go.png +0 -0
- data/spec/dummy/public/icons/timeline_marker.png +0 -0
- data/spec/dummy/public/icons/user_add.png +0 -0
- data/spec/dummy/public/icons/user_delete.png +0 -0
- data/spec/dummy/public/icons/user_edit.png +0 -0
- data/spec/dummy/public/icons/wrench.png +0 -0
- data/spec/dummy/script/delayed_job +6 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/features/javascripts/job_dashboard_live_search.js.coffee +8 -0
- data/spec/features/javascripts/login.js.coffee +8 -0
- data/spec/features/jobs_dashboard_netzke_spec.rb +24 -0
- data/spec/features/jobs_dashboard_spec.rb +49 -0
- data/spec/fixtures/scripts/load_tests/script1.dl +2 -0
- data/spec/fixtures/scripts/load_tests/script2.dl +2 -0
- data/spec/job_helper.rb +102 -0
- data/spec/lib/data_exporter_spec.rb +71 -0
- data/spec/lib/data_importer_spec.rb +461 -0
- data/spec/lib/xl_spec.rb +198 -0
- data/spec/lib/xl_styles_spec.rb +115 -0
- data/spec/models/api_auth_spec.rb +187 -0
- data/spec/models/posting_spec.rb +107 -0
- data/spec/models/promise_spec.rb +65 -0
- data/spec/models/script_spec.rb +187 -0
- data/spec/models/user_spec.rb +68 -0
- data/spec/requests/routes_spec.rb +12 -0
- data/spec/spec_helper.rb +61 -0
- data/spec/support/clean_db_helpers.rb +18 -0
- data/spec/support/delayed_job_helpers.rb +12 -0
- data/spec/support/user_helpers.rb +12 -0
- metadata +139 -89
- data/app/components/marty/auth_app.rb~ +0 -51
- data/app/components/marty/auth_app/javascripts/auth_app.js~ +0 -91
- data/app/components/marty/cm_form_panel.rb~ +0 -5
- data/app/components/marty/cm_grid_panel.rb~ +0 -35
- data/app/components/marty/data_import_view.rb~ +0 -142
- data/app/components/marty/extras/layout.rb~ +0 -46
- data/app/components/marty/live_search_grid_panel.rb~ +0 -49
- data/app/components/marty/main_auth_app.rb~ +0 -238
- data/app/components/marty/mcfly_grid_panel.rb~ +0 -80
- data/app/components/marty/new_posting_form.rb~ +0 -46
- data/app/components/marty/new_posting_window.rb~ +0 -21
- data/app/components/marty/pivot_grid.rb +0 -52
- data/app/components/marty/pivot_grid/endpoints.rb +0 -45
- data/app/components/marty/pivot_grid/javascripts/extensions.js +0 -150
- data/app/components/marty/pivot_grid/javascripts/pivot_grid.js +0 -86
- data/app/components/marty/pivot_grid/services.rb +0 -44
- data/app/components/marty/posting_grid.rb~ +0 -140
- data/app/components/marty/promise_view.rb~ +0 -157
- data/app/components/marty/promise_view/stylesheets/promise_view.css~ +0 -15
- data/app/components/marty/report_form.rb~ +0 -217
- data/app/components/marty/report_select.rb~ +0 -133
- data/app/components/marty/reporting.rb~ +0 -39
- data/app/components/marty/script_detail.rb~ +0 -430
- data/app/components/marty/script_form.rb~ +0 -233
- data/app/components/marty/script_form/javascripts/Ext.ux.form.field.CodeMirror.js~ +0 -909
- data/app/components/marty/script_grid.rb~ +0 -99
- data/app/components/marty/script_tester.rb~ +0 -213
- data/app/components/marty/scripting.rb~ +0 -124
- data/app/components/marty/select_report.rb~ +0 -143
- data/app/components/marty/simple_app.rb~ +0 -101
- data/app/components/marty/tag_grid.rb~ +0 -89
- data/app/components/marty/tree_panel.rb~ +0 -256
- data/app/components/marty/tree_panel/javascripts/tree_panel.js~ +0 -317
- data/app/components/marty/user_pivot.rb +0 -128
- data/app/components/marty/user_view.rb~ +0 -188
- data/app/controllers/marty/application_controller.rb~ +0 -133
- data/app/controllers/marty/components_controller.rb~ +0 -37
- data/app/controllers/marty/job_controller.rb~ +0 -28
- data/app/controllers/marty/rpc_controller.rb~ +0 -61
- data/app/helpers/marty/script_set.rb~ +0 -59
- data/app/models/marty/api_auth.rb~ +0 -48
- data/app/models/marty/data_change.rb~ +0 -141
- data/app/models/marty/enum.rb~ +0 -16
- data/app/models/marty/import_type.rb~ +0 -48
- data/app/models/marty/poop.rb~ +0 -169
- data/app/models/marty/posting.rb~ +0 -86
- data/app/models/marty/posting_type.rb~ +0 -21
- data/app/models/marty/promise.rb~ +0 -196
- data/app/models/marty/role.rb~ +0 -10
- data/app/models/marty/script.rb~ +0 -62
- data/app/models/marty/tag.rb~ +0 -91
- data/app/models/marty/user.rb~ +0 -148
- data/app/models/marty/user_role.rb~ +0 -13
- data/app/views/layouts/marty/application.html.erb~ +0 -11
- data/config/routes.rb~ +0 -10
- data/db/migrate/019_create_marty_postings.rb~ +0 -19
- data/db/migrate/095_create_marty_tags.rb~ +0 -19
- data/lib/marty.rb~ +0 -13
- data/lib/marty/content_handler.rb~ +0 -93
- data/lib/marty/data_exporter.rb~ +0 -137
- data/lib/marty/data_importer.rb~ +0 -114
- data/lib/marty/data_row_processor.rb~ +0 -206
- data/lib/marty/drop_folder_hook.rb~ +0 -17
- data/lib/marty/folder_hook.rb~ +0 -9
- data/lib/marty/lazy_column_loader.rb~ +0 -47
- data/lib/marty/mcfly_query.rb~ +0 -188
- data/lib/marty/migrations.rb~ +0 -65
- data/lib/marty/monkey.rb~ +0 -160
- data/lib/marty/permissions.rb~ +0 -69
- data/lib/marty/promise.rb~ +0 -41
- data/lib/marty/promise_job.rb~ +0 -121
- data/lib/marty/promise_proxy.rb~ +0 -69
- data/lib/marty/util.rb~ +0 -80
- data/lib/marty/version.rb~ +0 -3
- data/lib/marty/xl.rb~ +0 -526
- data/lib/pyxll/README.txt~ +0 -16
- data/lib/pyxll/gemini.py~ +0 -110
- 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
|
data/lib/marty/folder_hook.rb~
DELETED
@@ -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
|
data/lib/marty/mcfly_query.rb~
DELETED
@@ -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
|
data/lib/marty/migrations.rb~
DELETED
@@ -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
|