erp_orders 3.0.6 → 3.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. data/app/models/charge_line.rb +20 -19
  2. data/app/models/charge_line_payment_txn.rb +2 -0
  3. data/app/models/line_item_role_type.rb +2 -0
  4. data/app/models/order_line_item.rb +1 -0
  5. data/app/models/order_line_item_pty_role.rb +8 -7
  6. data/app/models/order_line_item_type.rb +2 -0
  7. data/app/models/order_txn.rb +2 -0
  8. data/app/models/order_txn_type.rb +2 -0
  9. data/db/migrate/20080805000060_base_orders.rb +2 -0
  10. data/lib/erp_orders.rb +2 -0
  11. data/lib/erp_orders/version.rb +2 -2
  12. data/public/javascripts/erp_app/desktop/applications/order_manager/line_items_grid_panel.js +1 -1
  13. data/public/javascripts/erp_app/desktop/applications/order_manager/payments_grid_panel.js +1 -1
  14. data/public/javascripts/erp_app/organizer/applications/order_management/line_items_grid_panel.js +1 -1
  15. data/public/javascripts/erp_app/organizer/applications/order_management/payments_grid_panel.js +1 -1
  16. data/spec/dummy/config/application.rb +6 -0
  17. data/spec/dummy/config/environments/spec.rb +3 -0
  18. data/spec/dummy/db/data_migrations/20101011152441_payment_gateway_actions.erp_commerce.rb +28 -0
  19. data/spec/dummy/db/data_migrations/20101014142230_financial_txn_types.erp_txns_and_accts.rb +16 -0
  20. data/spec/dummy/db/data_migrations/20110109173616_create_capability_scope_types.erp_tech_svcs.rb +15 -0
  21. data/spec/dummy/db/data_migrations/20110324010232_product_role_types.erp_products.rb +24 -0
  22. data/spec/dummy/db/data_migrations/20110525001935_add_usd_currency.erp_base_erp_svcs.rb +12 -0
  23. data/spec/dummy/db/data_migrations/20110527160807_add_default_prod_avail_types.erp_products.rb +27 -0
  24. data/spec/dummy/db/data_migrations/20110605231556_create_order_party_roles.erp_orders.rb +24 -0
  25. data/spec/dummy/db/data_migrations/20110609150135_add_iso_codes.erp_base_erp_svcs.rb +19 -0
  26. data/spec/dummy/db/data_migrations/20110728201729_erp_app_setup.erp_app.rb +252 -0
  27. data/spec/dummy/db/data_migrations/20110728201730_create_desktop_app_product_manager.erp_products.rb +26 -0
  28. data/spec/dummy/db/data_migrations/20110728201731_create_desktop_app_order_manager.erp_orders.rb +26 -0
  29. data/spec/dummy/db/data_migrations/20110728201732_create_organizer_app_order_management.erp_orders.rb +15 -0
  30. data/spec/dummy/db/data_migrations/20110728201733_update_preferences.erp_app.rb +53 -0
  31. data/spec/dummy/db/data_migrations/20110802200222_schedule_delete_expired_sessions_job.erp_tech_svcs.rb +16 -0
  32. data/spec/dummy/db/data_migrations/20110816161238_create_desktop_app_audit_log_viewer.erp_app.rb +21 -0
  33. data/spec/dummy/db/data_migrations/20110817160743_add_file_manager_application.erp_app.rb +32 -0
  34. data/spec/dummy/db/data_migrations/20110913145838_setup_compass_ae_instance.erp_base_erp_svcs.rb +12 -0
  35. data/spec/dummy/db/data_migrations/20111108183739_add_default_capabilities.erp_app.rb +23 -0
  36. data/spec/dummy/db/data_migrations/20111108183740_add_new_contact_widgets.erp_app.rb +42 -0
  37. data/spec/dummy/db/data_migrations/20111111144706_setup_audit_log_types.erp_tech_svcs.rb +22 -0
  38. data/spec/dummy/db/data_migrations/20120109173616_create_download_capability_type.erp_tech_svcs.rb +14 -0
  39. data/spec/dummy/db/data_migrations/20120229160222_add_userinfo_widget.erp_app.rb +29 -0
  40. data/spec/dummy/db/data_migrations/20120229174343_add_orders_widget.erp_orders.rb +29 -0
  41. data/spec/dummy/db/data_migrations/20120405193721_create_party_and_role_type_for_communication_events.erp_app.rb +11 -0
  42. data/spec/dummy/db/data_migrations/20120411180756_create_user_management_mobile_application.erp_app.rb +19 -0
  43. data/spec/dummy/db/data_migrations/20120418164215_create_configuration_management_desktop_application.erp_app.rb +23 -0
  44. data/spec/dummy/db/data_migrations/20121116155018_create_group_relationship_and_role_types.erp_tech_svcs.rb +20 -0
  45. data/spec/dummy/db/data_migrations/20121130201859_upgrade_remove_system_mgmt_app.erp_app.rb +16 -0
  46. data/spec/dummy/db/data_migrations/20121130212146_note_capabilities.erp_tech_svcs.rb +24 -0
  47. data/spec/dummy/db/data_migrations/20121218175028_create_security_management_desktop_application.erp_app.rb +23 -0
  48. data/spec/dummy/db/migrate/20130107214803_base_erp_services.erp_base_erp_svcs.rb +461 -0
  49. data/spec/dummy/db/migrate/20130107214804_base_orders.erp_orders.rb +178 -0
  50. data/spec/dummy/db/migrate/20130107214805_base_tech_services.erp_tech_svcs.rb +271 -0
  51. data/spec/dummy/db/migrate/20130107214806_create_has_attribute_tables.erp_tech_svcs.rb +39 -0
  52. data/spec/dummy/db/migrate/20130107214807_create_groups.erp_tech_svcs.rb +19 -0
  53. data/spec/dummy/db/migrate/20130107214808_upgrade_security.erp_tech_svcs.rb +54 -0
  54. data/spec/dummy/db/migrate/20130107214809_upgrade_security2.erp_tech_svcs.rb +270 -0
  55. data/spec/dummy/db/migrate/20130107214810_base_products.erp_products.rb +234 -0
  56. data/spec/dummy/db/migrate/20130107214811_base_products_indexes.erp_products.rb +59 -0
  57. data/spec/dummy/db/migrate/20130107214812_base_txns_and_accts.erp_txns_and_accts.rb +364 -0
  58. data/spec/dummy/db/migrate/20130107214813_agreements_services.erp_agreements.rb +160 -0
  59. data/spec/dummy/db/migrate/20130107214814_agreements_services_indexes.erp_agreements.rb +52 -0
  60. data/spec/dummy/db/migrate/20130107214815_base_app_framework.erp_app.rb +276 -0
  61. data/spec/dummy/db/migrate/20130107214816_erp_commerce_base.erp_commerce.rb +442 -0
  62. data/spec/dummy/db/schema.rb +1821 -0
  63. data/spec/dummy/db/spec.sqlite3 +0 -0
  64. data/spec/dummy/log/spec.log +12158 -0
  65. data/spec/spec_helper.rb +11 -3
  66. metadata +128 -14
  67. data/db/migrate/20110602194707_update_order_txn_ship_to_bill_to.rb +0 -25
@@ -0,0 +1,178 @@
1
+ # This migration comes from erp_orders (originally 20080805000060)
2
+ class BaseOrders < ActiveRecord::Migration
3
+ def self.up
4
+
5
+ unless table_exists?(:order_txns)
6
+ create_table :order_txns do |t|
7
+ t.column :state_machine, :string
8
+ t.column :description, :string
9
+ t.column :order_txn_type_id, :integer
10
+ # Multi-table inheritance info
11
+ # MTI implemented using Rails' polymorphic associations
12
+ # Contact Information
13
+ t.column :email, :string
14
+ t.column :phone_number, :string
15
+ # Shipping Address
16
+ t.column :ship_to_first_name, :string
17
+ t.column :ship_to_last_name, :string
18
+ t.column :ship_to_address_line_1, :string
19
+ t.column :ship_to_address_line_2, :string
20
+ t.column :bill_to_address_line_1, :string
21
+ t.column :bill_to_address_line_2, :string
22
+ t.column :ship_to_city, :string
23
+ t.column :ship_to_state, :string
24
+ t.column :ship_to_postal_code, :string
25
+ t.column :ship_to_country, :string
26
+ # Private parts
27
+ t.column :customer_ip, :string
28
+ t.column :order_number, :integer
29
+ t.column :status, :string
30
+ t.column :error_message, :string
31
+ t.column :order_txn_record_id, :integer
32
+ t.column :order_txn_record_type, :string
33
+ t.timestamps
34
+ end
35
+
36
+ add_index :order_txns, :order_txn_type_id
37
+ add_index :order_txns, [:order_txn_record_id, :order_txn_record_type], :name => 'order_txn_record_idx'
38
+ end
39
+
40
+ unless table_exists?(:order_txn_types)
41
+ create_table :order_txn_types do |t|
42
+ t.column :parent_id, :integer
43
+ t.column :lft, :integer
44
+ t.column :rgt, :integer
45
+ #custom columns go here
46
+ t.column :description, :string
47
+ t.column :comments, :string
48
+ t.column :internal_identifier, :string
49
+ t.column :external_identifier, :string
50
+ t.column :external_id_source, :string
51
+ t.timestamps
52
+ end
53
+
54
+ add_index :order_txn_types, :parent_id
55
+ end
56
+
57
+
58
+ unless table_exists?(:order_line_items)
59
+ create_table :order_line_items do |t|
60
+ t.column :order_txn_id, :integer
61
+ t.column :order_line_item_type_id, :integer
62
+ t.column :product_id, :integer
63
+ t.column :product_description, :string
64
+ t.column :product_instance_id, :integer
65
+ t.column :product_instance_description, :string
66
+ t.column :product_type_id, :integer
67
+ t.column :product_type_description, :string
68
+ t.column :sold_price, :decimal, :precision => 8, :scale => 2
69
+ t.column :sold_price_uom, :integer
70
+ t.column :sold_amount, :integer
71
+ t.column :sold_amount_uom, :integer
72
+ t.column :product_offer_id, :integer
73
+ t.timestamps
74
+ end
75
+
76
+ add_index :order_line_items, :order_txn_id
77
+ add_index :order_line_items, :order_line_item_type_id
78
+ add_index :order_line_items, :product_id
79
+ add_index :order_line_items, :product_instance_id
80
+ add_index :order_line_items, :product_type_id
81
+ add_index :order_line_items, :product_offer_id
82
+ end
83
+
84
+ unless table_exists?(:order_line_item_types)
85
+ create_table :order_line_item_types do |t|
86
+ t.column :parent_id, :integer
87
+ t.column :lft, :integer
88
+ t.column :rgt, :integer
89
+ #custom columns go here
90
+ t.column :description, :string
91
+ t.column :comments, :string
92
+ t.column :internal_identifier, :string
93
+ t.column :external_identifier, :string
94
+ t.column :external_id_source, :string
95
+ t.timestamps
96
+ end
97
+
98
+ add_index :order_line_item_types, :parent_id
99
+ end
100
+
101
+ unless table_exists?(:order_line_item_pty_roles)
102
+ create_table :order_line_item_pty_roles do |t|
103
+ t.column :description, :string
104
+ t.column :order_line_item_id, :integer
105
+ t.column :party_id, :integer
106
+ t.column :line_item_role_type_id, :integer
107
+ t.column :biz_txn_acct_root_id, :integer #optional for splitting orders across accounts
108
+ t.timestamps
109
+ end
110
+
111
+ add_index :order_line_item_pty_roles, :order_line_item_id
112
+ add_index :order_line_item_pty_roles, :party_id
113
+ add_index :order_line_item_pty_roles, :line_item_role_type_id
114
+ add_index :order_line_item_pty_roles, :biz_txn_acct_root_id
115
+ end
116
+
117
+ unless table_exists?(:line_item_role_types)
118
+ create_table :line_item_role_types do |t|
119
+ t.column :parent_id, :integer
120
+ t.column :lft, :integer
121
+ t.column :rgt, :integer
122
+ #custom columns go here
123
+ t.column :description, :string
124
+ t.column :comments, :string
125
+ t.column :internal_identifier, :string
126
+ t.column :external_identifier, :string
127
+ t.column :external_id_source, :string
128
+ t.timestamps
129
+ end
130
+
131
+ add_index :line_item_role_types, :parent_id
132
+ end
133
+
134
+ unless table_exists?(:charge_lines)
135
+ create_table :charge_lines do |t|
136
+ t.string :sti_type
137
+ t.references :money
138
+ t.string :description #could be expanded to include type information, etc.
139
+ t.string :external_identifier
140
+ t.string :external_id_source
141
+
142
+ #polymorphic
143
+ t.references :charged_item, :polymorphic => true
144
+
145
+ t.timestamps
146
+ end
147
+
148
+ add_index :charge_lines, [:charged_item_id, :charged_item_type], :name => 'charged_item_idx'
149
+ end
150
+
151
+ unless table_exists?(:charge_line_payment_txns)
152
+ create_table :charge_line_payment_txns do |t|
153
+ t.column :charge_line_id, :integer
154
+
155
+ #polymorphic
156
+ t.references :payment_txn, :polymorphic => true
157
+
158
+ t.timestamps
159
+ end
160
+
161
+ add_index :charge_line_payment_txns, [:payment_txn_id, :payment_txn_type], :name => 'payment_txn_idx'
162
+ add_index :charge_line_payment_txns, :charge_line_id
163
+ end
164
+ end
165
+
166
+ def self.down
167
+ [
168
+ :charge_lines, :charge_line_payment_txns, :line_item_role_types, :order_line_item_pty_roles,
169
+ :order_line_item_types, :order_line_items, :order_txn_types,
170
+ :order_txns
171
+ ].each do |tbl|
172
+ if table_exists?(tbl)
173
+ drop_table tbl
174
+ end
175
+ end
176
+ end
177
+
178
+ end
@@ -0,0 +1,271 @@
1
+ # This migration comes from erp_tech_svcs (originally 20080805000010)
2
+ class BaseTechServices < ActiveRecord::Migration
3
+ def self.up
4
+ unless table_exists?(:users)
5
+ # Create the users table
6
+ create_table :users do |t|
7
+ t.string :username
8
+ t.string :email
9
+ t.references :party
10
+ t.string :type
11
+ t.string :salt, :default => nil
12
+ t.string :crypted_password, :default => nil
13
+
14
+ #activity logging
15
+ t.datetime :last_login_at, :default => nil
16
+ t.datetime :last_logout_at, :default => nil
17
+ t.datetime :last_activity_at, :default => nil
18
+
19
+ #brute force protection
20
+ t.integer :failed_logins_count, :default => 0
21
+ t.datetime :lock_expires_at, :default => nil
22
+
23
+ #remember me
24
+ t.string :remember_me_token, :default => nil
25
+ t.datetime :remember_me_token_expires_at, :default => nil
26
+
27
+ #reset password
28
+ t.string :reset_password_token, :default => nil
29
+ t.datetime :reset_password_token_expires_at, :default => nil
30
+ t.datetime :reset_password_email_sent_at, :default => nil
31
+
32
+ #user activation
33
+ t.string :activation_state, :default => nil
34
+ t.string :activation_token, :default => nil
35
+ t.datetime :activation_token_expires_at, :default => nil
36
+
37
+ t.string :security_question_1
38
+ t.string :security_answer_1
39
+ t.string :security_question_2
40
+ t.string :security_answer_2
41
+
42
+ t.timestamps
43
+ end
44
+ add_index :users, :email, :unique => true
45
+ add_index :users, :username, :unique => true
46
+ add_index :users, [:last_logout_at, :last_activity_at], :name => 'activity_idx'
47
+ add_index :users, :remember_me_token
48
+ add_index :users, :reset_password_token
49
+ add_index :users, :activation_token
50
+
51
+ end
52
+
53
+ unless table_exists?(:groups)
54
+ create_table :groups do |t|
55
+ t.column :description, :string
56
+ t.timestamps
57
+ end
58
+ end
59
+
60
+ unless table_exists?(:security_roles)
61
+ # create the roles table
62
+ create_table :security_roles do |t|
63
+ t.column :description, :string
64
+ t.column :internal_identifier, :string
65
+ t.column :external_identifier, :string
66
+ t.column :external_id_source, :string
67
+
68
+ t.timestamps
69
+ end
70
+ end
71
+
72
+ unless table_exists?(:sessions)
73
+ # Create sessions table
74
+ create_table :sessions do |t|
75
+ t.string :session_id, :null => false
76
+ t.text :data
77
+ t.timestamps
78
+ end
79
+ add_index :sessions, :session_id
80
+ add_index :sessions, :updated_at
81
+ end
82
+
83
+ unless table_exists?(:audit_logs)
84
+ # Create audit_logs
85
+ create_table :audit_logs do |t|
86
+ t.string :application
87
+ t.string :description
88
+ t.integer :party_id
89
+ t.text :additional_info
90
+ t.references :audit_log_type
91
+
92
+ #polymorphic columns
93
+ t.references :event_record, :polymorphic => true
94
+
95
+ t.timestamps
96
+ end
97
+ add_index :audit_logs, :party_id
98
+ add_index :audit_logs, [:event_record_id, :event_record_type], :name => 'event_record_index'
99
+ end
100
+
101
+ unless table_exists?(:audit_log_types)
102
+ # Create audit_logs
103
+ create_table :audit_log_types do |t|
104
+ t.string :description
105
+ t.string :error_code
106
+ t.string :comments
107
+ t.string :internal_identifier
108
+ t.string :external_identifier
109
+ t.string :external_id_source
110
+
111
+ #better nested set columns
112
+ t.integer :parent_id
113
+ t.integer :lft
114
+ t.integer :rgt
115
+
116
+ t.timestamps
117
+ end
118
+ end
119
+
120
+ unless table_exists?(:audit_log_items)
121
+ # Create audit_log_items
122
+ create_table :audit_log_items do |t|
123
+ t.references :audit_log
124
+ t.references :audit_log_item_type
125
+ t.string :audit_log_item_value
126
+ t.string :description
127
+
128
+ t.timestamps
129
+ end
130
+ end
131
+
132
+ unless table_exists?(:audit_log_item_types)
133
+ # Create audit_log_item_types
134
+ create_table :audit_log_item_types do |t|
135
+ t.string :internal_identifier
136
+ t.string :external_identifier
137
+ t.string :external_id_source
138
+ t.string :description
139
+ t.string :comments
140
+
141
+ #better nested set columns
142
+ t.integer :parent_id
143
+ t.integer :lft
144
+ t.integer :rgt
145
+
146
+ t.timestamps
147
+ end
148
+ end
149
+
150
+ unless table_exists?(:file_assets)
151
+ create_table :file_assets do |t|
152
+ t.references :file_asset_holder, :polymorphic => true
153
+ t.string :type
154
+ t.string :name
155
+ t.string :directory
156
+ t.string :data_file_name
157
+ t.string :data_content_type
158
+ t.integer :data_file_size
159
+ t.datetime :data_updated_at
160
+ t.string :width
161
+ t.string :height
162
+
163
+ t.timestamps
164
+ end
165
+ add_index :file_assets, :type
166
+ add_index :file_assets, [:file_asset_holder_id, :file_asset_holder_type], :name => 'file_asset_holder_idx'
167
+ add_index :file_assets, :name
168
+ add_index :file_assets, :directory
169
+ end
170
+
171
+ unless table_exists?(:delayed_jobs)
172
+ create_table :delayed_jobs, :force => true do |table|
173
+ table.integer :priority, :default => 0 # Allows some jobs to jump to the front of the queue
174
+ table.integer :attempts, :default => 0 # Provides for retries, but still fail eventually.
175
+ table.text :handler # YAML-encoded string of the object that will do work
176
+ table.text :last_error # reason for last failure (See Note below)
177
+ table.datetime :run_at # When to run. Could be Time.zone.now for immediately, or sometime in the future.
178
+ table.datetime :locked_at # Set when a client is working on this object
179
+ table.datetime :failed_at # Set when all retries have failed (actually, by default, the record is deleted instead)
180
+ table.string :locked_by # Who is working on this object (if locked)
181
+ table.string :queue
182
+ table.timestamps
183
+ end
184
+ add_index :delayed_jobs, [:priority, :run_at], :name => 'delayed_jobs_priority'
185
+ end
186
+
187
+ unless table_exists?(:capable_models)
188
+ # create the roles table
189
+ create_table :capable_models do |t|
190
+ t.references :capable_model_record, :polymorphic => true
191
+
192
+ t.timestamps
193
+ end
194
+
195
+ add_index :capable_models, [:capable_model_record_id, :capable_model_record_type], :name => 'capable_model_record_idx'
196
+ end
197
+
198
+ unless table_exists?(:capability_types)
199
+ # create the roles table
200
+ create_table :capability_types do |t|
201
+ t.string :internal_identifier
202
+ t.string :description
203
+ t.timestamps
204
+ end
205
+ end
206
+
207
+ unless table_exists?(:capabilities)
208
+ # create the roles table
209
+ create_table :capabilities do |t|
210
+ t.string :description
211
+ t.references :capability_type
212
+ t.string :capability_resource_type
213
+ t.integer :capability_resource_id
214
+ t.integer :scope_type_id
215
+ t.text :scope_query
216
+ t.timestamps
217
+ end
218
+
219
+ add_index :capabilities, :capability_type_id
220
+ add_index :capabilities, :scope_type_id
221
+ add_index :capabilities, [:capability_resource_id, :capability_resource_type], :name => 'capability_resource_index'
222
+ end
223
+
224
+ unless table_exists?(:capability_accessors)
225
+ create_table :capability_accessors do |t|
226
+ t.string :capability_accessor_record_type
227
+ t.integer :capability_accessor_record_id
228
+ t.integer :capability_id
229
+ t.timestamps
230
+ end
231
+
232
+ add_index :capability_accessors, :capability_id
233
+ add_index :capability_accessors, [:capability_accessor_record_id, :capability_accessor_record_type], :name => 'capability_accessor_record_index'
234
+ end
235
+
236
+ unless table_exists?(:scope_types)
237
+ create_table :scope_types do |t|
238
+ t.string :description
239
+ t.string :internal_identifier
240
+ t.timestamps
241
+ end
242
+
243
+ add_index :scope_types, :internal_identifier
244
+ end
245
+
246
+ unless table_exists?(:parties_security_roles)
247
+ create_table :parties_security_roles, :id => false do |t|
248
+ t.integer :party_id
249
+ t.integer :security_role_id
250
+ end
251
+
252
+ add_index :parties_security_roles, :party_id
253
+ add_index :parties_security_roles, :security_role_id
254
+ end
255
+
256
+ end
257
+
258
+ def self.down
259
+ # check that each table exists before trying to delete it.
260
+ [ :groups,
261
+ :audit_logs, :sessions, :simple_captcha_data,
262
+ :capability_accessors, :capability_types, :capabilities,:scope_types,
263
+ :parties_security_roles, :roles, :audit_log_items, :audit_log_item_types,
264
+ :users, :file_assets, :delayed_jobs
265
+ ].each do |tbl|
266
+ if table_exists?(tbl)
267
+ drop_table tbl
268
+ end
269
+ end
270
+ end
271
+ end
@@ -0,0 +1,39 @@
1
+ # This migration comes from erp_tech_svcs (originally 20111117183144)
2
+ class CreateHasAttributeTables < ActiveRecord::Migration
3
+ def up
4
+ unless table_exists?(:attribute_types)
5
+ create_table :attribute_types do |t|
6
+ t.string :internal_identifier
7
+ t.string :description
8
+ t.string :data_type
9
+
10
+ t.timestamps
11
+ end
12
+
13
+ add_index :attribute_types, :internal_identifier, :name => ':attribute_types_iid_idx'
14
+ end
15
+ unless table_exists?(:attribute_values)
16
+ create_table :attribute_values do |t|
17
+ t.integer :attributed_record_id
18
+ t.string :attributed_record_type
19
+ t.references :attribute_type
20
+ t.string :value
21
+
22
+ t.timestamps
23
+ end
24
+
25
+ add_index :attribute_values, [:attributed_record_id, :attributed_record_type], :name => 'attribute_values_attributed_record_idx'
26
+ add_index :attribute_values, :attribute_type_id, :name => 'attribute_values_attributed_type_idx'
27
+ add_index :attribute_values, :value, :name => 'attribute_values_value_idx'
28
+ end
29
+ end
30
+
31
+ def down
32
+ if table_exists?(:attribute_types)
33
+ drop_table :attribute_types
34
+ end
35
+ if table_exists?(:attribute_values)
36
+ drop_table :attribute_values
37
+ end
38
+ end
39
+ end