spree_unified_payment 1.0.0 → 1.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/Gemfile +2 -1
- data/Rakefile +15 -0
- data/app/assets/javascripts/admin/spree_unified_payment.js +1 -1
- data/app/controllers/spree/unified_payments_controller.rb +2 -4
- data/app/overrides/add_unified_tabs_to_admin_menu.rb +1 -1
- data/app/overrides/add_user_view_link_for_transactions.rb +6 -0
- data/app/views/spree/admin/unified_payments/index.html.erb +3 -3
- data/app/views/spree/admin/unified_payments/query_gateway.js.erb +1 -1
- data/app/views/spree/shared/_unified_payments_link.html.erb +1 -0
- data/db/migrate/20131101092408_add_unified_payment_transactions.rb +25 -0
- data/spec/controllers/spree/unified_payments_controller_spec.rb +10 -11
- data/spec/models/unified_payment/transaction_decorator_spec.rb +2 -2
- data/spec/spec_helper.rb +6 -1
- data/spree_unified_payment.gemspec +2 -2
- metadata +11 -7
data/Gemfile
CHANGED
@@ -1,13 +1,14 @@
|
|
1
1
|
source "https://rubygems.org"
|
2
2
|
gem 'rails', '3.2.16'
|
3
3
|
gem 'mysql2'
|
4
|
+
gem 'sqlite3'
|
4
5
|
|
5
6
|
|
6
7
|
gem 'spree', :git => 'git://github.com/spree/spree.git', :tag => 'v2.0.3'
|
7
8
|
gem 'spree_wallet', :git => 'git://github.com/vinsol/spree_wallet.git'
|
8
9
|
gem 'spree_auth_devise', github: 'spree/spree_auth_devise', branch: '2-0-stable'
|
9
10
|
|
10
|
-
gem 'unified_payment', :
|
11
|
+
gem 'unified_payment', :tag => 'v1.0.1'
|
11
12
|
gem 'delayed_job_active_record', :tag => 'v4.0.0'
|
12
13
|
|
13
14
|
group :test do
|
data/Rakefile
ADDED
@@ -0,0 +1,15 @@
|
|
1
|
+
require 'bundler'
|
2
|
+
Bundler::GemHelper.install_tasks
|
3
|
+
|
4
|
+
require 'rspec/core/rake_task'
|
5
|
+
require 'spree/testing_support/extension_rake'
|
6
|
+
|
7
|
+
RSpec::Core::RakeTask.new
|
8
|
+
|
9
|
+
task :default => [:spec]
|
10
|
+
|
11
|
+
desc 'Generates a dummy app for testing'
|
12
|
+
task :test_app do
|
13
|
+
ENV['LIB_NAME'] = 'spree_unified_payment'
|
14
|
+
Rake::Task['extension:test_app'].invoke
|
15
|
+
end
|
@@ -30,7 +30,7 @@ $(document).ready(function() {
|
|
30
30
|
return self;
|
31
31
|
}
|
32
32
|
|
33
|
-
$('
|
33
|
+
$('.reveal_xml').click(function() {
|
34
34
|
ct_id = $(this).attr('data-ct-id');
|
35
35
|
var quick_view = new ModalPopUp($("<div></div>").attr('id', 'quick_view_popup').html($("#xml_response_" + ct_id).clone()));
|
36
36
|
$('#quick_view_popup .xml_response').removeClass('hidden');
|
@@ -49,7 +49,7 @@ module Spree
|
|
49
49
|
|
50
50
|
@payment_made = @gateway_message_hash['PurchaseAmountScr'].to_f
|
51
51
|
if @card_transaction.approved_at_gateway?
|
52
|
-
if @card_transaction.amount != @payment_made
|
52
|
+
if @card_transaction.amount.to_f != @payment_made
|
53
53
|
process_unsuccessful_transaction
|
54
54
|
else
|
55
55
|
process_successful_transaction
|
@@ -129,9 +129,7 @@ module Spree
|
|
129
129
|
|
130
130
|
def tasks_on_gateway_create_response(response, transaction_id)
|
131
131
|
response_order = response['Order']
|
132
|
-
|
133
|
-
#[TODO_CR] Make required attributes protected and save them with without protection in the place where protection is not necessary.
|
134
|
-
#[MK] Please look into this change. Could not find a good way to implement it without much hastle.
|
132
|
+
|
135
133
|
gateway_transaction = UnifiedPayment::Transaction.where(:gateway_session_id => response_order['SessionID'], :gateway_order_id => response_order['OrderID'], :url => response_order['URL']).first
|
136
134
|
gateway_transaction.assign_attributes({:user_id => @order.user.try(:id), :payment_transaction_id => transaction_id, :order_id => @order.id, :gateway_order_status => 'CREATED', :amount => @order.total, :currency => Spree::Config[:currency], :response_status => response["Status"], :status => 'pending'}, :without_protection => true)
|
137
135
|
gateway_transaction.save!
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Deface::Override.new(:virtual_path => "spree/layouts/admin",
|
2
2
|
:name => "Add Unified tab to menu",
|
3
3
|
:insert_bottom => "[data-hook='admin_tabs'], #admin_tabs[data-hook]",
|
4
|
-
:text => " <%= tab( :
|
4
|
+
:text => " <%= tab( :UnifiedPayments , :url => admin_unified_payments_path) %>",
|
5
5
|
:sequence => {:after => "promo_admin_tabs"},
|
6
6
|
:disabled => false)
|
@@ -0,0 +1,6 @@
|
|
1
|
+
Deface::Override.new(:virtual_path => "spree/shared/_nav_bar",
|
2
|
+
:name => "User link to view UnifiedPayment Transactions",
|
3
|
+
:insert_before => "li#search-bar",
|
4
|
+
:partial => "spree/shared/unified_payments_link",
|
5
|
+
:disabled => false,
|
6
|
+
:original => 'eb3fa668cd98b6a1c75c36420ef1b238a1fc55ac')
|
@@ -2,7 +2,7 @@
|
|
2
2
|
|
3
3
|
<% content_for :table_filter do %>
|
4
4
|
<div data-hook="admin_orders_index_search">
|
5
|
-
<%= form_for [:admin, @search], :url =>
|
5
|
+
<%= form_for [:admin, @search], :url => admin_unified_payments_path, :method => :get do |f| %>
|
6
6
|
<div class="field-block alpha four columns">
|
7
7
|
<div class="date-range-filter field">
|
8
8
|
<%= label_tag nil, Spree.t(:date_range) %>
|
@@ -79,10 +79,10 @@
|
|
79
79
|
<td><%= card_transaction.created_at.strftime("%d %b %Y, %I:%M%p") %></td>
|
80
80
|
<td class="action">
|
81
81
|
<% unless card_transaction.status == 'pending' %>
|
82
|
-
<a href="javascript:void(0)"
|
82
|
+
<a href="javascript:void(0)" class="reveal_xml" data-ct-id=<%= card_transaction.id%>>View XML</a>
|
83
83
|
<div class="hidden xml_response" id="xml_response_<%= card_transaction.id %>"><%= card_transaction.xml_response %></div>
|
84
84
|
<% unless card_transaction.store_credit.present? %>
|
85
|
-
|<%= link_to "Receipt",
|
85
|
+
|<%= link_to "Receipt", admin_unified_payments_receipt_path(:transaction_id => card_transaction.payment_transaction_id) %>
|
86
86
|
<% end %>
|
87
87
|
<% else %>
|
88
88
|
<%= link_to("QueryAndWallet", admin_unified_payments_query_gateway_path(:transaction_id => card_transaction.payment_transaction_id), :remote => true, confirm: "#{card_transaction.amount} will be walleted to #{card_transaction.user.try(:email) }. Are You Sure?", :method => 'post', :class => 'wallet_link') unless card_transaction.store_credit.present? %>
|
@@ -6,5 +6,5 @@
|
|
6
6
|
$('#<%= @card_transaction.payment_transaction_id %> .gateway_order_status').text('<%= @card_transaction.gateway_order_status %>')
|
7
7
|
<% else %>
|
8
8
|
alert('Could not wallet the money. Got order status <%= @card_transaction.gateway_order_status %>');
|
9
|
-
$('#<%= @card_transaction.payment_transaction_id %> .gateway_order_status').text('<%=
|
9
|
+
$('#<%= @card_transaction.payment_transaction_id %> .gateway_order_status').text('<%= @card_transaction.gateway_order_status %>')
|
10
10
|
<% end %>
|
@@ -0,0 +1 @@
|
|
1
|
+
<li><%= link_to 'UnifiedPayment Transactions', unified_payments_path %></li>
|
@@ -0,0 +1,25 @@
|
|
1
|
+
class AddUnifiedPaymentTransactions < ActiveRecord::Migration
|
2
|
+
def change
|
3
|
+
unless UnifiedPayment::Transaction.table_exists?
|
4
|
+
create_table :unified_payment_transactions do |t|
|
5
|
+
t.integer :gateway_order_id
|
6
|
+
t.string :gateway_order_status
|
7
|
+
t.string :amount
|
8
|
+
t.string :gateway_session_id
|
9
|
+
t.string :url
|
10
|
+
t.string :merchant_id
|
11
|
+
t.string :currency
|
12
|
+
t.string :order_description
|
13
|
+
t.string :response_status
|
14
|
+
t.string :response_description
|
15
|
+
t.string :pan
|
16
|
+
t.string :approval_code
|
17
|
+
t.text :xml_response
|
18
|
+
t.timestamps
|
19
|
+
end
|
20
|
+
|
21
|
+
add_index :unified_payment_transactions, [:gateway_order_id, :gateway_session_id], name: :order_session_index
|
22
|
+
add_index :unified_payment_transactions, :response_status
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
@@ -9,7 +9,6 @@ describe Spree::UnifiedPaymentsController do
|
|
9
9
|
before(:each) do
|
10
10
|
user.stub(:generate_spree_api_key!).and_return(true)
|
11
11
|
user.stub(:last_incomplete_spree_order).and_return(order)
|
12
|
-
Spree::Config[:site_name] = "MyTestSite"
|
13
12
|
controller.stub(:spree_current_user).and_return(user)
|
14
13
|
controller.stub(:current_order).and_return(order)
|
15
14
|
end
|
@@ -142,8 +141,8 @@ describe Spree::UnifiedPaymentsController do
|
|
142
141
|
before do
|
143
142
|
session[:transaction_id] = '12345678910121'
|
144
143
|
@gateway_response = Object.new
|
145
|
-
UnifiedPayment::Transaction.stub(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from
|
146
|
-
UnifiedPayment::Transaction.stub(:extract_url_for_unified_payment).with(@gateway_response).and_return(
|
144
|
+
UnifiedPayment::Transaction.stub(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from #{Spree::Config[:site_name]}"}).and_return(@gateway_response)
|
145
|
+
UnifiedPayment::Transaction.stub(:extract_url_for_unified_payment).with(@gateway_response).and_return("www.#{Spree::Config[:site_name]}.com")
|
147
146
|
controller.stub(:tasks_on_gateway_create_response).with(@gateway_response, '12345678910121').and_return(true)
|
148
147
|
end
|
149
148
|
|
@@ -175,8 +174,8 @@ describe Spree::UnifiedPaymentsController do
|
|
175
174
|
context 'when an order is successfully created at gateway' do
|
176
175
|
|
177
176
|
describe 'method calls' do
|
178
|
-
it { UnifiedPayment::Transaction.should_receive(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from
|
179
|
-
it { UnifiedPayment::Transaction.should_receive(:extract_url_for_unified_payment).with(@gateway_response).and_return(
|
177
|
+
it { UnifiedPayment::Transaction.should_receive(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from #{Spree::Config[:site_name]}"}).and_return(@gateway_response) }
|
178
|
+
it { UnifiedPayment::Transaction.should_receive(:extract_url_for_unified_payment).with(@gateway_response).and_return("www.#{Spree::Config[:site_name]}.com") }
|
180
179
|
it { controller.should_receive(:tasks_on_gateway_create_response).with(@gateway_response, '12345678910121').and_return(true) }
|
181
180
|
|
182
181
|
after { send_request }
|
@@ -185,17 +184,17 @@ describe Spree::UnifiedPaymentsController do
|
|
185
184
|
describe 'assigns' do
|
186
185
|
it 'payment_url' do
|
187
186
|
send_request
|
188
|
-
assigns(:payment_url).should eq("www.
|
187
|
+
assigns(:payment_url).should eq("www.#{Spree::Config[:site_name]}.com")
|
189
188
|
end
|
190
189
|
end
|
191
190
|
end
|
192
191
|
|
193
192
|
context 'when order not created at gateway' do
|
194
193
|
|
195
|
-
before { UnifiedPayment::Transaction.stub(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from
|
194
|
+
before { UnifiedPayment::Transaction.stub(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from #{Spree::Config[:site_name]}"}).and_return(false) }
|
196
195
|
|
197
196
|
describe 'method calls' do
|
198
|
-
it { UnifiedPayment::Transaction.should_receive(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from
|
197
|
+
it { UnifiedPayment::Transaction.should_receive(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from #{Spree::Config[:site_name]}"}).and_return(false) }
|
199
198
|
it { UnifiedPayment::Transaction.should_not_receive(:extract_url_for_unified_payment) }
|
200
199
|
it { controller.should_not_receive(:tasks_on_gateway_create_response) }
|
201
200
|
|
@@ -219,7 +218,7 @@ describe Spree::UnifiedPaymentsController do
|
|
219
218
|
before { send_request }
|
220
219
|
|
221
220
|
it { flash[:error].should be_nil }
|
222
|
-
it { response.body.should eq("$('#confirm_payment').hide();top.location.href = 'www.
|
221
|
+
it { response.body.should eq("$('#confirm_payment').hide();top.location.href = 'www.#{Spree::Config[:site_name]}.com'") }
|
223
222
|
end
|
224
223
|
end
|
225
224
|
end
|
@@ -236,8 +235,8 @@ describe Spree::UnifiedPaymentsController do
|
|
236
235
|
order.stub(:next).and_return(true)
|
237
236
|
@gateway_response = {'Status' => 'status', 'Order' => { 'SessionID' => '12312', 'OrderID' => '123121', 'URL' => 'MyResponse'}}
|
238
237
|
@transaction = UnifiedPayment::Transaction.new
|
239
|
-
UnifiedPayment::Transaction.stub(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from
|
240
|
-
UnifiedPayment::Transaction.stub(:extract_url_for_unified_payment).with(@gateway_response).and_return(
|
238
|
+
UnifiedPayment::Transaction.stub(:create_order_at_unified).with(order.total, {:approve_url=>"http://test.host/unified_payments/approved", :cancel_url=>"http://test.host/unified_payments/canceled", :decline_url=>"http://test.host/unified_payments/declined", :description=>"Purchasing items from #{Spree::Config[:site_name]}"}).and_return(@gateway_response)
|
239
|
+
UnifiedPayment::Transaction.stub(:extract_url_for_unified_payment).with(@gateway_response).and_return("www.#{Spree::Config[:site_name]}.com")
|
241
240
|
UnifiedPayment::Transaction.stub(:where).with(:gateway_session_id => '12312', :gateway_order_id => '123121', :url => 'MyResponse').and_return([@transaction])
|
242
241
|
@transaction.stub(:save!).and_return(true)
|
243
242
|
end
|
@@ -320,8 +320,8 @@ describe UnifiedPayment::Transaction do
|
|
320
320
|
|
321
321
|
describe 'abort!' do
|
322
322
|
before do
|
323
|
-
@time_now =
|
324
|
-
Time.stub(:
|
323
|
+
@time_now = DateTime.strptime('2012-03-03', '%Y-%m-%d')
|
324
|
+
Time.stub(:current).and_return(@time_now)
|
325
325
|
@card_transaction = UnifiedPayment::Transaction.new(:status => 'somestatus', :payment_transaction_id => '1234')
|
326
326
|
@card_transaction.stub(:release_order_inventory).and_return(true)
|
327
327
|
end
|
data/spec/spec_helper.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
# This file is copied to spec/ when you run 'rails generate rspec:install'
|
2
2
|
ENV["RAILS_ENV"] ||= 'test'
|
3
|
-
require File.expand_path("
|
3
|
+
require File.expand_path("../dummy/config/environment", __FILE__)
|
4
4
|
require 'rspec/rails'
|
5
5
|
# require 'rspec/autorun'
|
6
6
|
|
@@ -17,6 +17,11 @@ require 'database_cleaner'
|
|
17
17
|
# If you are not using ActiveRecord, you can remove this line.
|
18
18
|
# ActiveRecord::Migration.check_pending! if defined?(ActiveRecord::Migration)
|
19
19
|
|
20
|
+
#Allow attr_access for test environment
|
21
|
+
UnifiedPayment::Transaction.class_eval do
|
22
|
+
attr_accessible :payment_transaction_id
|
23
|
+
end
|
24
|
+
|
20
25
|
RSpec.configure do |config|
|
21
26
|
# ## Mock Framework
|
22
27
|
#
|
@@ -1,7 +1,7 @@
|
|
1
1
|
Gem::Specification.new do |s|
|
2
2
|
s.platform = Gem::Platform::RUBY
|
3
3
|
s.name = "spree_unified_payment"
|
4
|
-
s.version = "1.0.
|
4
|
+
s.version = "1.0.1"
|
5
5
|
s.author = ["Manish Kangia", "Sushant Mittal"]
|
6
6
|
s.email = 'info@vinsol.com'
|
7
7
|
s.homepage = 'http://vinsol.com'
|
@@ -17,7 +17,7 @@ Gem::Specification.new do |s|
|
|
17
17
|
s.requirements << 'none'
|
18
18
|
|
19
19
|
s.add_dependency('spree_core', '~> 2.0.0')
|
20
|
-
s.add_dependency 'unified_payment', '1.0.
|
20
|
+
s.add_dependency 'unified_payment', '1.0.1'
|
21
21
|
s.add_dependency 'spree_wallet', '~> 2.0.3'
|
22
22
|
s.add_dependency 'delayed_job_active_record', '~> 4.0.0'
|
23
23
|
end
|
metadata
CHANGED
@@ -1,13 +1,13 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: spree_unified_payment
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
hash:
|
4
|
+
hash: 21
|
5
5
|
prerelease:
|
6
6
|
segments:
|
7
7
|
- 1
|
8
8
|
- 0
|
9
|
-
-
|
10
|
-
version: 1.0.
|
9
|
+
- 1
|
10
|
+
version: 1.0.1
|
11
11
|
platform: ruby
|
12
12
|
authors:
|
13
13
|
- Manish Kangia
|
@@ -16,7 +16,7 @@ autorequire:
|
|
16
16
|
bindir: bin
|
17
17
|
cert_chain: []
|
18
18
|
|
19
|
-
date: 2014-
|
19
|
+
date: 2014-03-04 00:00:00 Z
|
20
20
|
dependencies:
|
21
21
|
- !ruby/object:Gem::Dependency
|
22
22
|
name: spree_core
|
@@ -42,12 +42,12 @@ dependencies:
|
|
42
42
|
requirements:
|
43
43
|
- - "="
|
44
44
|
- !ruby/object:Gem::Version
|
45
|
-
hash:
|
45
|
+
hash: 21
|
46
46
|
segments:
|
47
47
|
- 1
|
48
48
|
- 0
|
49
|
-
-
|
50
|
-
version: 1.0.
|
49
|
+
- 1
|
50
|
+
version: 1.0.1
|
51
51
|
type: :runtime
|
52
52
|
version_requirements: *id002
|
53
53
|
- !ruby/object:Gem::Dependency
|
@@ -96,6 +96,7 @@ files:
|
|
96
96
|
- Gemfile
|
97
97
|
- LICENSE
|
98
98
|
- README.md
|
99
|
+
- Rakefile
|
99
100
|
- Versionfile
|
100
101
|
- app/assets/javascripts/admin/spree_unified_payment.js
|
101
102
|
- app/assets/stylesheets/store/spree_unified_payment.css
|
@@ -112,10 +113,12 @@ files:
|
|
112
113
|
- app/models/spree/user_decorator.rb
|
113
114
|
- app/models/unified_payment/transaction_decorator.rb
|
114
115
|
- app/overrides/add_unified_tabs_to_admin_menu.rb
|
116
|
+
- app/overrides/add_user_view_link_for_transactions.rb
|
115
117
|
- app/views/spree/admin/unified_payments/index.html.erb
|
116
118
|
- app/views/spree/admin/unified_payments/query_gateway.js.erb
|
117
119
|
- app/views/spree/admin/unified_payments/receipt.html.erb
|
118
120
|
- app/views/spree/checkout/payment/_unifiedpaymentmethod.html.erb
|
121
|
+
- app/views/spree/shared/_unified_payments_link.html.erb
|
119
122
|
- app/views/spree/transaction_notification_mailer/send_mail.html.erb
|
120
123
|
- app/views/spree/unified_payments/approved.html.erb
|
121
124
|
- app/views/spree/unified_payments/canceled.html.erb
|
@@ -127,6 +130,7 @@ files:
|
|
127
130
|
- app/views/spree/unified_payments/new.js.erb
|
128
131
|
- config/initializers/constants.rb
|
129
132
|
- config/routes.rb
|
133
|
+
- db/migrate/20131101092408_add_unified_payment_transactions.rb
|
130
134
|
- db/migrate/20140120075553_add_transaction_fields_to_unified_payment_transactions.rb
|
131
135
|
- db/migrate/20140120081453_add_unified_transaction_id_to_spree_store_credits.rb
|
132
136
|
- lib/generators/spree_unified_payment/install/install_generator.rb
|