示例#1
0
def query_profile(request):
    try:
        login_model = LoginModel.objects.filter(
            login_id=request.session.get('uuid')).first()
        if not login_model:
            return http.JsonErrorResponse(error_message="no login model")
        if login_model.status == codes.StatusCode.AVAILABLE.value:
            return http.JsonSuccessResponse()
        else:
            return http.JsonErrorResponse(error_message="error status")
    except Exception as e:
        logger.exception("qurey profile error:%s" % str(e))
        return http.JsonErrorResponse()
示例#2
0
def query_proof(request):
    try:
        proof_model = LoginModel.objects.filter(
            login_id=request.session.get('proof_id')).first()
        print(proof_model)
        if not proof_model:
            return http.JsonErrorResponse(error_message="no login model")
        if proof_model.status == codes.StatusCode.AVAILABLE.value:
            del request.session['proof_id']
            return http.JsonSuccessResponse()
        else:
            return http.JsonErrorResponse(error_message="error status")
    except Exception as e:
        logger.exception("query proof error:%s" % str(e))
        return http.JsonErrorResponse()
示例#3
0
def receive_pay(request):
    try:
        content_type = request.META.get(
            'CONTENT_TYPE') or request.META.get['HTTP_CONTENT_TYPE']
        if content_type.find('application/json') > -1:
            data = json.loads(request.body)
            if data:
                request.POST = data
        body = request.POST
        print("pay info:")
        print(body)
        pay_model = PayModel()
        pay_model.txid = body.get('txid')
        pay_model.uuid = body.get('uuid')
        pay_model.save()
        print("pay_id" + pay_model.uuid)
        login_model = LoginModel.objects.filter(
            login_id=pay_model.uuid).first()
        if login_model:
            login_model.status = codes.StatusCode.AVAILABLE.value
            login_model.save()
        return http.JsonSuccessResponse()
    except Exception as e:
        logger.exception("receive pay error:%s" % str(e))
        return http.JsonErrorResponse()
示例#4
0
def request_pay(request):
    try:
        order_number = request.POST.get('order_number')
        login_id = request.session['uuid']
        user = HepProfileModel.objects.filter(uuid=login_id).first()
        pay_session_id = uuid.uuid4().hex
        request.session['pay_id'] = pay_session_id
        pay_model = LoginModel()
        pay_model.login_id = pay_session_id
        pay_model.save()
        order = {
            'uuid': pay_session_id,
            'description': '你好',
            'price_currency': 'NEW',
            'total_price': '100',
            'order_number': order_number,
            'seller': user.newid,
            'customer': user.newid,
            'broker': user.newid,
        }
        pay_qr_str = services.hep_pay(order)
        pay_info = {'pay_qr_str': pay_qr_str}
        return http.JsonSuccessResponse(data=pay_info)
    except Exception as e:
        logger.exception("query pay error:%s" % str(e))
        return http.JsonErrorResponse()
示例#5
0
def get_client_pay(request):
    try:
        os = request.POST.get('os')
        if not os:
            body = json.loads(request.body)
            os = body.get('os')
        newid = request.POST.get('newid')
        if not newid:
            body = json.loads(request.body)
            newid = body.get('newid')
        pay_params = {
            'action': settings.ACTION_PAY,
            'description': 'Pay description',
            'price_currency': 'NEW',
            'total_price': "1",
            'order_number': uuid.uuid4().hex,
            'seller': newid,
            'customer': newid,
            'broker': newid,
            'uuid': uuid.uuid4().hex
        }
        pay_params = _get_client_params(pay_params, os)
        return http.JsonSuccessResponse(data=pay_params)
    except Exception as e:
        logger.exception("get client pay error:%s" % str(e))
        return http.JsonErrorResponse()
示例#6
0
def request_pay_h5(request):
    try:
        login_id = request.session['uuid']
        user = HepProfileModel.objects.filter(uuid=login_id).first()
        newid = user.newid
        pay_session_id = uuid.uuid4().hex
        request.session['pay_id'] = pay_session_id
        pay_model = LoginModel()
        pay_model.login_id = pay_session_id
        pay_model.save()
        if not newid:
            body = json.loads(request.body)
            newid = body.get('newid')
        pay_params = {
            'uuid': pay_session_id,
            'action': settings.ACTION_PAY,
            'description': 'Pay description',
            'price_currency': 'NEW',
            'total_price': "1",
            'order_number': uuid.uuid4().hex,
            'seller': newid,
            'customer': newid,
            'broker': newid,
        }
        pay_params = _get_client_params(pay_params)
        return http.JsonSuccessResponse(data=pay_params)
    except Exception as e:
        logger.exception("request pay h5 error:%s" % str(e))
        return http.JsonErrorResponse()
示例#7
0
def receive_proof(request):
    try:
        content_type = request.META.get(
            'CONTENT_TYPE') or request.META.get['HTTP_CONTENT_TYPE']
        if content_type.find('application/json') > -1:
            data = json.loads(request.body)
            if data:
                request.POST = data
        body = request.POST
        proof_model = ProofModel()
        proof_model.uuid = body.get('uuid')
        proof_status = services.verify_proof(body)
        if proof_status:
            print(proof_status.proof_status)
            print(proof_status.proof_hash)
        proof_model.txid = uuid.uuid4().hex
        proof_model.save()
        login_model = LoginModel.objects.filter(
            login_id=proof_model.uuid).first()
        if login_model:
            login_model.status = codes.StatusCode.AVAILABLE.value
            login_model.save()
        return http.JsonSuccessResponse()
    except Exception as e:
        logger.exception("receive proof error:%s" % str(e))
        return http.JsonErrorResponse()
示例#8
0
def user_center(request):
    try:
        login_id = request.session['uuid']
        user = HepProfileModel.objects.filter(uuid=login_id).first()
        return render(request, "demo/user.html", {'user': user})
    except Exception as e:
        logger.exception("user center error:%s" % str(e))
        return http.JsonErrorResponse()
示例#9
0
def receive_profile(request):
    try:
        content_type = request.META.get(
            'CONTENT_TYPE') or request.META.get['HTTP_CONTENT_TYPE']
        if content_type.find('application/json') > -1:
            data = json.loads(request.body)
            if data:
                request.POST = data
        body = request.POST
        logger.info(body)
        is_valid = services.verify_profile(body)
        if is_valid:
            profile_model = HepProfileModel()
            profile_model.uuid = body.get('uuid')
            if not profile_model.uuid:
                logger.error("no uuid")
                return http.JsonErrorResponse(error_message="no uuid")
            profile_model.signature = body.get('signature')
            profile_model.newid = body.get('newid')
            profile_model.name = body.get('name')
            profile_model.avatar = body.get('avatar')
            profile_model.address = body.get('address')
            profile_model.cellphone = body.get('cellphone')
            if not profile_model.cellphone:
                profile_model.cellphone = "scope is 1,no cellphone"
            if not profile_model.address:
                profile_model.address = "scope is 1,no address"
            profile_model.save()
            login_model = LoginModel.objects.filter(
                login_id=profile_model.uuid).first()
            if login_model:
                login_model.status = codes.StatusCode.AVAILABLE.value
                logger.info("update profile info status")
                login_model.save()
                return http.HttpResponse("OK")
            else:
                logger.error("no login id ")
                return http.JsonErrorResponse(error_message="no login id")
        else:
            logger.error("invalidate profile information")
            return http.JsonErrorResponse(
                error_message="invalidate profile information")
    except Exception as e:
        logger.exception("receive profile error:%s" % str(e))
        return http.JsonErrorResponse()
示例#10
0
def request_login(request):
    try:
        login_session_id = uuid.uuid4().hex
        session_id = login_session_id
        login_model = LoginModel()
        login_model.login_id = session_id
        login_model.save()
        qr_code_str = services.hep_login(session_id)
        login = {'qr_str': qr_code_str, 'uuid': session_id}
        request.session['uuid'] = session_id
        return render(request, "demo/hep_login.html", {'login': login})
    except Exception as e:
        logger.exception("request login error:%s" % str(e))
        return http.JsonErrorResponse()
示例#11
0
def post_profile(request):
    try:
        body = request.POST
        profile_model = HepProfileModel()
        profile_model.uuid = uuid.uuid4().hex
        profile_model.signature = body.get('signature')
        profile_model.newid = body.get('newid')
        profile_model.name = body.get('name')
        profile_model.avatar = body.get('avatar')
        profile_model.address = body.get('address')
        profile_model.cellphone = body.get('cellphone')
        profile_model.save()
        request.session['uuid'] = profile_model.uuid
        return http.JsonSuccessResponse()
    except Exception as e:
        logger.exception("post profile error:%s" % str(e))
        return http.JsonErrorResponse()
示例#12
0
def request_login_h5(request):
    try:
        login_session_id = uuid.uuid4().hex
        request.session['uuid'] = login_session_id
        login_model = LoginModel()
        login_model.login_id = login_session_id
        login_params = {
            'action': settings.ACTION_LOGIN,
            'scope': 2,
            'memo': 'Demo Request Login',
            'uuid': login_session_id,
        }
        login_params = _get_client_params(login_params)
        return http.JsonSuccessResponse(data=login_params)
    except Exception as e:
        logger.exception("get client pay error:%s" % str(e))
        return http.JsonErrorResponse()
示例#13
0
def get_client_login(request):
    try:
        os = request.POST.get('os')
        if not os:
            body = json.loads(request.body)
            os = body.get('os')
        login_params = {
            'action': settings.ACTION_LOGIN,
            'scope': 2,
            'memo': 'Demo Request Login',
            'uuid': uuid.uuid4().hex
        }
        login_params = _get_client_params(login_params, os)
        return http.JsonSuccessResponse(data=login_params)
    except Exception as e:
        logger.exception("get client login error:%s" % str(e))
        return http.JsonErrorResponse()
示例#14
0
def show_order(request):
    try:
        order = {
            "ordername":
            "芒果",
            "ordernumber":
            uuid.uuid4().hex,
            "price_currency":
            "NEW",
            "total_price":
            "100",
            "order_img":
            "https://newton-dapp-store.oss-cn-beijing.aliyuncs.com/banner1559375214.png"
        }
        return render(request, "demo/orderlist.html", {'order': order})
    except Exception as e:
        logger.exception("show order error:%s" % str(e))
        return http.JsonErrorResponse()
示例#15
0
def get_proof_hash(request):
    try:
        os = request.POST.get('os')
        if not os:
            body = json.loads(request.body)
            os = body.get('os')
        newid = request.POST.get('newid')
        if not newid:
            body = json.loads(request.body)
            newid = body.get('newid')
        # todo: add proof field.
        pay_model = PayModel.objects.last()
        txid = pay_model.txid
        proof_session_id = uuid.uuid4().hex
        order_content = OrderProof(order_number=uuid.uuid4().hex,
                                   price_currency="NEW",
                                   total_price="100",
                                   seller=newid,
                                   customer=newid,
                                   broker=newid,
                                   description="description",
                                   chain_txid=txid)
        print("txid:" + txid)
        order_content.add_order_item(order_item_number=uuid.uuid4().hex,
                                     order_item_quantity=1,
                                     price="10",
                                     price_currency="NEW",
                                     thing_name="pingguo",
                                     thing_id=uuid.uuid4().hex,
                                     thing_type='product')
        proof_hash = services.get_proof_hash(order_content.to_dict(),
                                             proof_session_id, os)
        client_params = {
            'action': settings.ACTION_PROOF_SUBMIT,
            'proof_hash': proof_hash,
            'uuid': proof_session_id
        }
        client_params = _get_client_params(client_params, os)
        return http.JsonSuccessResponse(data=client_params)
    except Exception as e:
        logger.exception("get proof hash error:%s" % str(e))
        return http.JsonErrorResponse(error_message=str(e))
示例#16
0
def request_proof_h5(request):
    try:
        proof_session_id = uuid.uuid4().hex
        login_id = request.session['uuid']
        user = HepProfileModel.objects.filter(uuid=login_id).first()
        request.session['proof_id'] = proof_session_id
        login_model = LoginModel()
        login_model.login_id = proof_session_id
        login_model.save()
        # todo: add proof field.
        pay_model = PayModel.objects.last()
        txid = pay_model.txid
        order_content = OrderProof(order_number=uuid.uuid4().hex,
                                   price_currency="NEW",
                                   total_price="100",
                                   seller=user.newid,
                                   customer=user.newid,
                                   broker=user.newid,
                                   description="description",
                                   chain_txid=txid)
        order_content.add_order_item(order_item_number=uuid.uuid4().hex,
                                     order_item_quantity=1,
                                     price="10",
                                     price_currency="NEW",
                                     thing_name="pingguo",
                                     thing_id=uuid.uuid4().hex,
                                     thing_type='product')
        proof_hash = services.get_proof_hash(order_content.to_dict(),
                                             proof_session_id)
        client_params = {
            'uuid': proof_session_id,
            'action': settings.ACTION_PROOF_SUBMIT,
            'proof_hash': proof_hash
        }
        client_params = _get_client_params(client_params)
        return http.JsonSuccessResponse(data=client_params)
    except Exception as e:
        logger.exception("request proof error:%s" % str(e))
        return http.JsonErrorResponse()
示例#17
0
def request_proof(request):
    try:
        proof_session_id = uuid.uuid4().hex
        login_id = request.session['uuid']
        user = HepProfileModel.objects.filter(uuid=login_id).first()
        request.session['proof_id'] = proof_session_id
        login_model = LoginModel()
        login_model.login_id = proof_session_id
        login_model.save()
        # todo: add proof field.
        pay_model = PayModel.objects.last()
        txid = pay_model.txid
        order_content = OrderProof(order_number=uuid.uuid4().hex,
                                   price_currency="CNY",
                                   total_price="100",
                                   seller=user.newid,
                                   customer=user.newid,
                                   broker=user.newid,
                                   description="description",
                                   chain_txid=None)
        order_content.add_order_item(order_item_number=uuid.uuid4().hex,
                                     order_item_quantity=1,
                                     price="10",
                                     price_currency="NEW",
                                     thing_name="pingguo",
                                     thing_id=uuid.uuid4().hex,
                                     thing_type='product')
        proof_qr_str = services.hep_proof(order_content.to_dict(),
                                          proof_session_id)
        pay_info = {
            'proof_qr_str': proof_qr_str,
        }
        return http.JsonSuccessResponse(data=pay_info)
    except Exception as e:
        logger.exception("request proof error:%s" % str(e))
        return http.JsonErrorResponse()