Subversion Repositories SmartDukaan

Rev

Rev 17904 | Rev 18039 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
17793 naman 1
<?php
2
App::uses('AppController', 'Controller');
3
/**
4
 * Exceptionalnlcs Controller
5
 *
6
 * @property Exceptionalnlc $Exceptionalnlc
7
 * @property PaginatorComponent $Paginator
8
 */
9
class ShippingsController extends AppController {
10
 
11
/**
12
 * Components
13
 *
14
 * @var array
15
 */
16
	public $components = array('Paginator');
17
 
18
	public function beforeFilter() {
19
		parent::beforeFilter();
20
		$this->apihost = Configure::read('pythonapihost');
21
		$this->mobileapihost = Configure::read('saholicapihost');
17838 manish.sha 22
		$this->Auth->allow('isServicable');
17793 naman 23
	}
24
 
25
 
26
	public function index(){
27
		$userId = $this->Auth->User('id');
17838 manish.sha 28
		$dataGiven = json_decode($this->request->data['cart_details']);
17793 naman 29
		if ($this->request->is('post')) {
30
			$data = $this->request->data;
31
		}
17871 manish.sha 32
 
17838 manish.sha 33
		$suserId = base64_decode($_COOKIE['s_id']);
17871 manish.sha 34
		$scartId = base64_decode($_COOKIE['s_cart']);
35
		$semailId = base64_decode($_COOKIE['s_email']);
36
 
37
		$pincode = 0;
38
 
39
		if($pincode==0 && isset($_COOKIE['s_pincode'])){
40
			$pincode = base64_decode($_COOKIE['s_pincode']);
17793 naman 41
		}
17838 manish.sha 42
 
17871 manish.sha 43
		$cartItems = array();
44
 
45
		foreach ($dataGiven->cartItems as $key=>$obj) {
46
		    $itemobj = array(
47
					'itemId'   => $key,
48
		    		'quantity' => $obj->quantity);
49
			array_push($cartItems, $itemobj);
17838 manish.sha 50
		}
17871 manish.sha 51
		$postData = array(
52
					'cartItems'	=>	$cartItems
53
					);
54
 
55
		$params = array(
56
				'cartMap' => urlencode(json_encode($postData)));
17838 manish.sha 57
 
17871 manish.sha 58
		$this->layout = 'cartinnerpages';
59
		$url = Configure::read('saholicapihost').'cart!validateCart?isLoggedIn=true&privateDealUser=true&userId='.$suserId.'&id='.$scartId.'&email='.$semailId;
60
		if($pincode!='0'){
61
			$url = $url.'&pinCode='.$pincode;
62
		}
63
		$cartskus = $this->post_cartinfo_request($url,$params);
64
		if(isset($cartskus['response']) && $cartskus['response']=='error'){
65
			$this->set(compact('cartskus'));
66
			$this->render('/Users/cartdetails');
67
 
68
		}elseif(isset($cartskus['cartMessages']) && count($cartskus['cartMessages'])>0){
69
			setcookie('s_pincode', base64_encode($cartskus['pincode']), -1, '/');
70
			$this->set(compact('cartskus'));
71
			$this->render('/Users/cartdetails');
72
		}else{
73
			$totalPayable = intval($dataGiven->totalCartValue) + intval($dataGiven->shippingCharges);
74
			$this->Session->write('totalPayable', $totalPayable);
75
			$this->layout = 'innerpages';
17882 naman 76
			$url = Configure::read ( 'saholicapihost' ) . 'address?isLoggedIn=true&privateDealUser=true&userId=' . $suserId;
77
			$response = $this->make_request ( $url, null );
78
			$user_name = "";
79
			$user_contact = "";
17871 manish.sha 80
 
17947 manish.sha 81
			$codAvailable = $cartskus['cod'];
82
			$this->Session->write('cod', $codAvailable);
83
 
17882 naman 84
			if(empty($response ['addresses'])){
85
				$this->redirect ( array (
86
						'action' => 'add' 
87
				));
17793 naman 88
			}
17871 manish.sha 89
 
17882 naman 90
			$firstshowaddress = array ();
91
			$findedaddress = array ();
92
			$moreshowaddress = array ();
93
			$current_address_id = - 1;
94
			$defaultpin = - 1;
95
			$defaultcookiepin = - 1;
96
			$defaultcheckedaddress = - 1;
97
			$defaultpinaddress = - 1;
98
			foreach ( $response ['addresses'] as $key => $value ) {
99
				// debug($value['']);
100
 
101
				if ($value ['id'] == intval ( $response ['defaultAddress'] ) && intval ( $value ['pin'] ) == $pincode) {
102
					$defaultcookiepin = $key;
103
					$user_name = $value ['name'];
104
					$user_contact = $value ['phone'];
105
					if ($defaultcheckedaddress == - 1) {
106
						$defaultcheckedaddress = $value ['id'];
107
					}
108
				} else if (intval ( $value ['pin'] ) == $pincode) {
109
					$current_address_id = $key;
110
					array_push ( $findedaddress, $key );
111
					if ($defaultpinaddress == - 1) {
112
						$defaultpinaddress = $value ['id'];
113
					}
114
				} else if ($value ['id'] == intval ( $response ['defaultAddress'] )) {
115
					$defaultpin = $key;
116
					$user_name = $value ['name'];
117
					$user_contact = $value ['phone'];
118
				} else {
119
					array_push ( $moreshowaddress, $key );
17871 manish.sha 120
				}
121
			}
17882 naman 122
 
123
			$defaultselectedaddress = - 1;
124
			if ($defaultpinaddress != - 1) {
125
				$defaultselectedaddress = $defaultpinaddress;
17793 naman 126
			}
17882 naman 127
			if ($defaultcheckedaddress != - 1) {
128
				$defaultselectedaddress = $defaultcheckedaddress;
17871 manish.sha 129
			}
17882 naman 130
 
131
			if ($defaultcookiepin != - 1) {
132
				array_push ( $firstshowaddress, $defaultcookiepin );
17871 manish.sha 133
			}
17882 naman 134
 
135
			for($i = 0; $i < count ( $findedaddress ); $i ++) {
136
				array_push ( $firstshowaddress, $findedaddress [$i] );
17871 manish.sha 137
			}
138
 
17882 naman 139
			if ($defaultpin != - 1) {
140
				array_push ( $firstshowaddress, $defaultpin );
141
			}
142
 
143
			for($i = 0; $i < count ( $moreshowaddress ); $i ++) {
144
				array_push ( $firstshowaddress, $moreshowaddress [$i] );
145
			}
146
 
147
			$this->set ( 'address', $response );
148
 
17947 manish.sha 149
			$this->set ( compact ( 'firstshowaddress', 'totalPayable', 'user_name', 'user_contact', 'pincode', 'defaultselectedaddress', 'message', 'codAvailable') );
17793 naman 150
		}
17882 naman 151
	}
152
	public function add($user_name = null, $user_contact = null) {
153
		$this->layout = 'cartinnerpages';
17793 naman 154
 
17882 naman 155
		$totalPayable = $_SESSION ['totalPayable'];
17947 manish.sha 156
		$codAvailable = $_SESSION ['cod'];
17882 naman 157
		$pinval = base64_decode ( $_COOKIE ['s_pincode'] );
158
		$suserId = base64_decode ( $_COOKIE ['s_id'] );
159
		$scart = base64_decode ( $_COOKIE ['s_cart'] );
160
 
161
		if ($this->request->is ( 'post' )) {
17793 naman 162
			$data = $this->request->data;
17882 naman 163
 
164
			$senddata ['name'] = $data ['name'];
165
			$senddata ['line1'] = $data ['line1'];
166
			$senddata ['line2'] = "";
167
			$senddata ['city'] = $data ['city'];
168
			$senddata ['state'] = $data ['state'];
169
			$senddata ['pin'] = $data ['pin'];
170
			$senddata ['phone'] = $data ['phone'];
171
			$senddata ['country'] = 'India';
172
			$url = Configure::read ( 'saholicapihost' ) . "address?userId=" . $suserId . "&isLoggedIn=true&cartId=" . $scart . "&isPrivateDealUser=true";
173
 
174
			$response = $this->post_request ( $url, $senddata );
175
 
176
			$scartId = base64_decode ( $_COOKIE ['s_cart'] );
177
			$semailId = base64_decode ( $_COOKIE ['s_email'] );
178
			$blank = array ();
179
			$postData = array (
180
					'cartItems' => $blank 
181
			);
182
 
183
			$params = array (
184
					'cartMap' => urlencode ( json_encode ( $postData ) ) 
185
			);
186
			$url = Configure::read ( 'saholicapihost' ) . 'cart!validateCart?isLoggedIn=true&privateDealUser=true&userId=' . $suserId . '&id=' . $scartId . '&email=' . $semailId;
187
			// if($pin!='0'){
188
			$url = $url . '&pinCode=' . $data ['pin'];
189
			// }
190
			$cartskus = $this->post_cartinfo_request ( $url, $params );
191
			$checkestimate = 'true';
192
			if ($cartskus ['maxEstimate'] == - 1) {
193
				$checkestimate = 'false';
194
			} else {
195
				for($i = 0; $i < count ( $cartskus ['cartItems'] ); $i ++) {
17904 amit.gupta 196
					if(array_key_exists('estimate',$cartskus ['cartItems'] [$i])){
197
						continue;
198
					}
199
					$estimate = $cartskus ['cartItems'] [$i] ['estimate'];
200
					if ($estimate==-1) {
17882 naman 201
						$checkestimate = 'false';
202
						break;
203
					}
204
				}
17793 naman 205
			}
206
 
17882 naman 207
			if ($checkestimate == 'false') {
208
				// debug("I am here");
209
				$this->Session->setFlash ( "Address is not serviceable", 'default', array (
210
						'class' => 'alert alert-danger custom_class' 
211
				) );
212
				// $this->Session->setFlash('Address is not serviceable');
213
				return $this->redirect ( array (
214
						'action' => 'index' 
215
				) );
216
			} else {
217
				$this->Session->setFlash ( "Address is  serviceable" );
17793 naman 218
			}
219
		}
220
 
17882 naman 221
		$url = $this->apihost . "pincodeValidation/" . $pinval;
222
		$getstate = $this->make_request ( $url, null );
17844 naman 223
		// debug($getstate);
17793 naman 224
		$getstateval = "";
17882 naman 225
		if ($getstate != "{}") {
226
			$getstateval = ucwords ( strtolower ( $getstate ['state'] ) );
17793 naman 227
		}
17947 manish.sha 228
		$this->set(compact('getstateval', 'user_name', 'user_contact', 'pinval', 'totalPayable', 'codAvailable'));
17793 naman 229
	}
17882 naman 230
	public function submitcheck() {
231
		$this->autoRender = false;
232
		$this->request->onlyAllow ( 'ajax' );
233
 
17899 amit.gupta 234
		$suserId = base64_decode($_COOKIE['s_id']);
235
		$scartId = base64_decode($_COOKIE['s_cart']);
236
		$semailId = base64_decode($_COOKIE['s_email']);
237
 
17882 naman 238
		$data = $this->request->data;
239
 
240
		$senddata ['name'] = $data ['name'];
241
		$senddata ['line1'] = $data ['line1'];
242
		$senddata ['line2'] = "";
243
		$senddata ['city'] = $data ['city'];
244
		$senddata ['state'] = $data ['state'];
245
		$senddata ['pin'] = $data ['pin'];
246
		$senddata ['phone'] = $data ['phone'];
247
		$senddata ['country'] = 'India';
17899 amit.gupta 248
		$url = Configure::read ( 'saholicapihost' ) . "address?userId=" . $suserId . "&isLoggedIn=true&cartId=" . $scartId . "&isPrivateDealUser=true";
17882 naman 249
 
17899 amit.gupta 250
		$response = $this->post_cartinfo_request($url,$senddata);
17882 naman 251
		$suserId = base64_decode ( $_COOKIE ['s_id'] );
252
 
253
		$scartId = base64_decode ( $_COOKIE ['s_cart'] );
254
		$semailId = base64_decode ( $_COOKIE ['s_email'] );
255
		$blank = array ();
256
		$postData = array (
257
				'cartItems' => $blank 
258
		);
259
 
260
		$params = array (
261
				'cartMap' => urlencode ( json_encode ( $postData ) ) 
262
		);
263
		$url = Configure::read ( 'saholicapihost' ) . 'cart!validateCart?isLoggedIn=true&privateDealUser=true&userId=' . $suserId . '&id=' . $scartId . '&email=' . $semailId;
264
		// if($pin!='0'){
265
		$url = $url . '&pinCode=' . $data ['pin'];
266
		// }
267
		$cartskus = $this->post_cartinfo_request ( $url, $params );
17893 amit.gupta 268
		$checkestimate = $response ['defaultAddress'];
17882 naman 269
		if ($cartskus ['maxEstimate'] == - 1) {
17893 amit.gupta 270
			$checkestimate = '';
17882 naman 271
		} else {
272
			for($i = 0; $i < count ( $cartskus ['cartItems'] ); $i ++) {
17904 amit.gupta 273
				if(array_key_exists('estimate',$cartskus ['cartItems'] [$i])){
274
					continue;
275
				}
276
				$estimate = $cartskus ['cartItems'] [$i] ['estimate'];
277
				if ($estimate==-1) {
17893 amit.gupta 278
					$checkestimate = '';
17882 naman 279
					break;
280
				}
281
			}
282
		}
283
 
284
		return $checkestimate;
285
	}
286
	public function getstate($pin_val) {
287
		$this->autoRender = false;
288
		$this->request->onlyAllow ( 'ajax' );
289
		$url = $this->apihost . "pincodeValidation/" . $pin_val;
290
		$getstate = $this->make_request ( $url, null );
291
		// $getstate['state'] = ucwords(strtolower($getstate['state']));
17844 naman 292
		$nothing = "nothing";
17882 naman 293
		if ($getstate != "{}") {
294
			$getstate ['state'] = ucwords ( strtolower ( $getstate ['state'] ) );
17844 naman 295
		}
17882 naman 296
		return json_encode ( $getstate );
297
	}
298
	public function isServicable($pin) {
299
		$this->autoRender = false;
300
		$this->request->onlyAllow ( 'ajax' );
17793 naman 301
		// $url = "http://shop2020.in:8080/mobileapi/address!serviceable?pincode=".$pin;
302
		// $response = $this->make_request($url,null);
17882 naman 303
 
304
		$scartId = base64_decode ( $_COOKIE ['s_cart'] );
305
		$suserId = base64_decode ( $_COOKIE ['s_id'] );
306
		$semailId = base64_decode ( $_COOKIE ['s_email'] );
307
		$blank = array ();
308
		$postData = array (
309
				'cartItems' => $blank 
310
		);
311
 
312
		$params = array (
313
				'cartMap' => urlencode ( json_encode ( $postData ) ) 
314
		);
315
		$url = Configure::read ( 'saholicapihost' ) . 'cart!validateCart?isLoggedIn=true&privateDealUser=true&userId=' . $suserId . '&id=' . $scartId . '&email=' . $semailId;
316
		$url = $url . '&pinCode=' . $pin;
317
		$cartskus = $this->post_cartinfo_request ( $url, $params );
318
		$checkestimate = 'true';
319
		if ($cartskus ['maxEstimate'] == - 1) {
320
			$checkestimate = 'false';
321
		} else {
322
			for($i = 0; $i < count ( $cartskus ['cartItems'] ); $i ++) {
17904 amit.gupta 323
				if(array_key_exists('estimate',$cartskus ['cartItems'] [$i])){
324
					continue;
325
				}
326
				$estimate = $cartskus ['cartItems'] [$i] ['estimate'];
327
				if ($estimate==-1) {
17882 naman 328
					$checkestimate = 'false';
329
					break;
330
				}
331
			}
332
		}
333
 
334
		return $checkestimate;
335
	}
336
 
17871 manish.sha 337
	 public function checkout(){
338
	 	$addressid = json_decode($this->request->data['addressid']);
17846 manish.sha 339
	 	$pincode = 0;
17871 manish.sha 340
		$cod = $this->request->query('cod');
17846 manish.sha 341
		$userId = $this->request->query('user_id');
342
 
343
		if(isset($this->request->data->pincode)){
344
			$pincode = $this->request->data->pincode;
345
		}
346
		if($pincode==0 && isset($_COOKIE['s_pincode'])){
347
			$pincode = base64_decode($_COOKIE['s_pincode']);
348
		}
349
 
17871 manish.sha 350
		$suserId = base64_decode($_COOKIE['s_id']);
351
		$scartId = base64_decode($_COOKIE['s_cart']);
352
		$semailId = base64_decode($_COOKIE['s_email']);
353
 
354
		if(isset($_COOKIE['txn_comp'])) {
355
			unset($_COOKIE['txn_comp']);
356
		}
357
 
358
		if($cod==1){
359
			$url = Configure::read('saholicapihost').'order?payment_option=3000&isLoggedIn=true&privateDealUser=true&userId='.$suserId.'&id='.$scartId.'&email='.$semailId.'&addressid='.$addressid;
360
		 	if($pincode!='0'){
361
				$url = $url.'&pinCode='.$pincode;
362
			}
363
			$orderCreationResponse = $this->post_cartinfo_request($url, null);
364
			//{"response":{"success":true,"redirectUrl":"pay-success?paymentId=998593"}}
365
			$redirecturl = $orderCreationResponse['response']['redirectUrl'];
366
			if (strpos($redirecturl,'pay-success') === false) {
17885 manish.sha 367
			    setcookie('txn_comp', 'no', -1, '/');
17871 manish.sha 368
			}
369
			$this->layout = 'innerpages';
370
			$next = $redirecturl;					
371
			$redirectUrl = $this->getAutoLoginUrl($userId,$next);
372
			$this->log($redirectUrl,'headers');
373
			$this->set(compact('redirectUrl','next'));
374
		}else{
375
			$dataGiven = json_decode($this->request->data['cart_details']);
376
			$totalSkus= intval($dataGiven->totalSkus);
17885 manish.sha 377
			setcookie('txn_comp', 'no', -1, '/');
17871 manish.sha 378
			$this->layout = 'innerpages';
17892 manish.sha 379
			$next = "payment?cq=".$totalSkus.'&addressid='.$addressid;					
17871 manish.sha 380
			$redirectUrl = $this->getAutoLoginUrl($userId,$next);
381
			$this->log($redirectUrl,'headers');
382
			$this->set(compact('redirectUrl','next'));
383
		}
384
	 }
17793 naman 385
}