From 7f70738eb628003d5e645e7f0849cf37f2854e57 Mon Sep 17 00:00:00 2001
From: Immanuel Onyeka <immanuel@onyeka.ca>
Date: Sat, 19 Jun 2021 18:13:40 -0400
Subject: [PATCH] Change payment section from stripe to payeer

---
 app/Http/Controllers/BillingController.php    |  51 +++---
 .../2014_10_12_000000_create_users_table.php  |   2 +-
 ...06_08_224029_create_transactions_table.php |   1 -
 database/seeders/DatabaseSeeder.php           |   8 +-
 resources/images/payeer.png                   | Bin 0 -> 3610 bytes
 resources/images/perfect_money.svg            |  88 +++++++++++
 resources/js/panel/credits.vue                | 147 +++++++++---------
 resources/js/panel/settings.vue               |   7 +-
 resources/scss/main.scss                      |  35 ++++-
 resources/views/home.blade.php                |   3 +-
 resources/views/master.blade.php              |   1 -
 routes/web.php                                |   3 +-
 12 files changed, 237 insertions(+), 109 deletions(-)
 create mode 100644 resources/images/payeer.png
 create mode 100644 resources/images/perfect_money.svg

diff --git a/app/Http/Controllers/BillingController.php b/app/Http/Controllers/BillingController.php
index 56c2c55..2b5f1ef 100644
--- a/app/Http/Controllers/BillingController.php
+++ b/app/Http/Controllers/BillingController.php
@@ -23,21 +23,28 @@ class BillingController extends Controller
 		$this->user = Auth::user();
 	}
 
-	protected function attempt(Request $request) {
+	protected function attempt($packs) {
 		$user = Auth::user();
-		$amount = $request->packs[ 'credits10' ]*1099 +
-			$request->packs[ 'credits50' ]*5499 + $request->packs[ 'credits100' ]*10999
-			+ $request->packs[ 'credits1000' ]*101000;
+
+		foreach($packs as $value) {
+			if ($value < 0) {
+				abort(422);
+			}
+		}
+
+		$amount = $packs[ 'credits10' ]*1099 +
+			$packs[ 'credits50' ]*5499 + $packs[ 'credits100' ]*10999
+			+ $packs[ 'credits1000' ]*101000;
 
 		$transaction = new Transaction;
-		$transaction->credits = $request->packs['credits10']*1000 +
-			$request->packs['credits50']*5000 +
-			$request->packs['credits100']*10000 +
-			$request->packs['credits1000']*100000;
+		$transaction->credits = $packs['credits10']*1000 +
+			$packs['credits50']*5000 +
+			$packs['credits100']*10000 +
+			$packs['credits1000']*100000;
 		$transaction->credits_extra =
-			$request->packs['credits50']*500 +
-			$request->packs['credits100']*1000 +
-			$request->packs['credits1000']*15000;
+			$packs['credits50']*500 +
+			$packs['credits100']*1000 +
+			$packs['credits1000']*15000;
 
 		$transaction->user_id = $user->id;
 		$transaction->charge = $amount;
@@ -51,7 +58,7 @@ class BillingController extends Controller
 	//Should validate that all amounts are positive integers in a reasonable range
 	public function stripeSecret(Request $request) {
 		$user = Auth::user();
-		$transaction = $this->attempt($request);
+		$transaction = $this->attempt($request->packs);
 
 		$intent = PaymentIntent::create([
 			'amount' => $amount,
@@ -125,25 +132,33 @@ class BillingController extends Controller
 	//Receives a request with a packs. It is an array of each type of credit
 	//amount to be bought
 	public function payeer(Request $request) {
-		$transaction = $this->attempt($request);
+		$user = Auth::user();
+		$transaction = $this->attempt($request->packs);
 		$shopid = config('services.payeer.id');
 		$secret = config('services.payeer.secret');
 		$param_key = config('services.payeer.param_key');
-		$total = $transaction->credits + $transaction->credits_extra;
+		$total = $transaction->credits/100 + $transaction->credits_extra/100;
+		$description =  base64_encode("You will receive $total credits.");
 
-		$arHash = [$shopid, $transaction->id, $transaction->charge, 'USD', "You
-			will receive $total credits."];
+		$arHash = [$shopid, $transaction->id, $transaction->charge/100, 'USD',
+			$description];
 
 		$params = ['reference' => ['transaction_id' => $transaction->id]];
 		$key = md5($param_key.$transaction->id);
-		$encodedParams = urlencode(base64_encode(openssl_encrypt(
+		$encodedParams = @urlencode(base64_encode(openssl_encrypt(
 			json_encode($params), 'AES-256-CBC', $key, OPENSSL_RAW_DATA
 		)));
 		$arHash[] = $encodedParams;
 		$arHash[] = $secret;
 
 		$signature = strtoupper(hash('sha256', implode(':', $arHash)));
+		$user->paying = true; $user->save();
+
 		return [ 'signature' => $signature, 'params' => $encodedParams, 'shop'
-			=> $shopid, 'transaction' => $transaction->id ];
+			=> $shopid, 'transaction' => $transaction->id, 'amount' =>
+			$transaction->charge/100, 'description' => $description ];
+	}
+
+	public function processPayeer(Request $request) {
 	}
 }
diff --git a/database/migrations/2014_10_12_000000_create_users_table.php b/database/migrations/2014_10_12_000000_create_users_table.php
index 1dac20a..702dc14 100644
--- a/database/migrations/2014_10_12_000000_create_users_table.php
+++ b/database/migrations/2014_10_12_000000_create_users_table.php
@@ -17,7 +17,7 @@ class CreateUsersTable extends Migration
             $table->id();
             $table->string('name');
             $table->string('email')->unique();
-            $table->string('customer_id')->unique();
+            $table->string('customer_id')->unique()->nullable();
             $table->timestamp('email_verified_at')->nullable();
             $table->string('password');
             $table->enum('role', ['client', 'guest', 'admin']);
diff --git a/database/migrations/2021_06_08_224029_create_transactions_table.php b/database/migrations/2021_06_08_224029_create_transactions_table.php
index 1240a26..647e4d4 100644
--- a/database/migrations/2021_06_08_224029_create_transactions_table.php
+++ b/database/migrations/2021_06_08_224029_create_transactions_table.php
@@ -20,7 +20,6 @@ class CreateTransactionsTable extends Migration
 			$table->integer('credits')->unsigned();
 			$table->integer('credits_extra')->unsigned()->default(0);
             $table->string('status');
-            $table->string('intent_id')->unique();
             $table->boolean('completed');
             $table->string('note')->nullable();
             $table->timestamps();
diff --git a/database/seeders/DatabaseSeeder.php b/database/seeders/DatabaseSeeder.php
index fb04301..5bac2c7 100644
--- a/database/seeders/DatabaseSeeder.php
+++ b/database/seeders/DatabaseSeeder.php
@@ -20,11 +20,12 @@ class DatabaseSeeder extends Seeder
     public function run()
     {
 		Stripe::setApiKey(config('services.stripe.secret'));
+
 		 User::create([
 			'name' => 'test_user_unverified',
 			'email' => 'unverified@example.com',
 			'role' => 'client',
-			'customer_id' => Customer::create(['email' => 'unverified@example.com'])->id,
+			'credits' => 55000,
 			'active' => true,
 			'password' => Hash::make("test123")
 		]);
@@ -32,8 +33,7 @@ class DatabaseSeeder extends Seeder
 			'name' => 'test_user_verified',
 			'email' => 'verified@example.com',
 			'email_verified_at' => now(),
-			'credits' => 250,
-			'customer_id' => Customer::create(['email' => 'verified@example.com'])->id,
+			'credits' => 25000,
 			'role' => 'client',
 			'active' => true,
 			'password' => Hash::make("test123")
@@ -42,8 +42,8 @@ class DatabaseSeeder extends Seeder
 			'name' => 'test_admin_verified',
 			'email' => 'admin_verified@example.com',
 			'email_verified_at' => now(),
-			'customer_id' => Customer::create(['email' => 'admin_verified@example.com'])->id,
 			'role' => 'admin',
+			'credits' => 55000,
 			'active' => true,
 			'password' => Hash::make("test123")
 		]);
diff --git a/resources/images/payeer.png b/resources/images/payeer.png
new file mode 100644
index 0000000000000000000000000000000000000000..257c0170264dec4231428f8e0346e2328472532e
GIT binary patch
literal 3610
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
A+5i9m

literal 0
HcmV?d00001

diff --git a/resources/images/perfect_money.svg b/resources/images/perfect_money.svg
new file mode 100644
index 0000000..9630019
--- /dev/null
+++ b/resources/images/perfect_money.svg
@@ -0,0 +1,88 @@
+<?xml version="1.0" encoding="UTF-8" standalone="no"?>
+<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
+<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="230px" height="60px" viewBox="0 0 230 60" enable-background="new 0 0 230 60" xml:space="preserve">  <image id="image0" width="230" height="60" x="0" y="0"
+    xlink:href="
+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
+AElFTkSuQmCC" />
+</svg>
diff --git a/resources/js/panel/credits.vue b/resources/js/panel/credits.vue
index 00ef39b..ac4a3e7 100644
--- a/resources/js/panel/credits.vue
+++ b/resources/js/panel/credits.vue
@@ -23,25 +23,26 @@
 	<h4>Select a payment method</h4>
 
 	<div class="sliding-menu">
-	<a @click="selectSaved = true" :class="{selected: selectSaved}">Saved Card</a>
-	<a @click="selectSaved = false" :class="{selected: !selectSaved}">New Card</a>
-	<div :class="{right: !selectSaved}" class="menu-slider"><div></div></div>
+	<a @click="method = 'payeer'" :class="{selected: method == 'payeer'}">Payeer</a>
+	<a @click="method = 'pm'" :class="{selected: method == 'pm'}">Perfect Money</a>
+	<div :class="{right: (method == 'pm')}" class="menu-slider"><div></div></div>
 	</div>
 
-	<saved-cards :preferred="preferred" v-model:picked-card="picked" :cards="cards"
-	:token="token" v-if="selectSaved"></saved-cards>
-
-	<payment-card @set-card="(c) => {card = c}" @card-valid="(val) => {cardValid = val}"
-	@update-billing-name="billingName = $event.target.value" :stripe="stripe"
-	v-if="!selectSaved">
-	</payment-card>
-	<div>
-	<input type="checkbox"><label>I have read and agree to the<a
-	href="/terms-and-policy">Terms and Policy</a></label>
-	<div class="info-grey">
-		<span>A chargeback will result in a ban. Contact <a
-		href="#contact">support</a>if you have any problems of concerns.</span>
+	<div v-if="method == 'payeer'" class="payment-window">
+	<img src="../../images/payeer.png" alt="">
+	<p>Payeer allows you to pay securely by transfering your choice of cryptocurrency
+	to a temporary address.
+	</p>
 	</div>
+
+	<div v-if="method == 'pm'" class="payment-window">
+	<img src="../../images/perfect_money.svg" alt="">
+	<p>Pay by transfering USD from your Perfect Money wallet.</p>
+	</div>
+
+	<div id="agreement-check">
+	<input v-model="agreed" type="checkbox"><label>I have read and agree to the <a
+	href="/terms-and-policy">Terms and Policy</a> and will not pursue a fraudulent dispute or chargeback.</label>
 	<div id="payment-error"></div>
 	</div>
 </section>
@@ -51,14 +52,10 @@
 	class="brand-btn">Buy<loading v-if="loading"></loading></button>
 </section>
 
-<PurchaseCompleted v-if="complete"></PurchaseCompleted>
 </template>
 
 <script>
 import Loading from '../icons/loading.vue'
-import PaymentCard from './payment-card.vue'
-import SavedCards from './saved-cards.vue'
-import PurchaseCompleted from './purchase-completed.vue'
 
 function total() {
 	return this.packs.credits10*10.99 + this.packs.credits50*54.99
@@ -88,78 +85,78 @@ function getSecret() {
 	})
 }
 
-//Gets key from the server then sends it with stripe
-//Maybe it should asl attach the user's receipt email
 function pay() {
-	this.getSecret().then(secret => {
-		if (!secret) {return}
-		this.loading = true
-		if (!this.selectSaved) {
-			return this.stripe.confirmCardPayment(secret, {
-				payment_method: {
-					card: this.card,
-					billing_details: {name:
-					document.getElementById('billing-name').value},
-				},
-				setup_future_usage: document.querySelector(
-				"#save-card input").value == 'on' ? 'off_session' : null
-			})
-		} else {
-			return this.stripe.confirmCardPayment(secret, {
-				payment_method: this.picked
-			})
-		}
-	}).then(result => {
-		if (result.error) {
-			document.getElementById('payment-error').textContent =
-			result.error.message
-		} else if (result.paymentIntent.status === 'succeeded') {
-			setTimeout(() => {this.$emit('purchaseComplete')}, 4000)
-			setTimeout(() => {this.$emit('purchaseComplete')}, 10000)
-			this.complete = true
-		} else {
-			document.getElementById('payment-error').textContent =
-			'An unknown error occured'
-		}
-		this.loading = false
-	})
+	if (this.method == 'payeer') {
+		this.payPayeer();
+	} else if (this.method == 'pm') {
+		this.payPm();
+	}
+}
+
+function makeInput(name, value) {
+	let input = document.createElement('input')
+	input.type = 'hidden'
+	input.name = name
+	input.value = value
+	return input
 }
 
-function getCards() {
-	fetch('/panel/cards', {
-		method: 'GET',
+function payPayeer() {
+	fetch('/panel/payeer', {
+		method: 'POST',
 		headers: {'Content-Type': 'application/json',
 			'Accept': 'application/json',
-		'X-XSRF-TOKEN': this.token}
-	}).then((response) => {response.json().then(data => {
-		this.cards = data.data
-		if (this.cards && this.cards.length > 0) {
-			this.picked = this.cards[0].id
-		}
-	})})
+		'X-XSRF-TOKEN': this.token},
+		body: JSON.stringify({'packs': this.packs})
+		}).then(response => {return response.json()}).then(data => {
+			let form = document.createElement('form')
+			document.body.appendChild(form)
+			form.method = 'post'
+			form.action = 'https://payeer.com/merchant/'
+			form.appendChild(this.makeInput('m_shop', data.shop))
+			form.appendChild(this.makeInput('m_orderid', data.transaction))
+			form.appendChild(this.makeInput('m_amount', data.amount))
+			form.appendChild(this.makeInput('m_curr', 'USD'))
+			form.appendChild(this.makeInput('m_desc', data.description))
+			form.appendChild(this.makeInput('m_sign', data.signature))
+			form.appendChild(this.makeInput('m_params', data.params))
+			form.appendChild(this.makeInput('m_cipher_method', 'AES-256-CBC'))
+			form.submit()
+			/* console.log(data.description) */
+			/* console.log(data.signature) */
+		})
+
+}
+
+function payPm() {
+
 }
 
 function ready() {
-	return this.total != 0 && !this.loading && ((this.cardValid &&
-	this.billingName) || this.picked)
+	if (this.packs.credis10 < 0) {
+		return false
+	} else if (this.packs.credis50 < 0) {
+		return false	
+	} else if (this.packs.credis100 < 0) {
+		return false
+	} else if (this.packs.credis1000 < 0) {
+		return false
+	}
+
+	return this.total > 0 && !this.loading && this.agreed
 }
 
 export default {
-	components:{Loading, PaymentCard, SavedCards, PurchaseCompleted},
+	components:{Loading},
 	data() {
 		return {packs: {credits10: 0, credits50: 0,
-		credits100: 0, credits1000: 0}, loading: false, stripe:
-		window.Stripe(process.env.VUE_APP_STRIPE_KEY), card:
-		null, billingName: null, selectSaved: true, cardValid: false, cards:
-		null, picked: null, complete: false
+		credits100: 0, credits1000: 0}, loading: false, method: 'payeer',
+		complete: false, agreed: false
 		}
 	},
 	computed: {total, ready},
-	methods: {getSecret, pay, getCards},
+	methods: {getSecret, pay, payPm, payPayeer, makeInput},
 	props: ['preferred', 'token'],
 	emits: ['purchaseComplete'],
-	created() {
-		this.getCards()	
-	}
 }
 </script>
diff --git a/resources/js/panel/settings.vue b/resources/js/panel/settings.vue
index 9f7e376..d0bfbc0 100644
--- a/resources/js/panel/settings.vue
+++ b/resources/js/panel/settings.vue
@@ -1,10 +1,6 @@
 <template>
 <div>
 	<h3>Settings</h3>
-	<section class="billing-pane">
-		<h4>Billing</h4>
-		<edit-cards :preferred="user.payment_method" :token="token"></edit-cards>
-	</section>
 	<section class="change-name-pane">
 		<h4>Name</h4>
 		<input :value="user.name" name="name" id="changed_name" type="text">
@@ -30,7 +26,6 @@
 
 <script>
 import Loading from '../icons/loading.vue'
-import EditCards from './edit-cards.vue'
 
 function changeName() {
 	let name = document.getElementById('changed_name').value
@@ -115,7 +110,7 @@ function changePassword() {
 }
 
 export default {
-	components: {Loading, EditCards},
+	components: {Loading,},
 	methods: {
 		changePassword, changeName, changeEmail
 	},
diff --git a/resources/scss/main.scss b/resources/scss/main.scss
index c4bead1..98dc50f 100644
--- a/resources/scss/main.scss
+++ b/resources/scss/main.scss
@@ -567,7 +567,8 @@ section.features-info {
 }
 
 div.register-area.active {
-	min-height: 35em;
+	height: fit-content;
+	min-height: 20em;
 	opacity: 1;
 }
 
@@ -1336,3 +1337,35 @@ main.terms {
 		color: grey;
 	}
 }
+
+.payment-window {
+	min-height: 5em;
+	margin-top: 1em;
+	text-align: center;
+	color: grey;
+	img {
+		width: 250px;
+		max-width: 80%;
+		margin: auto;
+		margin-bottom: 1em;
+		display: block;
+		height: 90px;
+	}
+}
+
+#agreement-check {
+	margin: auto;
+	max-width: 30em;
+	display: flex;
+	align-items: center;
+
+	label {
+		display: inline-block;
+		// width: 85%;
+		margin: 1em;
+	}
+
+	input {
+		display: inline-block;
+	}
+}
diff --git a/resources/views/home.blade.php b/resources/views/home.blade.php
index 8aa0eb1..2052902 100644
--- a/resources/views/home.blade.php
+++ b/resources/views/home.blade.php
@@ -193,7 +193,8 @@
 		</p></div></div>
 		<div class="collapsible"><button>How can I pay?</button>
 		<div class="content"><p>
-		We accept credit and debit through Mastercard and Visa.
+		We accept Bitcoin, Litecoin, and other cryptocurrencies through our
+		Payeer and Perfect Money payment providers.
 		</p></div></div>
 
 		</div>
diff --git a/resources/views/master.blade.php b/resources/views/master.blade.php
index de9b6a1..3ed0b76 100644
--- a/resources/views/master.blade.php
+++ b/resources/views/master.blade.php
@@ -35,7 +35,6 @@
 @show
 
 @section('scripts')
-	<script src="https://js.stripe.com/v3/"></script>
 @show
 
 </body>
diff --git a/routes/web.php b/routes/web.php
index cc30c70..cd76ea9 100644
--- a/routes/web.php
+++ b/routes/web.php
@@ -112,6 +112,7 @@ Route::post('/panel/orders', [OrderController::class,
 Route::post('/panel/secret', [BillingController::class,
 	'stripeSecret'])->middleware([ 'auth', 'verified' ]);
 
+//Initiate a payeer payment
 Route::post('/panel/payeer', [BillingController::class,
 	'payeer'])->middleware([ 'auth', 'verified' ]);
 
@@ -124,4 +125,4 @@ Route::post('/hooks/charge',
 
 //Payeer handler function
 Route::post('/hooks/payeer-transaction',
-	[BillingController::class, 'payeer']);
+	[BillingController::class, 'processPayeer']);