caddie 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (62) hide show
  1. checksums.yaml +7 -0
  2. data/MIT-LICENSE +20 -0
  3. data/README.rdoc +3 -0
  4. data/Rakefile +37 -0
  5. data/app/assets/javascripts/caddie/application.js +13 -0
  6. data/app/assets/stylesheets/caddie/application.css +15 -0
  7. data/app/controllers/caddie/application_controller.rb +5 -0
  8. data/app/helpers/caddie/application_helper.rb +4 -0
  9. data/app/models/caddie/crest_data_retriever.rb +50 -0
  10. data/app/models/caddie/crest_price_history_update.rb +56 -0
  11. data/app/models/caddie/update_table.sql +39 -0
  12. data/app/models/crest_price_history.rb +1 -0
  13. data/app/models/eve_item.rb +1 -0
  14. data/app/models/region.rb +1 -0
  15. data/app/views/layouts/caddie/application.html.erb +14 -0
  16. data/config/routes.rb +2 -0
  17. data/db/migrate/20160524122651_create_caddie_crest_price_history_updates.rb +21 -0
  18. data/lib/caddie/engine.rb +5 -0
  19. data/lib/caddie/version.rb +3 -0
  20. data/lib/caddie.rb +4 -0
  21. data/lib/tasks/caddie_tasks.rake +16 -0
  22. data/test/caddie_test.rb +7 -0
  23. data/test/dummy/README.rdoc +28 -0
  24. data/test/dummy/Rakefile +6 -0
  25. data/test/dummy/app/assets/javascripts/application.js +13 -0
  26. data/test/dummy/app/assets/stylesheets/application.css +15 -0
  27. data/test/dummy/app/controllers/application_controller.rb +5 -0
  28. data/test/dummy/app/helpers/application_helper.rb +2 -0
  29. data/test/dummy/app/views/layouts/application.html.erb +14 -0
  30. data/test/dummy/bin/bundle +3 -0
  31. data/test/dummy/bin/rails +4 -0
  32. data/test/dummy/bin/rake +4 -0
  33. data/test/dummy/bin/setup +29 -0
  34. data/test/dummy/config/application.rb +26 -0
  35. data/test/dummy/config/boot.rb +5 -0
  36. data/test/dummy/config/database.yml +24 -0
  37. data/test/dummy/config/environment.rb +5 -0
  38. data/test/dummy/config/environments/development.rb +41 -0
  39. data/test/dummy/config/environments/production.rb +79 -0
  40. data/test/dummy/config/environments/test.rb +42 -0
  41. data/test/dummy/config/initializers/assets.rb +11 -0
  42. data/test/dummy/config/initializers/backtrace_silencers.rb +7 -0
  43. data/test/dummy/config/initializers/cookies_serializer.rb +3 -0
  44. data/test/dummy/config/initializers/filter_parameter_logging.rb +4 -0
  45. data/test/dummy/config/initializers/inflections.rb +16 -0
  46. data/test/dummy/config/initializers/mime_types.rb +4 -0
  47. data/test/dummy/config/initializers/session_store.rb +3 -0
  48. data/test/dummy/config/initializers/wrap_parameters.rb +14 -0
  49. data/test/dummy/config/locales/en.yml +23 -0
  50. data/test/dummy/config/routes.rb +4 -0
  51. data/test/dummy/config/secrets.yml +22 -0
  52. data/test/dummy/config.ru +4 -0
  53. data/test/dummy/db/schema.rb +368 -0
  54. data/test/dummy/log/development.log +50234 -0
  55. data/test/dummy/public/404.html +67 -0
  56. data/test/dummy/public/422.html +67 -0
  57. data/test/dummy/public/500.html +66 -0
  58. data/test/dummy/public/favicon.ico +0 -0
  59. data/test/integration/navigation_test.rb +8 -0
  60. data/test/models/caddie/crest_price_history_update_test.rb +9 -0
  61. data/test/test_helper.rb +21 -0
  62. metadata +187 -0
@@ -0,0 +1,79 @@
1
+ Rails.application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb.
3
+
4
+ # Code is not reloaded between requests.
5
+ config.cache_classes = true
6
+
7
+ # Eager load code on boot. This eager loads most of Rails and
8
+ # your application in memory, allowing both threaded web servers
9
+ # and those relying on copy on write to perform better.
10
+ # Rake tasks automatically ignore this option for performance.
11
+ config.eager_load = true
12
+
13
+ # Full error reports are disabled and caching is turned on.
14
+ config.consider_all_requests_local = false
15
+ config.action_controller.perform_caching = true
16
+
17
+ # Enable Rack::Cache to put a simple HTTP cache in front of your application
18
+ # Add `rack-cache` to your Gemfile before enabling this.
19
+ # For large-scale production use, consider using a caching reverse proxy like
20
+ # NGINX, varnish or squid.
21
+ # config.action_dispatch.rack_cache = true
22
+
23
+ # Disable serving static files from the `/public` folder by default since
24
+ # Apache or NGINX already handles this.
25
+ config.serve_static_files = ENV['RAILS_SERVE_STATIC_FILES'].present?
26
+
27
+ # Compress JavaScripts and CSS.
28
+ config.assets.js_compressor = :uglifier
29
+ # config.assets.css_compressor = :sass
30
+
31
+ # Do not fallback to assets pipeline if a precompiled asset is missed.
32
+ config.assets.compile = false
33
+
34
+ # Asset digests allow you to set far-future HTTP expiration dates on all assets,
35
+ # yet still be able to expire them through the digest params.
36
+ config.assets.digest = true
37
+
38
+ # `config.assets.precompile` and `config.assets.version` have moved to config/initializers/assets.rb
39
+
40
+ # Specifies the header that your server uses for sending files.
41
+ # config.action_dispatch.x_sendfile_header = 'X-Sendfile' # for Apache
42
+ # config.action_dispatch.x_sendfile_header = 'X-Accel-Redirect' # for NGINX
43
+
44
+ # Force all access to the app over SSL, use Strict-Transport-Security, and use secure cookies.
45
+ # config.force_ssl = true
46
+
47
+ # Use the lowest log level to ensure availability of diagnostic information
48
+ # when problems arise.
49
+ config.log_level = :debug
50
+
51
+ # Prepend all log lines with the following tags.
52
+ # config.log_tags = [ :subdomain, :uuid ]
53
+
54
+ # Use a different logger for distributed setups.
55
+ # config.logger = ActiveSupport::TaggedLogging.new(SyslogLogger.new)
56
+
57
+ # Use a different cache store in production.
58
+ # config.cache_store = :mem_cache_store
59
+
60
+ # Enable serving of images, stylesheets, and JavaScripts from an asset server.
61
+ # config.action_controller.asset_host = 'http://assets.example.com'
62
+
63
+ # Ignore bad email addresses and do not raise email delivery errors.
64
+ # Set this to true and configure the email server for immediate delivery to raise delivery errors.
65
+ # config.action_mailer.raise_delivery_errors = false
66
+
67
+ # Enable locale fallbacks for I18n (makes lookups for any locale fall back to
68
+ # the I18n.default_locale when a translation cannot be found).
69
+ config.i18n.fallbacks = true
70
+
71
+ # Send deprecation notices to registered listeners.
72
+ config.active_support.deprecation = :notify
73
+
74
+ # Use default logging formatter so that PID and timestamp are not suppressed.
75
+ config.log_formatter = ::Logger::Formatter.new
76
+
77
+ # Do not dump schema after migrations.
78
+ config.active_record.dump_schema_after_migration = false
79
+ end
@@ -0,0 +1,42 @@
1
+ Rails.application.configure do
2
+ # Settings specified here will take precedence over those in config/application.rb.
3
+
4
+ # The test environment is used exclusively to run your application's
5
+ # test suite. You never need to work with it otherwise. Remember that
6
+ # your test database is "scratch space" for the test suite and is wiped
7
+ # and recreated between test runs. Don't rely on the data there!
8
+ config.cache_classes = true
9
+
10
+ # Do not eager load code on boot. This avoids loading your whole application
11
+ # just for the purpose of running a single test. If you are using a tool that
12
+ # preloads Rails for running tests, you may have to set it to true.
13
+ config.eager_load = false
14
+
15
+ # Configure static file server for tests with Cache-Control for performance.
16
+ config.serve_static_files = true
17
+ config.static_cache_control = 'public, max-age=3600'
18
+
19
+ # Show full error reports and disable caching.
20
+ config.consider_all_requests_local = true
21
+ config.action_controller.perform_caching = false
22
+
23
+ # Raise exceptions instead of rendering exception templates.
24
+ config.action_dispatch.show_exceptions = false
25
+
26
+ # Disable request forgery protection in test environment.
27
+ config.action_controller.allow_forgery_protection = false
28
+
29
+ # Tell Action Mailer not to deliver emails to the real world.
30
+ # The :test delivery method accumulates sent emails in the
31
+ # ActionMailer::Base.deliveries array.
32
+ config.action_mailer.delivery_method = :test
33
+
34
+ # Randomize the order test cases are executed.
35
+ config.active_support.test_order = :random
36
+
37
+ # Print deprecation notices to the stderr.
38
+ config.active_support.deprecation = :stderr
39
+
40
+ # Raises error for missing translations
41
+ # config.action_view.raise_on_missing_translations = true
42
+ end
@@ -0,0 +1,11 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Version of your assets, change this if you want to expire all your assets.
4
+ Rails.application.config.assets.version = '1.0'
5
+
6
+ # Add additional assets to the asset load path
7
+ # Rails.application.config.assets.paths << Emoji.images_path
8
+
9
+ # Precompile additional assets.
10
+ # application.js, application.css, and all non-JS/CSS in app/assets folder are already added.
11
+ # Rails.application.config.assets.precompile += %w( search.js )
@@ -0,0 +1,7 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # You can add backtrace silencers for libraries that you're using but don't wish to see in your backtraces.
4
+ # Rails.backtrace_cleaner.add_silencer { |line| line =~ /my_noisy_library/ }
5
+
6
+ # You can also remove all the silencers if you're trying to debug a problem that might stem from framework code.
7
+ # Rails.backtrace_cleaner.remove_silencers!
@@ -0,0 +1,3 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ Rails.application.config.action_dispatch.cookies_serializer = :json
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Configure sensitive parameters which will be filtered from the log file.
4
+ Rails.application.config.filter_parameters += [:password]
@@ -0,0 +1,16 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new inflection rules using the following format. Inflections
4
+ # are locale specific, and you may define rules for as many different
5
+ # locales as you wish. All of these examples are active by default:
6
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
7
+ # inflect.plural /^(ox)$/i, '\1en'
8
+ # inflect.singular /^(ox)en/i, '\1'
9
+ # inflect.irregular 'person', 'people'
10
+ # inflect.uncountable %w( fish sheep )
11
+ # end
12
+
13
+ # These inflection rules are supported but not enabled by default:
14
+ # ActiveSupport::Inflector.inflections(:en) do |inflect|
15
+ # inflect.acronym 'RESTful'
16
+ # end
@@ -0,0 +1,4 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Add new mime types for use in respond_to blocks:
4
+ # Mime::Type.register "text/richtext", :rtf
@@ -0,0 +1,3 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ Rails.application.config.session_store :cookie_store, key: '_dummy_session'
@@ -0,0 +1,14 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # This file contains settings for ActionController::ParamsWrapper which
4
+ # is enabled by default.
5
+
6
+ # Enable parameter wrapping for JSON. You can disable this by setting :format to an empty array.
7
+ ActiveSupport.on_load(:action_controller) do
8
+ wrap_parameters format: [:json] if respond_to?(:wrap_parameters)
9
+ end
10
+
11
+ # To enable root element in JSON for ActiveRecord objects.
12
+ # ActiveSupport.on_load(:active_record) do
13
+ # self.include_root_in_json = true
14
+ # end
@@ -0,0 +1,23 @@
1
+ # Files in the config/locales directory are used for internationalization
2
+ # and are automatically loaded by Rails. If you want to use locales other
3
+ # than English, add the necessary files in this directory.
4
+ #
5
+ # To use the locales, use `I18n.t`:
6
+ #
7
+ # I18n.t 'hello'
8
+ #
9
+ # In views, this is aliased to just `t`:
10
+ #
11
+ # <%= t('hello') %>
12
+ #
13
+ # To use a different locale, set it with `I18n.locale`:
14
+ #
15
+ # I18n.locale = :es
16
+ #
17
+ # This would use the information in config/locales/es.yml.
18
+ #
19
+ # To learn more, please read the Rails Internationalization guide
20
+ # available at http://guides.rubyonrails.org/i18n.html.
21
+
22
+ en:
23
+ hello: "Hello world"
@@ -0,0 +1,4 @@
1
+ Rails.application.routes.draw do
2
+
3
+ mount Caddie::Engine => "/caddie"
4
+ end
@@ -0,0 +1,22 @@
1
+ # Be sure to restart your server when you modify this file.
2
+
3
+ # Your secret key is used for verifying the integrity of signed cookies.
4
+ # If you change this key, all old signed cookies will become invalid!
5
+
6
+ # Make sure the secret is at least 30 characters and all random,
7
+ # no regular words or you'll be exposed to dictionary attacks.
8
+ # You can use `rake secret` to generate a secure secret key.
9
+
10
+ # Make sure the secrets in this file are kept private
11
+ # if you're sharing your code publicly.
12
+
13
+ development:
14
+ secret_key_base: ad7c292450ce212dd48633918e7e8398f7f75fce4b66c0973091f990e4b49c33fca0da6ad40a171d3fb2a60ce0b8844d52eb5d78021c7db5d4b7eade7b902b2f
15
+
16
+ test:
17
+ secret_key_base: 3715029d2627ede10e1444117c31899160a676d03510d0083b9fe8d8db65076077dfb8cda27f01f729438e828b5123e1546e4d4f22c5f3935393a9eb12d81c19
18
+
19
+ # Do not keep production secrets in the repository,
20
+ # instead read values from the environment.
21
+ production:
22
+ secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>
@@ -0,0 +1,4 @@
1
+ # This file is used by Rack-based servers to start the application.
2
+
3
+ require ::File.expand_path('../config/environment', __FILE__)
4
+ run Rails.application
@@ -0,0 +1,368 @@
1
+ # encoding: UTF-8
2
+ # This file is auto-generated from the current state of the database. Instead
3
+ # of editing this file, please use the migrations feature of Active Record to
4
+ # incrementally modify your database, and then regenerate this schema definition.
5
+ #
6
+ # Note that this schema.rb definition is the authoritative source for your
7
+ # database schema. If you need to create the application database on another
8
+ # system, you should be using db:schema:load, not running all the migrations
9
+ # from scratch. The latter is a flawed and unsustainable approach (the more migrations
10
+ # you'll amass, the slower it'll run and the greater likelihood for issues).
11
+ #
12
+ # It's strongly recommended that you check this file into your version control system.
13
+
14
+ ActiveRecord::Schema.define(version: 20160524122651) do
15
+
16
+ # These are extensions that must be enabled in order to support this database
17
+ enable_extension "plpgsql"
18
+
19
+ create_table "api_key_errors", force: :cascade do |t|
20
+ t.integer "user_id"
21
+ t.string "error_message"
22
+ t.datetime "created_at", null: false
23
+ t.datetime "updated_at", null: false
24
+ t.string "user_message"
25
+ end
26
+
27
+ add_index "api_key_errors", ["user_id"], name: "index_api_key_errors_on_user_id", using: :btree
28
+
29
+ create_table "blueprints", force: :cascade do |t|
30
+ t.integer "eve_item_id"
31
+ t.integer "nb_runs"
32
+ t.integer "prod_qtt"
33
+ t.datetime "created_at"
34
+ t.datetime "updated_at"
35
+ t.integer "cpp_blueprint_id"
36
+ end
37
+
38
+ add_index "blueprints", ["cpp_blueprint_id"], name: "index_blueprints_on_cpp_blueprint_id", using: :btree
39
+ add_index "blueprints", ["eve_item_id"], name: "index_blueprints_on_eve_item_id", using: :btree
40
+
41
+ create_table "caddie_crest_price_history_updates", force: :cascade do |t|
42
+ t.integer "eve_item_id"
43
+ t.integer "region_id"
44
+ t.date "max_update"
45
+ t.date "max_eve_item_create"
46
+ t.date "max_region_create"
47
+ t.date "max_date"
48
+ t.integer "nb_days"
49
+ t.string "process_queue"
50
+ t.integer "process_queue_priority"
51
+ t.date "next_process_date"
52
+ t.datetime "created_at", null: false
53
+ t.datetime "updated_at", null: false
54
+ end
55
+
56
+ add_index "caddie_crest_price_history_updates", ["eve_item_id", "region_id"], name: "index_caddie_cphu_on_eve_item_id_and_region_id", unique: true, using: :btree
57
+
58
+ create_table "components", force: :cascade do |t|
59
+ t.integer "cpp_eve_item_id"
60
+ t.string "name", limit: 255
61
+ t.float "cost"
62
+ t.datetime "created_at"
63
+ t.datetime "updated_at"
64
+ end
65
+
66
+ add_index "components", ["cpp_eve_item_id"], name: "index_components_on_cpp_eve_item_id", using: :btree
67
+
68
+ create_table "crest_costs", force: :cascade do |t|
69
+ t.integer "cpp_item_id", null: false
70
+ t.integer "eve_item_id", null: false
71
+ t.float "adjusted_price"
72
+ t.float "average_price"
73
+ t.float "cost"
74
+ t.datetime "created_at"
75
+ t.datetime "updated_at"
76
+ end
77
+
78
+ add_index "crest_costs", ["cpp_item_id"], name: "index_crest_costs_on_cpp_item_id", unique: true, using: :btree
79
+ add_index "crest_costs", ["eve_item_id"], name: "index_crest_costs_on_eve_item_id", unique: true, using: :btree
80
+
81
+ create_table "crest_price_histories", force: :cascade do |t|
82
+ t.integer "region_id", null: false
83
+ t.integer "eve_item_id", null: false
84
+ t.string "day_timestamp", null: false
85
+ t.datetime "history_date", null: false
86
+ t.integer "order_count", limit: 8
87
+ t.integer "volume", limit: 8
88
+ t.float "low_price"
89
+ t.float "avg_price"
90
+ t.float "high_price"
91
+ t.datetime "created_at", null: false
92
+ t.datetime "updated_at", null: false
93
+ end
94
+
95
+ add_index "crest_price_histories", ["day_timestamp"], name: "index_crest_price_histories_on_day_timestamp", using: :btree
96
+ add_index "crest_price_histories", ["eve_item_id"], name: "index_crest_price_histories_on_eve_item_id", using: :btree
97
+ add_index "crest_price_histories", ["history_date"], name: "index_crest_price_histories_on_history_date", using: :btree
98
+ add_index "crest_price_histories", ["region_id", "eve_item_id", "day_timestamp"], name: "price_histories_all_keys_index", unique: true, using: :btree
99
+ add_index "crest_price_histories", ["region_id"], name: "index_crest_price_histories_on_region_id", using: :btree
100
+
101
+ create_table "crest_price_histories_daily_used", id: false, force: :cascade do |t|
102
+ t.integer "eve_item_id"
103
+ t.integer "region_id"
104
+ t.datetime "max"
105
+ t.datetime "items_created_at"
106
+ t.datetime "regions_created_at"
107
+ end
108
+
109
+ create_table "crest_price_histories_frequently_used", id: false, force: :cascade do |t|
110
+ t.integer "eve_item_id"
111
+ t.integer "region_id"
112
+ t.datetime "updated_at"
113
+ t.datetime "items_created_at"
114
+ t.datetime "regions_created_at"
115
+ end
116
+
117
+ create_table "crest_price_histories_never_used", id: false, force: :cascade do |t|
118
+ t.integer "eve_items_id"
119
+ t.integer "regions_id"
120
+ end
121
+
122
+ create_table "crest_price_histories_rarely_used", id: false, force: :cascade do |t|
123
+ t.integer "eve_items_id"
124
+ t.integer "regions_id"
125
+ end
126
+
127
+ create_table "crest_prices_last_month_averages", force: :cascade do |t|
128
+ t.integer "region_id", null: false
129
+ t.integer "eve_item_id", null: false
130
+ t.integer "order_count_sum", limit: 8
131
+ t.integer "volume_sum", limit: 8
132
+ t.integer "order_count_avg", limit: 8
133
+ t.integer "volume_avg", limit: 8
134
+ t.float "low_price_avg"
135
+ t.float "avg_price_avg"
136
+ t.float "high_price_avg"
137
+ t.datetime "created_at", null: false
138
+ t.datetime "updated_at", null: false
139
+ end
140
+
141
+ add_index "crest_prices_last_month_averages", ["eve_item_id"], name: "index_crest_prices_last_month_averages_on_eve_item_id", using: :btree
142
+ add_index "crest_prices_last_month_averages", ["region_id", "eve_item_id"], name: "prices_lmavg_all_keys_index", unique: true, using: :btree
143
+ add_index "crest_prices_last_month_averages", ["region_id"], name: "index_crest_prices_last_month_averages_on_region_id", using: :btree
144
+
145
+ create_table "eve_clients", force: :cascade do |t|
146
+ t.string "cpp_client_id", limit: 255, null: false
147
+ t.string "name", limit: 255, null: false
148
+ t.datetime "created_at"
149
+ t.datetime "updated_at"
150
+ end
151
+
152
+ add_index "eve_clients", ["cpp_client_id"], name: "index_eve_clients_on_cpp_client_id", unique: true, using: :btree
153
+
154
+ create_table "eve_items", force: :cascade do |t|
155
+ t.integer "cpp_eve_item_id"
156
+ t.string "name", limit: 255, null: false
157
+ t.datetime "created_at"
158
+ t.datetime "updated_at"
159
+ t.string "name_lowcase", limit: 255
160
+ t.float "cost"
161
+ t.boolean "epic_blueprint", default: false
162
+ t.boolean "involved_in_blueprint", default: false
163
+ t.integer "market_group_id"
164
+ end
165
+
166
+ add_index "eve_items", ["cpp_eve_item_id"], name: "index_eve_items_on_cpp_eve_item_id", using: :btree
167
+ add_index "eve_items", ["market_group_id"], name: "index_eve_items_on_market_group_id", using: :btree
168
+
169
+ create_table "eve_items_users", force: :cascade do |t|
170
+ t.integer "user_id"
171
+ t.integer "eve_item_id"
172
+ end
173
+
174
+ add_index "eve_items_users", ["eve_item_id"], name: "index_eve_items_users_on_eve_item_id", using: :btree
175
+ add_index "eve_items_users", ["user_id"], name: "index_eve_items_users_on_user_id", using: :btree
176
+
177
+ create_table "identities", force: :cascade do |t|
178
+ t.string "name", limit: 255
179
+ t.string "email", limit: 255
180
+ t.string "password_digest", limit: 255
181
+ t.datetime "created_at"
182
+ t.datetime "updated_at"
183
+ end
184
+
185
+ create_table "jita_margins", force: :cascade do |t|
186
+ t.integer "eve_item_id"
187
+ t.float "margin"
188
+ t.datetime "created_at"
189
+ t.datetime "updated_at"
190
+ t.float "margin_percent"
191
+ t.float "jita_min_price"
192
+ t.float "cost"
193
+ t.integer "mens_volume", limit: 8, default: 0, null: false
194
+ t.integer "batch_size", limit: 8, default: 0, null: false
195
+ end
196
+
197
+ add_index "jita_margins", ["eve_item_id"], name: "index_jita_margins_on_eve_item_id", using: :btree
198
+
199
+ create_table "market_group_hierarchies", id: false, force: :cascade do |t|
200
+ t.integer "ancestor_id", null: false
201
+ t.integer "descendant_id", null: false
202
+ t.integer "generations", null: false
203
+ end
204
+
205
+ add_index "market_group_hierarchies", ["ancestor_id", "descendant_id", "generations"], name: "market_group_anc_desc_idx", unique: true, using: :btree
206
+ add_index "market_group_hierarchies", ["descendant_id"], name: "market_group_desc_idx", using: :btree
207
+
208
+ create_table "market_groups", force: :cascade do |t|
209
+ t.string "cpp_market_group_id", null: false
210
+ t.string "name", null: false
211
+ t.integer "parent_id"
212
+ t.datetime "created_at", null: false
213
+ t.datetime "updated_at", null: false
214
+ end
215
+
216
+ add_index "market_groups", ["cpp_market_group_id"], name: "index_market_groups_on_cpp_market_group_id", unique: true, using: :btree
217
+
218
+ create_table "materials", force: :cascade do |t|
219
+ t.integer "blueprint_id"
220
+ t.integer "component_id"
221
+ t.integer "required_qtt"
222
+ t.datetime "created_at"
223
+ t.datetime "updated_at"
224
+ end
225
+
226
+ add_index "materials", ["blueprint_id"], name: "index_materials_on_blueprint_id", using: :btree
227
+ add_index "materials", ["component_id"], name: "index_materials_on_component_id", using: :btree
228
+
229
+ create_table "min_prices", force: :cascade do |t|
230
+ t.integer "eve_item_id"
231
+ t.integer "trade_hub_id"
232
+ t.float "min_price"
233
+ t.datetime "created_at"
234
+ t.datetime "updated_at"
235
+ end
236
+
237
+ add_index "min_prices", ["eve_item_id"], name: "index_min_prices_on_eve_item_id", using: :btree
238
+ add_index "min_prices", ["trade_hub_id"], name: "index_min_prices_on_trade_hub_id", using: :btree
239
+
240
+ create_table "regions", force: :cascade do |t|
241
+ t.string "cpp_region_id", null: false
242
+ t.string "name", null: false
243
+ t.datetime "created_at", null: false
244
+ t.datetime "updated_at", null: false
245
+ end
246
+
247
+ add_index "regions", ["cpp_region_id"], name: "index_regions_on_cpp_region_id", unique: true, using: :btree
248
+
249
+ create_table "sale_records", force: :cascade do |t|
250
+ t.integer "user_id", null: false
251
+ t.integer "eve_client_id", null: false
252
+ t.integer "eve_item_id", null: false
253
+ t.integer "station_id", null: false
254
+ t.string "eve_transaction_key", limit: 255, null: false
255
+ t.integer "quantity", null: false
256
+ t.float "unit_sale_price", null: false
257
+ t.float "total_sale_price", null: false
258
+ t.float "unit_cost"
259
+ t.float "unit_sale_profit"
260
+ t.float "total_sale_profit"
261
+ t.datetime "transaction_date_time", null: false
262
+ t.datetime "created_at"
263
+ t.datetime "updated_at"
264
+ end
265
+
266
+ add_index "sale_records", ["eve_client_id"], name: "index_sale_records_on_eve_client_id", using: :btree
267
+ add_index "sale_records", ["eve_item_id"], name: "index_sale_records_on_eve_item_id", using: :btree
268
+ add_index "sale_records", ["eve_transaction_key"], name: "index_sale_records_on_eve_transaction_key", unique: true, using: :btree
269
+ add_index "sale_records", ["station_id"], name: "index_sale_records_on_station_id", using: :btree
270
+ add_index "sale_records", ["user_id"], name: "index_sale_records_on_user_id", using: :btree
271
+
272
+ create_table "shopping_baskets", force: :cascade do |t|
273
+ t.integer "user_id", null: false
274
+ t.integer "trade_hub_id", null: false
275
+ t.integer "eve_item_id", null: false
276
+ t.datetime "created_at", null: false
277
+ t.datetime "updated_at", null: false
278
+ end
279
+
280
+ add_index "shopping_baskets", ["eve_item_id"], name: "index_shopping_baskets_on_eve_item_id", using: :btree
281
+ add_index "shopping_baskets", ["trade_hub_id"], name: "index_shopping_baskets_on_trade_hub_id", using: :btree
282
+ add_index "shopping_baskets", ["user_id"], name: "index_shopping_baskets_on_user_id", using: :btree
283
+
284
+ create_table "stations", force: :cascade do |t|
285
+ t.integer "trade_hub_id"
286
+ t.string "name", limit: 255
287
+ t.integer "cpp_station_id"
288
+ t.datetime "created_at"
289
+ t.datetime "updated_at"
290
+ end
291
+
292
+ add_index "stations", ["cpp_station_id"], name: "index_stations_on_cpp_station_id", using: :btree
293
+ add_index "stations", ["trade_hub_id"], name: "index_stations_on_trade_hub_id", using: :btree
294
+
295
+ create_table "trade_hubs", force: :cascade do |t|
296
+ t.integer "eve_system_id"
297
+ t.string "name", limit: 255
298
+ t.datetime "created_at"
299
+ t.datetime "updated_at"
300
+ t.integer "region_id"
301
+ t.boolean "inner", default: false
302
+ end
303
+
304
+ add_index "trade_hubs", ["region_id"], name: "index_trade_hubs_on_region_id", using: :btree
305
+
306
+ create_table "trade_hubs_users", force: :cascade do |t|
307
+ t.integer "user_id"
308
+ t.integer "trade_hub_id"
309
+ end
310
+
311
+ add_index "trade_hubs_users", ["trade_hub_id"], name: "index_trade_hubs_users_on_trade_hub_id", using: :btree
312
+ add_index "trade_hubs_users", ["user_id"], name: "index_trade_hubs_users_on_user_id", using: :btree
313
+
314
+ create_table "trade_orders", force: :cascade do |t|
315
+ t.integer "user_id"
316
+ t.integer "eve_item_id"
317
+ t.integer "trade_hub_id"
318
+ t.datetime "created_at"
319
+ t.datetime "updated_at"
320
+ t.boolean "new_order"
321
+ t.float "price"
322
+ end
323
+
324
+ add_index "trade_orders", ["eve_item_id"], name: "index_trade_orders_on_eve_item_id", using: :btree
325
+ add_index "trade_orders", ["trade_hub_id"], name: "index_trade_orders_on_trade_hub_id", using: :btree
326
+ add_index "trade_orders", ["user_id"], name: "index_trade_orders_on_user_id", using: :btree
327
+
328
+ create_table "user_activity_logs", force: :cascade do |t|
329
+ t.string "ip"
330
+ t.string "action"
331
+ t.datetime "created_at", null: false
332
+ t.datetime "updated_at", null: false
333
+ t.string "user"
334
+ end
335
+
336
+ create_table "users", force: :cascade do |t|
337
+ t.string "name", limit: 255
338
+ t.boolean "remove_occuped_places"
339
+ t.string "key_user_id", limit: 255
340
+ t.string "api_key", limit: 255
341
+ t.datetime "created_at"
342
+ t.datetime "updated_at"
343
+ t.string "provider", limit: 255
344
+ t.string "uid", limit: 255
345
+ t.string "oauth_token", limit: 255
346
+ t.datetime "oauth_expires_at"
347
+ t.datetime "last_changes_in_choices"
348
+ t.integer "min_pcent_for_advice"
349
+ t.boolean "watch_my_prices"
350
+ t.float "min_amount_for_advice"
351
+ t.boolean "admin", default: false, null: false
352
+ end
353
+
354
+ add_foreign_key "api_key_errors", "users"
355
+ add_foreign_key "blueprints", "eve_items"
356
+ add_foreign_key "caddie_crest_price_history_updates", "eve_items"
357
+ add_foreign_key "caddie_crest_price_history_updates", "regions"
358
+ add_foreign_key "crest_costs", "eve_items"
359
+ add_foreign_key "crest_price_histories", "eve_items"
360
+ add_foreign_key "crest_price_histories", "regions"
361
+ add_foreign_key "crest_prices_last_month_averages", "eve_items"
362
+ add_foreign_key "crest_prices_last_month_averages", "regions"
363
+ add_foreign_key "eve_items", "market_groups"
364
+ add_foreign_key "shopping_baskets", "eve_items"
365
+ add_foreign_key "shopping_baskets", "trade_hubs"
366
+ add_foreign_key "shopping_baskets", "users"
367
+ add_foreign_key "trade_hubs", "regions"
368
+ end