# -*- coding: utf-8 -*-
#################################################################################
#
#    Copyright (c) 2015-Present Webkul Software Pvt. Ltd. ()
#
#################################################################################
from odoo.addons.web.controllers.main import Home
import json
from urllib.parse import urlparse
import xml.etree.ElementTree as ET
import werkzeug
from odoo import _
from odoo.http import request, Controller, route
import logging
_logger = logging.getLogger(__name__)
from base64 import b64decode
from ast import literal_eval
from functools import wraps
from odoo.addons.mobikul.models.mobikul import _displayWithCurrency, _get_image_url
import hashlib
import requests
from ast import literal_eval
# from werkzeug.http import parse_authorization_header
# from odoo.http import Controller, dispatch_rpc
import re
TAG_RE = re.compile(r'<[^>]+>')
def remove_htmltags(text):
	return TAG_RE.sub('', text)
PRICE_FIELDS = [
"amount_total","amount_untaxed","amount_tax",
"price_unit","price_subtotal","price_tax","price_total","price"
]
AQUIRER_REF_CODES = [
'COD','STRIPE_E','STRIPE_W',
	"2_CHECKOUT","PAYFORT_SADAD","PAYFORT"
]
# For UI Controller payment Aquirer
# Note:  Remenber in place order api (def placeorder) methods Acquire name for Ui controller gateway like '2_CHECKOUT' and 'PAYFORT_SADAD' should be same as in backend acquire name.
PAYFORT_SDK_ENV_URL = {
"test":"https://sbpaymentservices.payfort.com/FortAPI/paymentApi",
"prod":"https://paymentservices.payfort.com/FortAPI/paymentApi"
}
STATUS_MAPPING = {
"STRIPE": {'succeeded':'done','pending':'pending','failed':'error'},
}
import uuid
def _get_next_reference(order_name):
	return order_name+"-"+str(uuid.uuid4())[:5]
class xml(object):
	@staticmethod
	def _encode_content(data):
		# .replace('&', '&')
		return data.replace('<','<').replace('>','>').replace('"', '"')
	@classmethod
	def dumps(cls, apiName, obj):
		_logger.warning("%r : %r"%(apiName, obj))
		if isinstance(obj, dict):
			return "".join("<%s>%s%s>" % (key, cls.dumps(apiName, obj[key]), key) for key in obj)
		elif isinstance(obj, list):
			return "".join("<%s>%s%s>" % ("I%s" % index, cls.dumps(apiName, element),"I%s" % index) for index,element in enumerate(obj))
		else:
			return "%s" % (xml._encode_content(obj.__str__()))
	@staticmethod
	def loads(string):
		def _node_to_dict(node):
			if node.text:
				return node.text
			else:
				return {child.tag: _node_to_dict(child) for child in node}
		root = ET.fromstring(string)
		return {root.tag: _node_to_dict(root)}
class WebServices(Controller):
	def __decorateMe(func):
		@wraps(func)
		def wrapped(inst, *args, **kwargs):
			inst._mData = request.httprequest.data and json.loads(request.httprequest.data.decode('utf-8')) or {}
			inst._mAuth = request.httprequest.authorization and (request.httprequest.authorization.get('password') or request.httprequest.authorization.get("username")) or None
			inst.base_url = request.httprequest.host_url
			inst._lcred = {}
			inst._sLogin = False
			inst.auth = True
			inst._mLang = request.httprequest.headers.get("lang") or None
			if request.httprequest.headers.get("Login"):
				try:
					inst._lcred = literal_eval(b64decode(request.httprequest.headers["Login"]).decode('utf-8'))
				except:
					inst._lcred = {"login":None,"pwd":None}
			elif request.httprequest.headers.get("SocialLogin"):
				inst._sLogin = True
				try:
					inst._lcred = literal_eval(b64decode(request.httprequest.headers["SocialLogin"]).decode('utf-8'))
				except:
					inst._lcred = {"authProvider":1,"authUserId":1234567890}
			else:
				inst.auth = False
			return func(inst, *args, **kwargs)
		return wrapped
	def _available_api(self):
		API = {
		'homepage':{
					'description':'HomePage API',
					'uri':'/mobikul/homepage'
				},
		'sliderProducts':{
					'description':'Product(s) of given Product Slider Record',
					'uri':'/mobikul/sliderProducts/<int:product_slider_id>',
				},
		'login':{
					'description':'Customer Login',
					'uri':'/mobikul/customer/login',
				},
		'signUp':{
					'description':'Customer signUp',
					'uri':'/mobikul/customer/signUp',
				},
		'resetPassword':{
					'description':'Customer Reset Password',
					'uri':'/mobikul/customer/resetPassword',
				},
		'splashPageData':{
					'description':'Default data to saved at app end.',
					'uri':'/mobikul/splashPageData',
				},
		}
		return API
	def _wrap2xml(self, apiName, data):
		resp_xml = ""
		resp_xml += ''
		resp_xml += "<%s>"%apiName
		resp_xml += xml.dumps(apiName, data)
		resp_xml += "%s>"%apiName
		resp_xml += ''
		return resp_xml
	def _response(self, apiName, response, ctype='json'):
		if 'local' in response:
			response.pop("local")
		if ctype=='json':
			mime='application/json; charset=utf-8'
			body = json.dumps(response)
		else:
			mime='text/xml'
			body = self._wrap2xml(apiName,response)
		headers = [
					('Content-Type', mime),
					('Content-Length', len(body))
				]
		return werkzeug.wrappers.Response(body, headers=headers)
	@__decorateMe
	def _authenticate(self, auth, **kwargs):
		if 'api_key' in kwargs:
			api_key  = kwargs.get('api_key')
		elif request.httprequest.authorization:
			api_key  = request.httprequest.authorization.get('password') or request.httprequest.authorization.get("username")
		else:
			api_key = False
		Mobikul = request.env['mobikul'].sudo()
		response = Mobikul._validate(api_key,{"lang":self._mLang})
		if not response.get('success'):
			return response
		request.context = dict(request.context, pricelist=response.get('pricelist'), lang=response.get('lang'), base_url=self.base_url)
		if auth:
			Mobikul = request.env['mobikul'].sudo()
			result = Mobikul.authenticate(self._lcred, kwargs.get('detailed',False),self._sLogin, context={'base_url':self.base_url})
			response.update(result)
		return response
	@route('/mobikul/', csrf=False, type='http', auth="none")
	def index(self, **kwargs):
		""" HTTP METHOD : request.httprequest.method
		"""
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			data = self._available_api()
			return self._response('mobikulApi', data, 'xml')
		else:
			headers=[('WWW-Authenticate','Basic realm="Welcome to Odoo Webservice, please enter the authentication key as the login. No password required."')]
			return werkzeug.wrappers.Response('401 Unauthorized %r'%request.httprequest.authorization, status=401, headers=headers)
	@route('/mobikul/homepage', csrf=False, type='http', auth="none", methods=['POST'])
	def getHomepage(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			response.update(self._languageData())
			Mobikul = request.env['mobikul'].sudo()
			if self.auth:
				result = Mobikul.authenticate(self._lcred, True, self._sLogin, context={'base_url':self.base_url})
				response.update(result)
			local = response.get('local',{})
			context = {"base_url":self.base_url, "currencySymbol":local.get("currencySymbol",""),
							"currencyPosition":local.get("currencyPosition",""),"lang_obj":local.get("lang_obj","")}
			result = Mobikul.homePage(self._mData,context)
			response.update(result)
			self._tokenUpdate(customer_id=response.get('customerId'))
		return self._response('homepage', response)
	@route(['/mobikul/sliderProducts/'], type='http', auth="none", csrf=False, methods=['GET','POST'])
	def getSliderProducts(self, slider_id, **kwargs):
		if request.httprequest.headers.get("Login"):
			response = self._authenticate(True, **kwargs)
		else:
			response = self._authenticate(False, **kwargs)
		if response.get('addons',{}).get('wishlist') and response.get('customerId'):
			response['wishlist']= self._website_Wishlist(response.get('customerId'))
		if response.get('success'):
			PSlider = request.env['mobikul.product.slider'].sudo().search([('id','=',slider_id)])
			if PSlider:
				local = response.get('local',{})
				context = {
						'limit':response.get('itemsPerPage',5),
						'offset':self._mData.get('offset',0),
						'order':self._mData.get('order',None),
						"currencySymbol":local.get("currencySymbol",""),
						"currencyPosition":local.get("currencyPosition",""),
						'lang_obj':local.get("lang_obj",""),
					}
				result = PSlider.get_product_data(context)
			else:
				result = {'success':False, 'message':'Product Slider not found !!!'}
			response.update(result)
		return self._response('sliderProducts', response)
	@route('/mobikul/customer/login', csrf=False, type='http', auth="none", methods=['POST'])
	def login(self, **kwargs):
		kwargs['detailed'] = True
		response = self._authenticate(True, **kwargs)
		self._tokenUpdate(customer_id=response.get('customerId'))
		return self._response('login', response)
	@route('/mobikul/customer/signUp', csrf=False, type='http', auth="none", methods=['POST'])
	def signUp(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			createNotification = False
			Mobikul = request.env['mobikul'].sudo()
			result = Mobikul.signUp(self._mData)
			response.update(result)
			if response['success'] and response.get('addons',{}).get('email_verification') and Mobikul.email_verification_defaults().get('send_email_on_signup'):
				if not self._mData.get('authUserId',False):
					response["message"] = _("An email has been sent to your email address. Please verify it.")
					createNotification = True
			if response['success']:
				homepage = {}
				login = {}
				if self._mData.get('authUserId',False):
					cred = {'authUserId':self._mData.get('authUserId',""),'authProvider':self._mData.get('authProvider',"")}
				else:
					cred = {'login':self._mData.get('login',""),'pwd':self._mData.get('password',"")}
				login = Mobikul.authenticate(cred, True, self._sLogin, context={'base_url':self.base_url})
				response.update({"login":login,"cred":cred})
				local = response.get('local',{})
				context = {
						"base_url":self.base_url,
						"currencySymbol":local.get("currencySymbol",""),
						"currencyPosition":local.get("currencyPosition",""),
						"lang_obj":local.get('lang_obj'),
						}
				result = Mobikul.homePage(self._mData,context)
				homepage.update(result)
				response.update({"homepage":homepage})
			self._tokenUpdate(customer_id=response.get('customerId'))
			if response.get("message","").startswith("Created"):
				createNotification = True
			if createNotification:
				self._pushNotification( self._mData.get("fcmToken",""), customer_id = response.get('customerId') )
		return self._response('signUp', response)
	@route('/mobikul/customer/resetPassword', csrf=False, type='http', auth="none", methods=['POST'])
	def resetPassword(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			Mobikul = request.env['mobikul'].sudo()
			result = Mobikul.resetPassword(self._mData.get('login',False))
			response.update(result)
		return self._response('resetPassword', response)
	@route('/mobikul/customer/signOut', csrf=False, type='http', auth="none", methods=['POST'])
	def signOut(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			response['message'] = "Have a Good Day !!!"
			self._tokenUpdate()
		return self._response('signOut', response)
	@route('/mobikul/splashPageData', csrf=False, type='http', auth="none", methods=['POST'])
	def getSplashPageData(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			Mobikul = request.env['mobikul'].sudo()
			if 'login' in self._lcred:
				result = Mobikul.authenticate(self._lcred, True,self._sLogin, context={'base_url':self.base_url})
				response.update(result)
			result = Mobikul.getDefaultData()
			response.update(result)
			response['sortData'] = [
				("Price: High to Low", "price desc"),
				("Price: Low to High", "price asc"),
				("Discounts", "id asc"),
				("Popularity", "id asc"),
				("Newest First", "id desc"),
			]
			response.update(self._languageData())
			if response.get('addons',{}).get('review'):
				response['RatingStatus'] = [
					("1",_("Poor")),
					("2",_("Ok")),
					("3",_("Good")),
					("4",_("Very Good")),
					("5",_("Excellent")),
				]
		return self._response('splashPageData', response)
	def _languageData(self):
		mobikul = request.env['mobikul'].sudo().search([], limit=1)
		temp = {
				'defaultLanguage':(mobikul.default_lang.code,mobikul.default_lang.name),
				'allLanguages':[(id.code,id.name) for id in mobikul.language_ids ]
		}
		return temp
	@route('/mobikul/my/orders', csrf=False, type='http', auth="none", methods=['POST'])
	def getMyOrders(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner:
				result = {}
				local = response.get('local',{})
				fields = ['name', 'create_date', 'state', 'amount_total', 'partner_shipping_id']
				SaleOrder = request.env['sale.order'].sudo()
				domain = [
						('message_partner_ids', 'child_of', [Partner.commercial_partner_id.id]),
						('state','not in',('draft','sent'))
					]
				if self._mData.get('date_from',False) and self._mData.get('date_to',False):
					# domain += [('create_date', '>', context['date_from']), ('create_date', '<=', context['date_to'])]
					domain += [('create_date', '>',self._mData.get('date_from') ), ('create_date', '<=', self._mData.get('date_to'))]
				result['tcount'] = SaleOrder.search_count(domain)
				orders = SaleOrder.search_read(domain, limit=self._mData.get('limit',response.get('itemsPerPage',5)), offset=self._mData.get('offset',0),  order="id desc", fields=fields)
				result['recentOrders'] = []
				for order in orders:
					ShippingAdd = PartnerObj.search([('id','=',order['partner_shipping_id'][0])])
					temp = {
					'id':order['id'],
					'name':order['name'] or "",
					'create_date':order['create_date'],
					'shipping_address':ShippingAdd and ShippingAdd._display_address() or "",
					'shipAdd_url':ShippingAdd and '/mobikul/my/address/%s'%ShippingAdd.id or "",
					'amount_total':_displayWithCurrency(local.get('lang_obj'),order['amount_total'], local.get('currencySymbol',""), local.get('currencyPosition',"")),
					'status':order['state'],
					'canReorder':True,
					'url':"/mobikul/my/order/%s"%order['id'],
					}
					result['recentOrders'].append(temp)
			else:
				result = {'success':False, 'message':'Customer not found !!!'}
			response.update(result)
		return self._response('orders', response)
	@route('/mobikul/my/order/', csrf=False, type='http', auth="none", methods=['POST'])
	def getMyOrder(self, order_id, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			Order = request.env['sale.order'].sudo().search([('id','=',order_id)])
			if Order:
				local = response.get('local',{})
				result = {
					'name':Order.name or "",
					'create_date':Order.create_date or "",
					'amount_total':_displayWithCurrency(local.get('lang_obj'),Order.amount_total, local.get('currencySymbol',""), local.get('currencyPosition',"")),
					'status':Order.state,
					'amount_untaxed':_displayWithCurrency(local.get('lang_obj'),Order.amount_untaxed, local.get('currencySymbol',""), local.get('currencyPosition',"")),
					'amount_tax':_displayWithCurrency(local.get('lang_obj'),Order.amount_tax, local.get('currencySymbol',""), local.get('currencyPosition',"")),
					'shipping_address':Order.partner_shipping_id._display_address(),
					'shipAdd_url':'/mobikul/my/address/%s'%Order.partner_shipping_id.id,
					'billing_address':Order.partner_invoice_id._display_address(),
				}
				result['items'] = []
				for line in Order.order_line:
					if response.get('addons', {}).get('website_sale_delivery') and line.is_delivery:
						shippingMethod = {
					      	"tax":[tax.name for tax in line.tax_id],
							"name":line.order_id.carrier_id.name,
							"description":line.order_id.carrier_id.website_description or "",
							"shippingId":line.order_id.carrier_id.id,
							"total": _displayWithCurrency(local.get('lang_obj'), line.price_subtotal,
														  local.get('currencySymbol'), local.get('currencyPosition')),
						}
						result.update({"delivery":shippingMethod})
					else:
						temp = {
						'name':line.name or "",
						'product_name':line.product_id and line.product_id.display_name or "",
						'qty':"%s %s"%(line.product_uom_qty, line.product_uom.name),
						'price_unit':_displayWithCurrency(local.get('lang_obj'),line.price_unit, local.get('currencySymbol',""), local.get('currencyPosition',"")),
						'price_subtotal':_displayWithCurrency(local.get('lang_obj'),line.price_subtotal, local.get('currencySymbol',""), local.get('currencyPosition',"")),
						'price_tax':_displayWithCurrency(local.get('lang_obj'),line.price_tax, local.get('currencySymbol',""), local.get('currencyPosition',"")),
						'price_total':_displayWithCurrency(local.get('lang_obj'),line.price_total, local.get('currencySymbol',""), local.get('currencyPosition',"")),
						'discount':"%s"%(line.discount and "%s %%"%line.discount or ""),
						'state':line.state,
						'thumbNail'		:_get_image_url(self.base_url, 'product.product', line.product_id and line.product_id.id or "",'image'),
						"templateId":line.product_id and line.product_id.product_tmpl_id.id or "",
						}
						result['items'].append(temp)
			else:
				result = {'success':False, 'message':'Order not found !!!'}
			response.update(result)
		return self._response('orders', response)
	@route('/mobikul/my/addresses', csrf=False, type='http', auth="none", methods=['POST'])
	def getMyAddresses(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner:
				result = {}
				domain = [
						('id', 'child_of', Partner.commercial_partner_id.ids),
						('id', 'not in', [Partner.id]),
					]
				result['tcount'] = PartnerObj.search_count(domain) + 1
				addresses = PartnerObj.search(domain, limit=self._mData.get('limit',response.get('itemsPerPage',5)), offset=self._mData.get('offset',0),  order="id desc")
				result['addresses'] = [
					{
						'name':Partner.name,
						'display_name':Partner._display_address(),
						'url':"/mobikul/my/address/%s"%Partner.id,
						'addressId':Partner.id,
					}
				]
				# in result['addresses'][0] zero index address is billing address other is shipping address
				for address in addresses:
					temp = {
					'name':address.name,
					'display_name':address._display_address(),
					'url':"/mobikul/my/address/%s"%address.id,
					'addressId':address.id,
					}
					result['addresses'].append(temp)
			else:
				result = {'success':False, 'message':'Customer not found !!!'}
			response.update(result)
		return self._response('orders', response)
	@route('/mobikul/my/address/default/', csrf=False, type='http', auth="none", methods=['PUT'])
	def setDefaultAddress(self, address_id, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Address = PartnerObj.search([('id','=',address_id)])
			if Address:
				result = {'message':'Updated successfully.'}
			else:
				result = {'success':False, 'message':'Address not found !!!'}
			response.update(result)
		return self._response('address', response)
	@route('/mobikul/my/address/new', csrf=False, type='http', auth="none", methods=['POST'])
	def addMyAddress(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			vals = {
				"name":self._mData.get('name',""),
				"street":self._mData.get('street',""),
				# "street2":self._mData.get('street2',""),
				"zip":self._mData.get('zip',""),
				"city":self._mData.get('city',""),
				"phone":self._mData.get('phone',""),
				"customer":1,
				"type":"delivery",
				"commercial_partner_id":int(response.get('customerId')),
				"parent_id":int(response.get('customerId')),
			}
			try:
				if self._mData.get("state_id"):
					if request.env['res.country.state'].sudo().browse(int(self._mData["state_id"])).exists():
						vals["state_id"] = int(self._mData["state_id"])
				if self._mData.get("country_id"):
					if request.env['res.country'].sudo().browse(int(self._mData["country_id"])).exists():
						vals["country_id"] = int(self._mData["country_id"])
				PartnerObj.create(vals)
				result = {'message':'Created successfully.'}
			except Exception as e:
				result = {'success':False, 'message':'Error: Invalid Data'}
			response.update(result)
		return self._response('address', response)
	@route('/mobikul/my/address/', csrf=False, type='http', auth="none", methods=['POST','PUT','DELETE'])
	def getMyAddress(self, address_id, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Address = PartnerObj.search([('id','=',address_id)])
			if Address:
				if request.httprequest.method in ["POST"]:
					result = {
						'name':Address.name or "" ,
						'street':Address.street or "",
						# 'street2':Address.street2 or "",
						'zip':Address.zip or "",
						'city':Address.city or "",
						'state_id':Address.state_id and Address.state_id.id or "",
						'country_id':Address.country_id and Address.country_id.id or "",
						'phone':Address.phone or "",
						# 'fax':Address.fax,
						# 'mobile':Address.mobile,
					}
				elif request.httprequest.method == "PUT":
					Address.name = self._mData.get('name',Address.name)
					Address.street = self._mData.get('street',Address.street)
					# Address.street2 = self._mData.get('street2',Address.street2)
					Address.zip = self._mData.get('zip',Address.zip)
					Address.city = self._mData.get('city',Address.city)
					Address.phone = self._mData.get('phone',Address.phone)
					try:
						if self._mData.get("state_id"):
							if request.env['res.country.state'].sudo().browse(int(self._mData["state_id"])).exists():
								Address.state_id = int(self._mData["state_id"])
						if self._mData.get("country_id"):
							if request.env['res.country'].sudo().browse(int(self._mData["country_id"])).exists():
								Address.country_id = int(self._mData["country_id"])
						result = {'message':'Updated successfully.'}
					except Exception as e:
						result = {'success':False, 'message':'Error: Invalid Data'}
				elif request.httprequest.method == "DELETE":
					if response.get('customerId') != address_id:
						Address.active = False
						result = {'message':'Deleted successfully.'}
					else:
						result = {'success':False, 'message':_('Error: You can`t delete Billing Address.')}
			else:
				result = {'success':False, 'message':'Address not found !!!'}
			response.update(result)
		return self._response('address', response)
	@route('/mobikul/my/account', csrf=False, type='http', auth="none", methods=['POST'])
	def getMyAccount(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner:
				result = {}
				result['data'] = {
				'name': {'required':True, 'label':_("Your name"), 'value':Partner.name or ""},
				'email': {'required':True, 'readonly':True, 'label':_("Email"), 'value':Partner.email or ""},
				'phone': {'label':_("Phone"), 'value':Partner.phone or ""},
				'street': {'label':_("Street"), 'value':Partner.street or ""},
				'street2': {'label':_("Street2"), 'value':Partner.street2 or ""},
				'city': {'label':_("City"), 'value':Partner.city or ""},
				'zip': {'label':_("Zip / Postal Code"), 'value':Partner.zip or ""},
				'country_id': {'label':_("Country"), 'value':Partner.country_id and Partner.country_id.id or ""},
				'state_id': {'label':_("State"), 'value':Partner.state_id and Partner.state_id.id or ""},
				}
			else:
				result = {'success':False, 'message':'Account not found !!!'}
			response.update(result)
		return self._response('account', response)
	@route('/mobikul/localizationData', csrf=False, type='http', auth="none", methods=['POST'])
	def getLocalizationData(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			StateObj = request.env['res.country.state'].sudo()
			countries = request.env['res.country'].sudo().search_read([], fields=['name','state_ids'])
			if countries:
				result = {'countries':[]}
				state_ids = []
				for country in countries:
					states = []
					if country['state_ids']:
						states = StateObj.search_read([('id','in',country['state_ids'])], fields=['name'])
					result['countries'].append({
							'id':country['id'],
							'name':country['name'],
							'states':states,
							})
			else:
				result = {'success':False, 'message':'Account not found !!!'}
			response.update(result)
		return self._response('account', response)
	@route('/mobikul/search', csrf=False, type='http', auth="none", methods=['POST'])
	def getSearchData(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		Mobikul = request.env['mobikul'].sudo()
		if self.auth:
			result = Mobikul.authenticate(self._lcred, True, self._sLogin, context={'base_url':self.base_url})
			response.update(result)
		if response.get('success'):
			self._mData.update(response.get('local',{}))
			result = Mobikul.fetch_products(**self._mData)
			response.update(result)
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				response['wishlist'] = self._website_Wishlist(response.get('customerId'))
		return self._response('search', response)
	def _website_Wishlist(self, customer_id, product_id=False):
		result = []
		wishlists = request.env['product.wishlist'].sudo().search([('partner_id','=',customer_id)])
		for wishlist in wishlists:
			result.append(wishlist.product_id.id)
		return result
	@route('/mobikul/template/', csrf=False, type='http', auth="none", methods=['POST'])
	def getTemplateData(self, template_id, **kwargs):
		response = self._authenticate(False, **kwargs)
		if self.auth:
			result = request.env['mobikul'].sudo().authenticate(self._lcred, True, self._sLogin, context={'base_url':self.base_url})
			response.update(result)
		if response.get('success'):
			wishlist = []
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				wishlist = self._website_Wishlist(response.get('customerId',0))
			TemplateObj = request.env['product.template'].sudo()
			Template = TemplateObj.search([('id','=',template_id)])
			if Template:
				result = {
					'templateId'	:Template.id,
					'name'			:Template.name or "",
					'attributes'	:[],
					"images": []
				}
				local = response.get('local',{})
				if response.get('addons',{}).get('review'):
					result.update({
						'avg_rating':Template.avg_review(),
						'total_review':len(Template.fetch_active_review(Template.id))
						})
				if response.get('addons',{}).get('odoo_marketplace'):
					if Template.marketplace_seller_id and Template.marketplace_seller_id.website_published:
						result.update({
							'seller_info':{
											'seller_profile_url'	:"/myTemplateseller/%s"%Template.marketplace_seller_id.id,
											'marketplace_seller_id'	:Template.marketplace_seller_id.id,
											'seller_name'			:Template.marketplace_seller_id.name,
											'seller_profile_image'	: self.get_marketplace_image_url(self.base_url, 'res.partner', Template.marketplace_seller_id.id,'profile_image'),
											'average_rating'		: Template.marketplace_seller_id.avg_review(),
											'total_reviews'			:len(Template.marketplace_seller_id.seller_review_ids.filtered(lambda r: (r.active == True and r.state == "pub"))),
											'message'				:str(Template.marketplace_seller_id.total_active_recommendation()[1])+" positive feedback (%s ratings)"%Template.marketplace_seller_id.avg_review()
											}
							})
					else:
						result.update({
							'seller_info': None
							})
				for im in Template.product_image_ids:
					result['images'].append(_get_image_url(self.base_url, 'product.image', im.id,'image'))
				for ali in Template.attribute_line_ids:
					temp = {
						"name":ali.attribute_id.name or "",
						"attributeId":ali.attribute_id.id,
						"type":ali.attribute_id.type,
						"newVariant":ali.attribute_id.create_variant,
						"values":[]
						}
					for v in ali.value_ids:
						temp["values"].append({
							"name":v.name or "",
							"valueId":v.id,
							"htmlCode":v.html_color or "",
							"newVariant":ali.attribute_id.create_variant,
							})
					result['attributes'].append(temp)
				if Template.product_variant_count > 1:
					result.update({
					'priceUnit'		:_displayWithCurrency(local.get('lang_obj'),Template.product_variant_id.lst_price, local.get('currencySymbol'), local.get('currencyPosition')),
					'priceReduce'	:Template.product_variant_id.price < Template.product_variant_id.lst_price and _displayWithCurrency(local.get('lang_obj'),Template.product_variant_id.price, local.get('currencySymbol'), local.get('currencyPosition')) or "",
					'productId'		:Template.product_variant_id.id,
					'productCount'	:Template.product_variant_count,
					'description'	:Template.product_variant_id.description_sale or "",
					'thumbNail'		:_get_image_url(self.base_url, 'product.product', Template.product_variant_id.id,'image'),
					'images'		:[_get_image_url(self.base_url, 'product.product', Template.product_variant_id.id,'image')],
					'variants'	:[]
					})
					for var in Template.product_variant_ids:
						temp = {
							"productId":var.id,
							'images':[_get_image_url(self.base_url, 'product.product', var.id,'image')],
							'priceReduce':var.price < var.lst_price and _displayWithCurrency(local.get('lang_obj'),var.price, local.get('currencySymbol'), local.get('currencyPosition')) or "",
							'priceUnit':_displayWithCurrency(local.get('lang_obj'),var.lst_price, local.get('currencySymbol'), local.get('currencyPosition')),
							"combinations":[],
							"addedToWishlist":var.id in wishlist,
							}
						for avl in var.attribute_value_ids:
							temp["combinations"].append({
									"valueId":avl.id,
									"attributeId":avl.attribute_id and avl.attribute_id.id,
								})
						result['variants'].append(temp)
				else:
					result.update({
					'priceUnit'		:_displayWithCurrency(local.get('lang_obj'),Template.lst_price, local.get('currencySymbol'), local.get('currencyPosition')),
					'priceReduce'	:Template.price < Template.lst_price and _displayWithCurrency(local.get('lang_obj'),Template.price, local.get('currencySymbol'), local.get('currencyPosition')) or "",
					'productId'		:Template.product_variant_id and Template.product_variant_id.id or '',
					'productCount'	:Template.product_variant_count,
					'description'	:Template.description_sale or "",
					'thumbNail'		:_get_image_url(self.base_url, 'product.template', Template.id,'image'),
					'images'		:[_get_image_url(self.base_url, 'product.template', Template.id,'image')],
					"addedToWishlist":Template.product_variant_id.id in wishlist
					})
			else:
				result = {'success':False, 'message':'Template not found !!!'}
			response.update(result)
		return self._response('template', response)
	@route(['/mobikul/mycart','/mobikul/mycart/'], csrf=False, type='http', auth="none", methods=['POST','PUT','DELETE'])
	def getMyCart(self, line_id=0, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			result = {}
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner:
				if request.httprequest.method == "POST":
					last_order = Partner.last_website_so_id
					if last_order:
						local = response.get('local',{})
						result = {
						"name":last_order.name,
						"subtotal":{"title":"Subtotal",
									"value":_displayWithCurrency(local.get('lang_obj'),last_order.amount_untaxed, local.get('currencySymbol'), local.get('currencyPosition')),
								},
						"tax":{"title":"Taxes",
									"value":_displayWithCurrency(local.get('lang_obj'),last_order.amount_tax, local.get('currencySymbol'), local.get('currencyPosition')),
							},
						"grandtotal":{"title":"Total",
									"value":_displayWithCurrency(local.get('lang_obj'),last_order.amount_total, local.get('currencySymbol'), local.get('currencyPosition')),
							},
						"items":[]
						}
						for item in last_order.order_line:
							if response.get('addons', {}).get('website_sale_delivery') and item.is_delivery:
								shippingMethod = {
							      	"tax":[tax.name for tax in item.tax_id],
									"name":item.order_id.carrier_id.name,
									"description":item.order_id.carrier_id.website_description or "",
									"shippingId":item.order_id.carrier_id.id,
									"total": _displayWithCurrency(local.get('lang_obj'), item.price_subtotal,
																  local.get('currencySymbol'), local.get('currencyPosition')),
								}
								result.update({"delivery":shippingMethod})
							else:
								temp = {
								"lineId":item.id,
								"templateId":item.product_id and item.product_id.product_tmpl_id.id or "",
								"name":item.product_id and item.product_id.display_name or item.name,
								"thumbNail":_get_image_url(self.base_url, 'product.product', item.product_id and item.product_id.id or "",'image'),
								"priceReduce":item.price_reduce < item.price_unit and _displayWithCurrency(local.get('lang_obj'),item.price_reduce, local.get('currencySymbol'), local.get('currencyPosition')) or "",
								"priceUnit":_displayWithCurrency(local.get('lang_obj'),item.price_unit, local.get('currencySymbol'), local.get('currencyPosition')),
								"qty":item.product_uom_qty,
								"total":_displayWithCurrency(local.get('lang_obj'),item.price_subtotal, local.get('currencySymbol'), local.get('currencyPosition')),
								"discount":item.discount and "(%d%% OFF)"%item.discount or "",
								}
								result['items'].append(temp)
						if not len(result['items']):
							result['message'] = _('Your Shopping Bag is empty.')
					else:
						result = {'message':_('Your Shopping Bag is empty.')}
				else:
					OrderLineObj = request.env['sale.order.line'].sudo()
					OrderLine = OrderLineObj.search([('id','=',line_id)])
					if OrderLine:
						if request.httprequest.method == "PUT":
							result = {'message':'Updated successfully.'}
							if self._mData.get('set_qty'):
								OrderLine.product_uom_qty = self._mData.get('set_qty')
							elif self._mData.get('add_qty'):
								OrderLine.product_uom_qty +=int(self._mData['add_qty'])
							else:
								result = {'message':'Wrong request.'}
						elif request.httprequest.method == "DELETE":
							try:
								result = {'message':'%s'%(OrderLine.product_id and OrderLine.product_id.name or OrderLine.name)+_(' was removed from your Shopping Bag.')}
								OrderLine.unlink()
							except:
								result = {'message':'Please try again after some time.'}
						else:
							result = {'message':'Wrong request.'}
					else:
						result = {'message':'No matching product found !!!'}
			else:
				result = {'success':False, 'message':'Account not found !!!'}
			response.update(result)
		return self._response('cart', response)
	@route('/mobikul/mycart/setToEmpty', csrf=False, type='http', auth="none", methods=['DELETE'])
	def setToEmpty(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			result = {}
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner:
				last_order = Partner.last_website_so_id
				if last_order:
					try:
						result = {'message':_('Your Shopping Bag has been set to Empty.')}
						last_order.order_line.unlink()
						result['cartCount'] = last_order.cart_count
					except:
						result = {'message':'Please try again after some time.'}
				else:
					result = {'message':_('Your Shopping Bag is already empty.')}
			else:
				result = {'success':False, 'message':'Account not found !!!'}
			response.update(result)
		return self._response('setToEmpty', response)
	@route('/mobikul/mycart/addToCart', csrf=False, type='http', auth="none", methods=['POST'])
	def addToCart(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			result = {}
			Mobikul = request.env['mobikul'].sudo()
			result = Mobikul.add_to_cart(response.get('customerId'),self._mData.get("productId"),self._mData.get("set_qty"),self._mData.get("add_qty"),response)
			response.update(result)
		return self._response('addToCart', response)
	@route('/mobikul/paymentAcquirers', csrf=False, type='http', auth="none", methods=['POST'])
	def getPaymentAcquirer(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			result = {}
			AcquirerObj = request.env['payment.acquirer'].sudo()
			Acquirers = AcquirerObj.search_read([('is_mobikul_available','=',1),('mobikul_reference_code','in',AQUIRER_REF_CODES)], fields=['name','pre_msg','mobikul_reference_code'])
			if Acquirers:
				result = {'acquirers':Acquirers}
				for index,value in enumerate(result['acquirers']):
					result['acquirers'][index]['thumbNail'] = _get_image_url(self.base_url, 'payment.acquirer', result['acquirers'][index]['id'],'image')
					result['acquirers'][index]['description'] = remove_htmltags(result['acquirers'][index].pop('pre_msg')) or ""
					result['acquirers'][index]['code'] = result['acquirers'][index].pop('mobikul_reference_code') or ""
			else:
				result = {'success':False, 'message':'No Active Payment methods found.'}
			response.update(result)
		return self._response('paymentAcquirer', response)
	def _computePayfortSdkSignature(self,values,Acquirer):
		keys = values.keys()
		keys.sort()
		sign = ""
		for k in keys:
			sign = sign + k + "=" +str(values[k])
		sign = Acquirer.request_phrase + sign + Acquirer.request_phrase
		sha256sign = hashlib.sha256(sign.encode()).hexdigest()
		return sha256sign
	def _computePayfortPaymentToken(self,val,Acquirer):
		token_url = PAYFORT_SDK_ENV_URL.get(Acquirer.environment)
		result = requests.post(url= token_url, json=val)
		return  result.json()
	def _computePayfortSdkToken(self,Acquirer,Transaction,order_name):
		if self._mData.get('device_id'):
			val = {
					"service_command":"SDK_TOKEN",
					"access_code":Acquirer.access_code,
					"merchant_identifier":Acquirer.merchant_identifier,
					"language":"en",
					"device_id":self._mData.get('device_id'),
				}
			val['signature'] = self._computePayfortSdkSignature(val,Acquirer)
			sdkToken = self._computePayfortPaymentToken(val,Acquirer)
			return {
					'status':True,
					'paymentReference':_get_next_reference(order_name),
					'code':'PAYFORT',
					'auth':True,
					"sdkToken":sdkToken
					}
		else:
			return {
					'status':False,
					'message': "No Device Id Found !!"
					}
	def _getAquirerCredentials(self, order_name, Acquirer,response):
		if Acquirer.mobikul_reference_code == 'COD':
			return {'status':True,'code':'COD','auth':False}
		elif Acquirer.mobikul_reference_code == 'STRIPE_W':
			Transaction = request.env['payment.transaction'].sudo()
			return {'status':True,'paymentReference':Transaction.get_next_reference(order_name),'code':'STRIPE','auth':True,'secret_key':Acquirer.stripe_checkout_client_secret_key,'publishable_key':Acquirer.stripe_checkout_publishable_key}
		elif Acquirer.mobikul_reference_code == 'PAYFORT':
			Transaction = request.env['payment.transaction'].sudo()
			sdkTokenResponse = self._computePayfortSdkToken(Acquirer,Transaction,order_name)
			return sdkTokenResponse
		elif Acquirer.mobikul_reference_code == 'STRIPE_E':
			Transaction = request.env['payment.transaction'].sudo()
			return {'status':True,'paymentReference':Transaction.get_next_reference(order_name),'code':'STRIPE','auth':True,'secret_key':Acquirer.stripe_secret_key,'publishable_key':Acquirer.stripe_publishable_key}
		elif Acquirer.mobikul_reference_code == '2_CHECKOUT':
			Transaction_refNo = request.env['payment.transaction'].sudo().get_next_reference(order_name)
			paymentUrl = "%sapp/payment/2checkout?reference=%s&acquirer_id=%s"%(self.base_url,order_name,Acquirer.id)
			return {'status':True,'paymentUrl':paymentUrl,'code':'2_CHECKOUT','auth':True,"acquire":Acquirer.name}
		elif Acquirer.mobikul_reference_code == 'PAYFORT_SADAD':
			Transaction_refNo = request.env['payment.transaction'].sudo().get_next_reference(order_name)
			paymentUrl = "%sapp/payment/payfortsadad?reference=%s&acquirer_id=%s&sadad_olp="%(self.base_url,order_name,Acquirer.id)
			return {'status':True,'paymentUrl':paymentUrl,'code':'PAYFORT_SADAD','auth':True,"acquire":Acquirer.name}
		else:
			return {'status':False,'message':_('Payment Mode not Available.')}
	def _getAquirerState(self, Acquirer, status=False):
		if Acquirer.mobikul_reference_code in ['COD']:
			return "pending"
		elif Acquirer.mobikul_reference_code in ['STRIPE_W','STRIPE_E']:
			return STATUS_MAPPING['STRIPE'].get(status,'pending')
		else:
			return "pending"
	def _orderReview(self,user,response,Acquirer):
		last_order = user.partner_id.last_website_so_id
		if last_order and len(last_order.order_line):
			local = response.get('local',{})
			if self._mData.get('shippingAddressId'):
				last_order.partner_shipping_id = int(self._mData.get('shippingAddressId'))
			# add shippigMethod
			if response.get('addons', {}).get('website_sale_delivery') and self._mData.get("shippingId"):
				last_order.sudo()._check_carrier_quotation( force_carrier_id=int(self._mData.get("shippingId")))
			result = {
			"name":last_order.name,
			"billingAddress": last_order.partner_invoice_id._display_address(),
			"shippingAddress": last_order.partner_shipping_id._display_address(),
			"paymentAcquirer": Acquirer.name,
			# "paymentPreMessage": Acquirer.pre_msg,
			"subtotal":{"title":"Subtotal",
						"value":_displayWithCurrency(local.get('lang_obj'),last_order.amount_untaxed, local.get('currencySymbol'), local.get('currencyPosition')),
					},
			"tax":{"title":"Taxes",
						"value":_displayWithCurrency(local.get('lang_obj'),last_order.amount_tax, local.get('currencySymbol'), local.get('currencyPosition')),
				},
			"grandtotal":{"title":"Total",
						"value":_displayWithCurrency(local.get('lang_obj'),last_order.amount_total, local.get('currencySymbol'), local.get('currencyPosition')),
				},
			"amount":last_order.amount_total,
			"currency":last_order.pricelist_id.currency_id.name or "",
			"items":[],
			}
			for item in last_order.order_line:
				if response.get('addons', {}).get('website_sale_delivery') and item.is_delivery:
					shippingMethod = {
				      	"tax":[tax.name for tax in item.tax_id],
						"name":item.order_id.carrier_id.name,
						"description":item.order_id.carrier_id.website_description or "",
						"shippingId":item.order_id.carrier_id.id,
						"total": _displayWithCurrency(local.get('lang_obj'), item.price_subtotal,
													  local.get('currencySymbol'), local.get('currencyPosition')),
					}
					result.update({"delivery":shippingMethod})
				else:
					temp = {
					"lineId":item.id,
					"templateId":item.product_id and item.product_id.product_tmpl_id.id or "",
					"name":item.product_id and item.product_id.display_name or item.name,
					"thumbNail":_get_image_url(self.base_url, 'product.product', item.product_id and item.product_id.id or "",'image'),
					"priceReduce":item.price_reduce < item.price_unit and _displayWithCurrency(local.get('lang_obj'),item.price_reduce, local.get('currencySymbol'), local.get('currencyPosition')) or "",
					"priceUnit":_displayWithCurrency(local.get('lang_obj'),item.price_unit, local.get('currencySymbol'), local.get('currencyPosition')),
					"qty":item.product_uom_qty,
					"total":_displayWithCurrency(local.get('lang_obj'),item.price_subtotal, local.get('currencySymbol'), local.get('currencyPosition')),
					"discount":item.discount and "(%d%% OFF)"%item.discount or "",
					}
					result['items'].append(temp)
			result['paymentData'] = self._getAquirerCredentials(last_order.name, Acquirer,response)
			result['paymentData'].update({'customer_email':last_order.partner_id.email})
			last_order.payment_acquirer_id = Acquirer.id
		else:
			result = {'success':False, 'message':_('Add some products in order to proceed.')}
		return result
	@route('/mobikul/orderReviewData', csrf=False, type='http', auth="none", methods=['POST'])
	def getOrderReviewData(self, **kwargs):
		Mobikul = request.env['mobikul'].sudo()
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			result = {}
			Acquirer = request.env['payment.acquirer'].sudo().browse(int(self._mData.get('acquirerId')))
			if Acquirer:
				UserObj = request.env['res.users'].sudo()
				user = UserObj.browse(response.get('userId',0))
				if user:
					if response.get('addons',{}).get('email_verification') and Mobikul.email_verification_defaults().get('restrict_unverified_users'):
						if user.wk_token_verified:
							result = self._orderReview(user,response,Acquirer)
						else:
							result = {'success':False,'message':_("You can't place your order, please verify your account") }
					else:
						result = self._orderReview(user,response,Acquirer)
				else:
					result = {'success':False, 'message':_('Account not found !!!')}
			else:
				result = {'success':False, 'message':_('No Payment methods found with given id.')}
			response.update(result)
		return self._response('orderReviewData', response)
	@route('/mobikul/placeMyOrder', csrf=False, type='http', auth="none", methods=['POST'])
	def placeMyOrder(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		result={}
		if response.get('success'):
			result = self.placeOrder(response.get('customerId'))
		response.update(result)
		return self._response('placeMyOrder', response)
	def _sendPaymentAcknowledge(self,last_order,Partner,customerId,result):
		if last_order.payment_tx_id.state != 'error':
			last_order.with_context(send_email=True).action_confirm()
			Partner.last_website_so_id = False
			self._pushNotification(self._mData.get("fcmToken", ""), condition='orderplaced',
							   customer_id=customerId)
			result.update({
			'url':"/mobikul/my/order/%s"%last_order.id,
			'name':last_order.name,
			'cartCount': 0,
			'success': True,
			'message': 'Your order' + ' %s ' % (last_order.name) + 'has been placed successfully.',
			})
			if last_order.payment_tx_id.state in ['pending','draft']:
				result.update({'txn_msg': remove_htmltags(last_order.payment_acquirer_id.pending_msg)})
			elif last_order.payment_tx_id.state == 'done':
				result.update({'txn_msg':remove_htmltags(last_order.payment_acquirer_id.done_msg)})
			elif last_order.payment_tx_id.state == 'cancel':
				result.update({'txn_msg':remove_htmltags(last_order.payment_acquirer_id.cancel_msg)})
			else:
				result.update({'txn_msg':'No transaction state found..'})
		else:
			result.update({
			'success': False,
			'message': "ERROR",
			'txn_msg':last_order.payment_acquirer_id.error_msg or "ERROR"
			})
		return result
	def placeOrder(self,customerId):
		result = {}
		PartnerObj = request.env['res.partner'].sudo()
		Partner = PartnerObj.browse(customerId)
		if Partner:
			last_order = Partner.last_website_so_id
			if last_order:
				if last_order.payment_acquirer_id:
					if last_order.payment_acquirer_id.name in ["2Checkout","PAYFORT_SADAD"]:
						result1 = {
						'paymentReference':"%s"%last_order.payment_tx_id.reference,
						'paymentStatus':"%s"%last_order.payment_tx_id.state,
						}
						result = self._sendPaymentAcknowledge(last_order,Partner,customerId,result)
						result.update(result1)
					else:
						Transaction = request.env['payment.transaction'].sudo()
						tx_values = {
							'acquirer_id': last_order.payment_acquirer_id.id,
							'type': 'form',
							'amount': last_order.amount_total,
							'currency_id': last_order.pricelist_id.currency_id.id,
							'partner_id': last_order.partner_id.id,
							'partner_country_id': last_order.partner_id.country_id.id,
							'reference': self._mData.get('paymentReference',Transaction.get_next_reference(last_order.name)), #ptptpt
							'sale_order_id': last_order.id,
							'state': self._getAquirerState(last_order.payment_acquirer_id,self._mData.get('paymentStatus')), #ptptpt
							'acquirer_reference': 'MOBIKUL',
						}
						tx = Transaction.create(tx_values)
						# update quotation
						last_order.write({
							'payment_tx_id': tx.id,
						})
						result = self._sendPaymentAcknowledge(last_order,Partner,customerId,{})
				else:
					result = {'success':False, 'message':_('No Payment Method found.')}
			else:
				result = {'success':False, 'message':_('Add some products in order to proceed.')}
		else:
			result = {'success':False, 'message':('Account not found !!!')}
		return result
	@route('/mobikul/saveMyDetails', csrf=False, type='http', auth="none", methods=['POST'])
	def saveMyDetails(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			result = {}
			Userobj = request.env['res.users'].sudo()
			User = Userobj.browse(response.get('userId'))
			if User:
				result['message'] = _("Updated Successfully.")
				if self._mData.get('image'):
					try:
						User.write({'image':self._mData['image']})
						result['customerProfileImage'] = _get_image_url(self.base_url, 'res.partner', User.partner_id.id, 'image')
					except Exception as e:
						result['message'] = _("Please try again later")+" %r"%e
				if self._mData.get('name'):
					User.write({'name':self._mData['name']})
				if self._mData.get('password'):
					User.write({'password':self._mData['password']})
			else:
				result = {'success':False, 'message':_('Account not found !!!')}
			response.update(result)
		return self._response('saveMyDetails', response)
	def _tokenUpdate(self, customer_id=False):
		FcmRegister = request.env['fcm.registered.devices'].sudo()
		already_registered = FcmRegister.search([('device_id','=',self._mData.get("fcmDeviceId"))])
		if already_registered:
			already_registered.write({'token':self._mData.get("fcmToken"),'customer_id':customer_id})
		else:
			FcmRegister.create({
				'token':self._mData.get("fcmToken",""),
				'device_id':self._mData.get("fcmDeviceId",""),
				'description':"%r"%self._mData,
				'customer_id':customer_id,
				})
		return True
	def _pushNotification(self, token, condition='signup', customer_id=False):
		notifications = request.env['mobikul.push.notification.template'].sudo().search([('condition','=',condition)])
		for n in notifications:
			n._send({'to':token},customer_id)
		return True
	@route('/mobikul/registerFcmToken', csrf=False, type='http', auth="none", methods=['POST'])
	def registerFcmToken(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			customer_id = False
			if self._mData.get("customerId") and request.env['res.partner'].sudo().browse(int(self._mData["customerId"])).exists():
				customer_id = int(self._mData["customerId"])
			self._tokenUpdate(customer_id=customer_id)
			response.update({'message':_('Request completed !')})
		return self._response('registerFcmToken', response)
	@route('/mobikul/notificationMessages', csrf=False, type='http', auth="none", methods=['POST'])
	def getNotificationMessages(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			fields = ['id','name','create_date','title','subtitle','body','banner','icon','period','datatype','is_read']
			domain = [('customer_id','=',Partner.id)]
			Message = request.env['mobikul.notification.messages'].sudo()
			notification_message = Message.search_read(domain, limit=self._mData.get('limit',response.get('itemsPerPage',5)), offset=self._mData.get('offset',0),  order="id desc", fields=fields)
			for msg in notification_message:
				msg['name'] = msg['name'] or ""
				msg['title'] = msg['title'] or ""
				msg['subtitle'] = msg['subtitle'] or ""
				msg['body'] = msg['body'] or ""
				msg['icon'] = _get_image_url(self.base_url, 'mobikul.notification.messages', msg['id'] ,'icon')
				msg['banner'] = _get_image_url(self.base_url, 'mobikul.notification.messages', msg['id'] ,'banner')
			result = {'all_notification_messages':notification_message}
			response.update(result)
		return self._response('notificationMessages', response)
	@route('/mobikul/notificationMessage/', csrf=False, type='http', auth="none",  methods=['POST','PUT','DELETE'])
	def getNotificationMessageDetails(self, message_id, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			MessageObj = request.env['mobikul.notification.messages'].sudo()
			message = MessageObj.search([('id','=',message_id),('customer_id','=',response.get('customerId'))])
			if message:
				if request.httprequest.method == "POST":
					message.is_read = True
					result = {
					'id':message.id,
					'name':message.name or "",
					'create_date':message.create_date ,
					'title':message.title or "",
					'subtitle':message.subtitle or "",
					'body':message.body or "",
					'icon':_get_image_url(self.base_url, 'mobikul.notification.messages', message.id ,'icon'),
					'banner':_get_image_url(self.base_url, 'mobikul.notification.messages', message.id ,'banner'),
					'period':message.period,
					'is_read':message.is_read,
					'datatype':message.datatype,
					'success':True,
					'message':'Successfull'
					}
				elif request.httprequest.method == "DELETE":
					message.active = False
					result = {'success':True, 'message':_('Deleted Successfully')}
				elif request.httprequest.method == "PUT":
					message.is_read = self._mData.get('is_read',message.is_read)
					result = {'success':True, 'message':_('Updated Successfully')}
			else:
				result = {'success':False, 'message':_('Message not Found')}
			response.update(result)
		return self._response('notificationMessageDetails', response)
# Wishlist api is according website_sale_wishlist
	@route('/mobikul/my/wishlists', csrf=False, type='http', auth="none", methods=['POST'])
	def getMyWishlists(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				wishlists=[]
				Partner = request.env['res.partner'].sudo().browse(response.get('customerId'))
				local = response.get('local',{})
				for wishlist in Partner.wishlist_ids:
					if wishlist.product_id:
						product_detail = {
							'id':wishlist.id,
							"name": wishlist.product_id.name,
							"thumbNail": _get_image_url(self.base_url, 'product.product', wishlist.product_id.id, 'image'),
							# "priceReduce":Product.price_reduce < Product.price_unit and _displayWithCurrency(local.get('lang_obj'),Product.price_reduce, local.get('currencySymbol'), local.get('currencyPosition')) or "",
							"priceUnit":_displayWithCurrency(local.get('lang_obj'),wishlist.product_id.lst_price, local.get('currencySymbol'), local.get('currencyPosition')),
							# "productId": wishlist.product_id.product_tmpl_id.id,
							"productId": wishlist.product_id.id,
						}
						wishlists.append(product_detail)
				result = {
				'success':True,
				"wishLists":wishlists,
				'message':'SUCCESS'
				}
			else:
				result = {'success':False, 'message':'Wishlist is not Active !!!'}
			response.update(result)
		return self._response('myWishlists', response)
	@route('/my/removeWishlist/', csrf=False, type='http', auth="none",  methods=['DELETE'])
	def removeWishlist(self, wishlist_id, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				try:
					wishlist = request.env['product.wishlist'].sudo().search([('id','=',wishlist_id)])
					if wishlist:
						wishlist.unlink()
						result={'success':True,
								'message':'Item removed'
								}
					else:
						result={
							'success':False,
							'message':'Not Found',
							}
				except Exception as e:
					result={
							'success':False,
							'message':'Please try again later',
							'detail':'Error Details: %r'%e,
						}
			else:
				result = {'success':False, 'message':'Wishlist is not Active !!!'}
			response.update(result)
		return self._response('removeWishlist', response)
	@route('/my/removeFromWishlist/', csrf=False, type='http', auth="none",  methods=['DELETE'])
	def removeFromWishlist(self, product_id, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				try:
					wishlist = request.env['product.wishlist'].sudo().search([('product_id','=',product_id),('partner_id','=',response.get('customerId'))])
					if wishlist:
						wishlist.unlink()
						result={'success':True,
								'message':'Item removed'
								}
					else:
						result={
							'success':False,
							'message':'Not Found',
							}
				except Exception as e:
					result={
							'success':False,
							'message':'Please try again later',
							'detail':'Error Details: %r'%e,
						}
			else:
				result = {'success':False, 'message':'Wishlist is not Active !!!'}
			response.update(result)
		return self._response('removeFromWishlist', response)
	@route('/my/addToWishlist', csrf=False, type='http', auth="none", methods=['POST'])
	def addToWishlist(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				result = self.add2Ws(response.get('customerId'), self._mData.get("productId"))
			else:
				result = {'success':False, 'message':'Wishlist is not Active !!!'}
			response.update(result)
		return self._response('addToWishlist', response)
	def add2Ws(self, customer_id, product_id):
		Mobikul = request.env['mobikul'].sudo().search([], limit=1)
		wishlistObj = request.env['product.wishlist'].sudo()
		p = request.env['product.product'].sudo().browse(product_id)
		try:
			wishlistObj._add_to_wishlist(Mobikul.pricelist_id.id , Mobikul.currency_id.id , Mobikul.website_id.id, p.website_price , product_id, partner_id=customer_id, session=False)
			result = {'success':True,
						'message':"Item moved to Wishlist"
					}
		except Exception as e:
			result = {
				'success':False,
				'message':'Please try again later',
				'detail':'Error Details: %r'%e,
				}
		return result
	@route('/my/wishlistToCart', csrf=False, type='http', auth="none", methods=['POST'])
	def moveWishlistToCart(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				wishlistObj = request.env['product.wishlist'].sudo()
				wishlist = wishlistObj.search([('id','=',self._mData.get("wishlistId")),('partner_id','=',response.get('customerId'))])
				result = request.env['mobikul'].sudo().add_to_cart(response.get('customerId'),wishlist.product_id.id, False, self._mData.get("add_qty",1), response)
				if result.get("success"):
					wishlist.unlink()
					result = {'success':True, 'message':'Item moved to Bag'}
				else:
					result = {'success':False, 'message':'Please try again later'}
			else:
				result = {'success':False, 'message':'Wishlist is not Active !!!'}
			response.update(result)
		return self._response('moveWishlistToCart', response)
	@route('/my/cartToWishlist', csrf=False, type='http', auth="none", methods=['POST'])
	def moveCartToWishlist(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('website_sale_wishlist') and response.get('customerId'):
				OrderLine = request.env['sale.order.line'].sudo().search([('id','=',self._mData.get('line_id'))])
				if OrderLine:
					result = self.add2Ws(response.get('customerId'), OrderLine.product_id.id)
					if result.get("success"):
						OrderLine.unlink()
				else:
					result = {'success':False, 'message':'Order not found'}
			else:
				result = {'success':False, 'message':'Wishlist is not Active !!!'}
			response.update(result)
		return self._response('moveCartToWishlist', response)
	# @route('/mobikul/my/reviewList', csrf=False, type='http', auth="none", methods=['GET'])
	# def getReviewList(self, **kwargs):
	# 	response = self._authenticate(True, **kwargs)
	# 	if response.get('success'):
	# 		if response.get('addons',{}).get('review') and response.get('customerId'):
	# 			result = {}
	# 			PartnerObj = request.env['res.partner'].sudo()
	# 			Partner = PartnerObj.browse(response.get('customerId'))
	# 			if Partner:
	# 				reviewList = []
	# 				pass
	# 				# write the logic for get customer review
	# 				result = {'all_ReviewList':reviewList}
	# 			else:
	# 				result = {'success':False, 'message':'Account not found !!!'}
	# 		else:
	# 			response.update({'success':False, 'message':'Review Module not install !!!'})
	# 		response.update(result)
	# 	return self._response('reviewList', response)
	@route('/product/reviews', csrf=False, type='http', auth="none", methods=['POST'])
	def getProductReview(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('review'):
				product_reviews = []
				reviewObj = request.env['user.review'].sudo()
				domain = [('template_id','=',self._mData.get('template_id')),('state','=','pub')]
				fields =['customer','customer_image','email','likes','dislikes','rating','title','msg','create_date']
				product_reviews = reviewObj.search_read(domain, limit=self._mData.get('limit',response.get('itemsPerPage',5)), offset=self._mData.get('offset',0),  order="id desc", fields=fields)
				for review in product_reviews:
					review['customer_image'] =  _get_image_url(self.base_url, 'user.review', review['id'] ,'customer_image')
					review['create_date'] =  request.env['mobikul'].sudo().easy_date(review['create_date'])
				result = {'product_reviews':product_reviews,"reviewCount":len(product_reviews)}
			else:
				result = {'success':False, 'message':_('Review Module not install !!!')}
			response.update(result)
		return self._response('ProductReview', response)
	@route('/my/saveReview', csrf=False, type='http', auth="none", methods=['POST'])
	def addReview(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		Mobikul = request.env['mobikul'].sudo()
		if response.get('success'):
			result = {}
			if response.get('addons',{}).get('review') and response.get('customerId'):
				Partner = request.env['res.partner'].sudo().browse(response.get('customerId'))
				if Partner:
					vals={
						"title":self._mData.get("title"),
						'msg':self._mData.get("detail"),
						"rating": self._mData.get("rate"),
						'partner_id':Partner.id,
						"template_id": self._mData.get("template_id"),
						"customer":Partner.name,
						"email":Partner.email,
						"customer_image":Partner.image
					}
					try:
						request.env['user.review'].sudo().create(vals)
						if Mobikul.review_defaults().get('auto_publish'):
							result = {'success':True, 'message':_('Thanks for your review.')}
						else:
							result = {'success':True, 'message': Mobikul.review_defaults().get('message_when_unpublish')}
					except Exception as e:
							result = {'success':False, 'message':_('Please try again later')}
				else:
					result = {'success':False, 'message':_('Account not found !!!')}
			else:
				response.update({'success':False, 'message':_('Review Module not install !!!')})
			response.update(result)
		return self._response('addReview', response)
	@route('/send/verifyEmail', csrf=False, type='http', auth="none", methods=['POST'])
	def verifyEmail(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		Mobikul = request.env['mobikul'].sudo()
		if response.get('success'):
			result={}
			if response.get('addons',{}).get('email_verification') and Mobikul.email_verification_defaults().get('restrict_unverified_users'):
				UserObj = request.env['res.users'].sudo()
				user = UserObj.search([('id','=',response.get('userId'))])
				if not user.wk_token_verified:
					UserObj.send_verification_email(user.id)
					response['message']=_("Verification email sent successfully.")
					response['success'] = True
				else:
					response['message']=_("Email already verified.")
					response['success'] = False
			else:
				response.update({'success':False, 'message':_('Email Verification Module not install !!!')})
			response.update(result)
		return self._response('verifyEmail', response)
	@route('/review/likeDislike', csrf=False, type='http', auth="none", methods=['POST'])
	def addLikeDislike(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		likeDislikeObj = request.env['review.like.dislike'].sudo()
		# it assume that review module is installed
		if response.get('success') and self._mData.get("review_id"):
			review = request.env['user.review'].sudo().browse(self._mData.get("review_id"))
			if review:
				ld_exist = likeDislikeObj.search([("customer_id","=",response.get('userId')),("review_id","=",review.id)])
				vals={
					"customer_id":response.get('userId'),
					'like':self._mData.get("ishelpful"),
					"dislike": not self._mData.get("ishelpful"),
					'review_id':review.id,
				}
				if ld_exist:
					try:
						ld_exist.write(vals)
						result = {'success':True, 'message':_('Thank you for your feedback.')}
					except Exception as e:
							result = {'success':False, 'message':_('Please try again later')}
				else:
					try:
						likeDislikeObj.sudo().create(vals)
						result = {'success':True, 'message':_('Thank you for your feedback.')}
					except Exception as e:
							result = {'success':False, 'message':_('Please try again later')}
			else:
				result = {'success':False, 'message':_('Review not found !!!')}
			response.update(result)
		else:
			response["message"] = _("You need to login first !")
		return self._response('addLikeDislike', response)
	@route('/my/Template/seller/', csrf=False, type='http', auth="none",  methods=['GET'])
	def productSellerInfo(self, seller_id, **kwargs):
		response = self._authenticate(False, **kwargs)
		if self.auth:
			result = request.env['mobikul'].sudo().authenticate(self._lcred, True, self._sLogin, context={'base_url':self.base_url})
			response.update(result)
		if response.get('success'):
			if response.get('addons',{}).get('odoo_marketplace'):
				local = response.get('local',{})
				sellerDetail = self.seller_profile_info(seller_id, local)
				if sellerDetail:
					result = {'SellerInfo':sellerDetail,'success':True,'message':_('Seller Found !!!')}
				else:
					result = {'success':False, 'message':_('Seller Not Found !!!')}
			else:
				result = {'success':False, 'message':_('Marketplace is not Active !!!')}
			if response.get('addons',{}).get('wishlist') and response.get('customerId'):
				wishlists = self._myWishlist(response.get('customerId',0))
				result.update({'wishlists':wishlists})
			response.update(result)
		return self._response('productSellerInfo', response)
	def seller_profile_info(self,seller_id, local):
		MobikulObj = request.env['mobikul'].sudo()
		detail = {}
		sellerDetail = request.env['res.partner'].sudo().search([('id','=',seller_id),('seller','=',True)])
		if sellerDetail:
			detail = {
				"seller_id"				:sellerDetail.id,
				'name'					:sellerDetail.name,
				'email'					:sellerDetail.email,
				'average_rating'		: sellerDetail.avg_review(),
				'total_reviews'			:len(sellerDetail.seller_review_ids.filtered(lambda r: (r.active == True and r.state == "pub"))),
				'sales_count'			:sellerDetail.seller_sales_count(),
				'product_count'			:sellerDetail.seller_products_count(),
				'seller_profile_image'	:self.get_marketplace_image_url(self.base_url, 'res.partner', sellerDetail.id, 'profile_image'),
				'seller_profile_banner'	:self.get_marketplace_image_url(self.base_url, 'res.partner', sellerDetail.id,'profile_banner'),
				'create_date'			:sellerDetail.create_date,
				'state'					:sellerDetail.state_id.name or "",
				'country'				:sellerDetail.country_id.name or "",
				'profile_msg'			:remove_htmltags(sellerDetail.profile_msg or "") ,
				'return_policy'			:remove_htmltags(sellerDetail.return_policy or ""),
				'shipping_policy'		:remove_htmltags(sellerDetail.shipping_policy or ""),
			}
			seller_review = []
			reviews = sellerDetail.fetch_active_review2(sellerDetail.id,0,2)
			seller_review = self.getSellerReviewsDetail(reviews)
			detail.update({'seller_reviews':seller_review})
			context = local or {}
			context.update({"domain":"[('marketplace_seller_id','=',%r)]"%sellerDetail.id,
						"order":"create_date desc, id desc",
						"limit":5})
			sellerProducts = MobikulObj.fetch_products(**context)
			detail.update({'sellerProducts':sellerProducts})
		return detail
	def getSellerReviewsDetail(self,reviewsObj):
		reviewsDetail = []
		for review in reviewsObj:
			reviewsDetail.append({
				"create_date":review.create_date,
				"rating":review.rating,
				"not_helpful":review.not_helpful,
				"total_votes":review.total_votes,
				"display_name":review.display_name,
				"message_is_follower":review.message_is_follower,
				"title":review.title,
				"id":review.id,
				"msg":review.msg,
				"helpful":review.helpful,
				"email":review.email,
				"name":review.partner_id.name,
				"image":_get_image_url(self.base_url, 'res.partner', review.partner_id.id,'profile_image'),
			})
		return reviewsDetail
	# view all the product of sellers api "http://192.168.1.86:8010/mobikul/search"
	# {"domain": "[('marketplace_seller_id','=',117)]", "offset": 0, "limit":100}
	@route('/mobikul/marketplace', csrf=False, type='http', auth="none",  methods=['GET'])
	def marketplace(self, **kwargs):
		PartnerObj = request.env['res.partner'].sudo()
		if request.httprequest.headers.get("Login"):
			response = self._authenticate(True, **kwargs)
		else:
			response = self._authenticate(False, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('odoo_marketplace'):
				lst = []
				local = response.get('local',{})
				result = {
					"banner":request.env['website'].sudo().get_mp_config_settings_values().get('landing_page_banner') or self.base_url+"odoo_marketplace/static/src/img/Hero-Banner.png",
					"heading":_("Still Selling Offline? Start Selling Online."),
				}
				sellersObj	= PartnerObj.search([('seller','=',True),('state','=','approved'),('website_published','=',True)],limit=5)
				for seller in sellersObj:
					sellerDetail = self.seller_profile_info(seller.id, local)
					lst.append(sellerDetail)
				result.update({'SellersDetail':lst,'success':True,'message':_('Marketplace page !!!')})
			else:
				result = {'success':False, 'message':_('Marketplace is not Active !!!')}
			response.update(result)
		return self._response('marketplace', response)
	def get_marketplace_image_url(self,base_url, model_name, record_id, field_name, width=0, height=0):
		""" Returns a local url that points to the image field of a given browse record only for marketplace """
		#format of marketplace image url "base_url+/ marketplace / image / 139 / res.partner / profile_banner"
		if base_url and not base_url.endswith("/"):
			base_url = base_url + "/"
		if width or height:
			return '%swebsite/image/%s/%s/%s/%sx%s' % (base_url,model_name,record_id, field_name, width, height)
		else:
			return '%swebsite/image/%s/%s/%s' % (base_url,model_name,record_id, field_name)
	def checkReviewEligibility(self,seller_id,customer_id):
		"""
		this method is responsible for marketplace ['/seller/review/check'] controller
		"""
		sol_objs = request.env["sale.order.line"].sudo().search([("product_id.marketplace_seller_id", "=", seller_id), ("order_id.partner_id", "=", customer_id), ("order_id.state", "in", ["sale", "done"])])
		for_seller_total_review_obj = request.env["seller.review"].sudo().search([('marketplace_seller_id', '=', seller_id), ('partner_id', '=', customer_id)])
		# This code must be used in create of review
		if len(sol_objs.ids) == 0:
			result =  {"success":False,"message" : _("You have to purchase a product of this seller first.")}
		elif len(for_seller_total_review_obj.ids) >= len(sol_objs.ids):
			result = {"success":False,"message" : _("According to your purchase your review limit is over.")}
		else:
			result = {"success":True,"message" : _("Eligible for write a review")}
		return result
	@route('/my/review/seller/', csrf=False, type='http', auth="none",  methods=['GET','POST'])
	def reviewSeller(self, seller_id, **kwargs):
		SellReviewObj = request.env['seller.review'].sudo()
		response = self._authenticate(False, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('odoo_marketplace'):
				seller = request.env['res.partner'].sudo().search([('id','=',seller_id),('seller','=',True)])
				if seller:
					if request.httprequest.method == "GET":
						sellerReviewDetail = SellReviewObj.search([('marketplace_seller_id','=',seller_id),('active','=',True),('state','=','pub')])
						reviewsDetail = self.getSellerReviewsDetail(sellerReviewDetail)
						result = {
							'SellerReview':reviewsDetail,
							"seller_image":self.get_marketplace_image_url(self.base_url, 'res.partner',seller.id,'image'),
							'seller_profile_image': self.get_marketplace_image_url(self.base_url, 'res.partner',seller.id,'profile_image'),
							'sellerReviewCount':len(sellerReviewDetail),
							'success':True,
							'message':_('Seller Found !!!')
						}
					elif request.httprequest.method == "POST":
						result = self.checkReviewEligibility(seller_id,response.get('customerId'))
						if result.get('success'):
							if self._mData.get('msg') and self._mData.get('rating') and self._mData.get('title'):
								review = {
									'msg' : self._mData.get('msg'),
									'rating' : int(self._mData.get('rating')),
									'title' : self._mData.get('title'),
									'marketplace_seller_id' : seller_id,
									"partner_id" : response.get('customerId'),
									}
								review_obj = request.env['seller.review'].sudo().create(review)
								result = {'success':True,'message':_('Review create successfully for seller id')+'%s'%seller_id}
							else:
								result = {'success':False,'message':_('Pass the params properly for create review!!!')}
					else:
						result = {'success':False,'message':_('Wrong Request')}
				else:
					result = {'success':False,'message':_('Seller not Found.')}
			else:
				result = {'success':False, 'message':'Marketplace is not Active !!!'}
			response.update(result)
		return self._response('reviewSeller', response)
	@route(['/mobikul/marketplace/seller/review/vote/'], csrf=False, type='http', auth="none",  methods=['POST'])
	def sellerReviewVote(self, review_id, **kwargs):
		review_help_obj = request.env['review.help'].sudo()
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			if response.get('addons',{}).get('odoo_marketplace'):
				ishelpful = self._mData.get('ishelpful') and "yes" or "no"
				vote_exist = review_help_obj.search( [('seller_review_id', '=', review_id), ('customer_id', '=', response.get('customerId'))])
				if vote_exist:
					vote_exist[0].write({"review_help": ishelpful})
					result = {'success':True, 'message':_('seller review vote update successfully !!!')}
				else:
					review_help_obj.sudo().create({"customer_id": response.get('customerId'), "seller_review_id": review_id, "review_help": ishelpful})
					result = {'success':True, 'message':_('seller review vote create successfully !!!')}
			else:
				result = {'success':False, 'message':_('Marketplace is not Active !!!')}
			response.update(result)
		return self._response('sellerReviewVote', response)
	@route(['/mobikul/marketplace/seller/orderlines'], csrf=False, type='http', auth="none",methods=['POST'])
	def sellerOrderLines(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner and Partner.seller:
				if response.get('addons', {}).get('odoo_marketplace'):
					result = {'success': True}
					local = response.get('local', {})
					SaleOrderLine = request.env['sale.order.line'].sudo()
					domain = [('marketplace_seller_id', '=',response.get('customerId'))]
					if self._mData.get('state'):
						domain += [('marketplace_state','=',self._mData.get('state'))]
					result['tcount'] = SaleOrderLine.search_count(domain)
					orderline = SaleOrderLine.search(domain, limit=self._mData.get('limit', response.get('itemsPerPage', 5)),
												   offset=self._mData.get('offset', 0), order="id desc")
					result['sellerOrderLines'] = []
					for order in orderline:
						temp = {
							'line_id': order.id,
							'create_date': order.create_date,
							'order_reference':order.order_id.id,
							'customer':order.order_partner_id.name,
							'product':order.product_id.name,
							'price_unit':_displayWithCurrency(local.get('lang_obj'), order.price_unit,
														local.get('currencySymbol', ""), local.get('currencyPosition', "")),
							'quantity': order.product_uom_qty,
							'sub_total':_displayWithCurrency(local.get('lang_obj'), order.price_subtotal,
														local.get('currencySymbol', ""), local.get('currencyPosition', "")),
							'delivered_qty':order.qty_delivered,
							'order_state':order.state,
							'marketplace_state':order.marketplace_state,
							'description': order.name,
						}
						result['sellerOrderLines'].append(temp)
				else:
					result = {'success': False, 'message': ('Marketplace is not Active !!!')}
			else:
				result = {'success': False, 'message': ('Customer is not a seller !!!')}
			response.update(result)
		return self._response('sellerOrderLines', response)
	@route(['/mobikul/marketplace/seller/orderline/'], csrf=False, type='http', auth="none", methods=['GET'])
	def sellerOrderLinesDetail(self,line_id,**kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner and Partner.seller:
				if response.get('addons', {}).get('odoo_marketplace'):
					result = {'success': True}
					local = response.get('local', {})
					SaleOrderLine = request.env['sale.order.line'].sudo()
					domain = [('id', '=', line_id)]
					orderline = SaleOrderLine.search(domain)
					result['sellerOrderLineDetail'] = {
						'line_id': orderline.id,
						'create_date': orderline.create_date,
						'order_reference': orderline.order_id.id,
						'customer': orderline.order_partner_id.name,
						'product': orderline.product_id.name,
						'price_unit': _displayWithCurrency(local.get('lang_obj'), orderline.price_unit,
														   local.get('currencySymbol', ""),
														   local.get('currencyPosition', "")),
						'quantity': orderline.product_uom_qty,
						'sub_total': _displayWithCurrency(local.get('lang_obj'), orderline.price_subtotal,
														  local.get('currencySymbol', ""),
														  local.get('currencyPosition', "")),
						'delivered_qty': orderline.qty_delivered,
						'order_state': orderline.state,
						'marketplace_state': orderline.marketplace_state,
						'description': orderline.name,
						'order_payment_acquirer':orderline.order_payment_acquirer_id.id and orderline.order_payment_acquirer_id.id or "",
						'delivery_method':orderline.order_id.carrier_id and orderline.order_id.carrier_id.id or ""
					}
				else:
					result = {'success': False, 'message': 'Marketplace is not Active !!!'}
			else:
				result = {'success': False, 'message': 'Customer is not a seller !!!'}
			response.update(result)
		return self._response('sellerOrderLinesDetail', response)
	# {"domain": "[('marketplace_seller_id','=',65),('status','=','approved')]", "offset": 0, "limit": 100}
	@route(['/mobikul/marketplace/seller/ask'], csrf=False, type='http', auth="none",methods=['POST'])
	def sellerAsk(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner and Partner.seller:
				ask_Query = "%s
%s
"%(self._mData.get('title') or "",self._mData.get('body'))
				mail_id = Partner.message_post(body=ask_Query, message_type='comment',subtype="mail.mt_comment",author_id=response.get('customerId'))
				if mail_id:
					result = {'message':_('Seller query is posted Successfully'),'success':True}
				else:
					result = {'message': 'Something went wrong in posted query', 'success': False}
			else:
				result = {'success': False, 'message': 'Customer is not a seller !!!'}
			response.update(result)
		return self._response('sellerAsk', response)
	@route(['/mobikul/marketplace/seller/product'], csrf=False, type='http', auth="none", methods=['POST'])
	def sellerProduct(self, **kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			TemplateObj = request.env['product.template'].sudo()
			if Partner and Partner.seller:
				local = response.get('local', {})
				domain = [('marketplace_seller_id', '=', response.get('customerId'))]
				if self._mData.get('state'):
					domain += [('status', '=', self._mData.get('state'))]
				productDetailsCount = TemplateObj.search_count(domain)
				productDetails = TemplateObj.search(domain,limit=self._mData.get('limit',response.get('itemsPerPage',5)), offset=self._mData.get('offset',0),  order="id desc")
				slr_product = []
				for prd in productDetails:
					temp = {
						"name": prd.name,
						'templateId':prd.id,
						'state': prd.status,
						'thumbNail' :_get_image_url(self.base_url, 'product.template', prd.id,'image'),
						'seller': prd.marketplace_seller_id.name,
						'qty': prd.qty,
						'priceUnit': _displayWithCurrency(local.get('lang_obj'),prd.list_price, local.get('currencySymbol',""), local.get('currencyPosition',"")),
					}
					slr_product.append(temp)
				result= {'success': True,'sellerProduct':slr_product,"tcount":productDetailsCount,"offset":self._mData.get('offset',0)}
			else:
				result = {'success': False, 'message': 'Customer is not a seller !!!'}
			response.update(result)
		return self._response('sellerProduct', response)
	@route(['/mobikul/marketplace/seller/dashboard'], csrf=False, type='http', auth="none",methods=['GET'])
	def sellerDashboard(self, **kwargs):
		Mobikul = request.env["mobikul"].sudo()
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			if Partner and Partner.seller:
				sellerData = Mobikul.sellerDashboardData(seller_Obj=Partner)
				result = {'success': True,'sellerDashboard': sellerData}
			else:
				result = {'success': False, 'message': 'Customer is not a seller !!!'}
			response.update(result)
		return self._response('sellerDashboard', response)
	@route(['/mobikul/marketplace/seller/terms'], csrf=False, type='http', auth="none", methods=['GET'])
	def sellerTermCond(self, **kwargs):
		response = self._authenticate(False, **kwargs)
		term_and_condition = request.env['website'].sudo().get_mp_config_settings_values().get('term_and_condition',False)
		if response.get('success'):
			result = {
				"term_and_condition":term_and_condition and  remove_htmltags(term_and_condition) or "",
			}
			response.update(result)
		return self._response('sellerTermCond', response)
	@route(['/mobikul/marketplace/become/seller'], csrf=False, type='http', auth="none", methods=['POST'])
	def becomeSeller(self, **kwargs):
		Mobikul = request.env["mobikul"].sudo()
		UserObj = request.env['res.users'].sudo()
		response = self._authenticate(True, **kwargs)
		if response.get('success'):
			user = UserObj.browse([response.get('userId')])
			if not user.partner_id.seller:
				if self._mData.get('url_handler') and Mobikul.checkSellerUniqueUrl(self._mData.get('url_handler')):
					Mobikul.set_marketplace_group_user(user)
					user.partner_id.seller = True
					user.partner_id.url_handler = self._mData.get('url_handler')
					user.partner_id.country_id = self._mData.get('country_id')
					result ={'success': True, 'message': 'Successfully became a seller'}
				else:
					result ={'success': False, 'message': _("Seller profile 'url_handler' is not unique or absent.")}
			else:
				result ={'success': False, 'message': 'Customer is already a seller' }
		response.update(result)
		return self._response('becomeSeller', response)
	@route(['/mobikul/ShippingMethods'], csrf=False, type='http', auth="none", methods=['GET'])
	def getAvailableShippingMethods(self,**kwargs):
		response = self._authenticate(True, **kwargs)
		if response.get('success') and response.get('addons', {}).get('website_sale_delivery'):
			PartnerObj = request.env['res.partner'].sudo()
			Partner = PartnerObj.browse(response.get('customerId'))
			SaleOrder = Partner.last_website_so_id
			ShippingMethods = SaleOrder.sudo()._get_delivery_methods()
			if ShippingMethods:
				local = response.get('local', {})
				result = []
				for method in ShippingMethods:
					result.append({
						"name": method.name,
						"id": method.id,
						"description": method.website_description or "",
						"price":_displayWithCurrency(local.get('lang_obj'), method.rate_shipment(SaleOrder).get('price'),
											 local.get('currencySymbol', ""), local.get('currencyPosition', "")),
					})
				result = {'ShippingMethods':result}
			else:
				result = {'success':False, 'message':'No Active Shipping methods found.'}
		else:
			result = {'success':False, 'message':'Website Sale Delivery is not install.'}
		response.update(result)
		return self._response('getAvailableShippingMethods', response)