1.风控核心代码:

<?php

namespace core\models;

class SalesCustomersFacade extends \common\models\Base{

    /**
     * 根据申请记录修改信用额度
     * @param $salesCustomersCreditModel
     * @return array
     */
    public static function updateCreditByApply($salesCustomersCreditModel){

        if(\core\models\SalesCustomersCredit::STATUS_FINISH == $salesCustomersCreditModel->sales_customers_credit_review_status){
            return ['status'=>false, 'code'=>"05010240", 'message'=>'信用额度已经更新,不能重复更新'];
        }
        $transaction = \Yii::$app->db->beginTransaction();
        try {
            //添加信用额度变更记录
            $sales_customers_credit_result = \core\models\SalesCustomersCreditRecord::insertByApply($salesCustomersCreditModel);
            if (false == $sales_customers_credit_result){
                throw new \yii\db\Exception('新增信用额度变更记录失败!', '05010243');
            }

            //更新信用额度快照
            $sales_customers_result = \core\models\SalesCustomers::updateSalesCustomersByApply($salesCustomersCreditModel);
            if (false == $sales_customers_result){
                throw new \yii\db\Exception('更新客户信用额度失败!', '05010244');
            }

            //更新信用额度申请记录状态为完成
            $sales_customers_credit_result = \core\models\SalesCustomersCredit::updateFinishStatusByApply($salesCustomersCreditModel);
            if (false == $sales_customers_credit_result){
                throw new \yii\db\Exception('更新客户信用额度申请记录状态失败!', '05010245');
            }

            $transaction->commit();
            return ['status'=>true, 'code'=>'0', 'message'=>'更新信用额度成功'];
        }catch (\yii\db\Exception $e){
            $transaction->rollBack();
            return ['status'=>false, 'code'=>$e->getCode(), 'message'=>$e->getMessage()];
        }
    }

    public static function updateCreditByOrder($salesOrderModel){
        //判断不是先货后款
        if (\core\models\SalesOrder::TYPE_WMS_BEFORE != $salesOrderModel->sales_order_settle_mode){
            return ['status'=>false, 'code'=>"05010250", 'message'=>'订单付款状态不是先货后款'];
        }

        //判断审批状态不是已完成
        $status = \core\models\CommonApproveStatus::getApprovalStatus($salesOrderModel->sales_order_code, \core\models\CommonDingtalkApproval::SALES_ORDER);
        if(!in_array($status, array(\core\models\DingtalkApproval::COMPLETE_APPROVAL))){
            return ['status'=>false, 'code'=>"05010251", 'message'=>'订单状态审批不是已完成'];
        }

        $transaction = \Yii::$app->db->beginTransaction();
        try {
            //添加信用额度变更记录
            $sales_customers_credit_result = \core\models\SalesCustomersCreditRecord::insertByOrder($salesOrderModel);
            if (false == $sales_customers_credit_result){
                throw new \yii\db\Exception('新增信用额度变更记录失败!', '05010252');
        }

            //更新信用额度快照
            $sales_customers_result = \core\models\SalesCustomers::updateSalesCustomersByOrder($salesOrderModel);
            if (false == $sales_customers_result){
                throw new \yii\db\Exception('更新客户信用额度失败!', '05010244');
            }

            //更新信用额度申请记录状态为完成
            $sales_order_result = \core\models\SalesOrder::updateFinishStatusByOrder($salesOrderModel);
            if (false == $sales_order_result){
                throw new \yii\db\Exception('更新订单状态失败!', '05010245');
            }

            $transaction->commit();
            return ['status'=>true, 'code'=>'0', 'message'=>'更新信用额度成功'];
        }catch (\yii\db\Exception $e){
            $transaction->rollBack();
            return ['status'=>false, 'code'=>$e->getCode(), 'message'=>$e->getMessage()];
        }
    }

    public static function updateCreditByRepay($financeInvoiceModel){
        $salesOrderModel = $financeInvoiceModel->salesOrder;
        //判断不是先货后款
        if (\core\models\SalesOrder::TYPE_WMS_BEFORE != $salesOrderModel->sales_order_settle_mode){
            return ['status'=>false, 'code'=>"05010250", 'message'=>'订单付款状态不是先货后款'];
        }

        //获取发票信息
        $financeInvoiceModel = \core\models\FinanceSalesInvoice::find()->where(['is_del'=>0, 'sales_order_code'=>$salesOrderModel->sales_order_code])->one();
        if (empty($financeInvoiceModel)){
            return ['status'=>false, 'code'=>"05010252", 'message'=>'发票信息不存在'];
        }

        if ($financeInvoiceModel->finance_sales_invoice_settle_status != 1){
            return ['status'=>false, 'code'=>"05010253", 'message'=>'订单未回款'];
        }

        $transaction = \Yii::$app->db->beginTransaction();
        try {
            //添加信用额度变更记录
            $sales_customers_credit_result = \core\models\SalesCustomersCreditRecord::insertByRepay($financeInvoiceModel);
            if (false == $sales_customers_credit_result){
                throw new \yii\db\Exception('新增信用额度变更记录失败!', '05010252');
            }

            //更新信用额度快照
            $sales_customers_result = \core\models\SalesCustomers::updateSalesCustomersByRepay($financeInvoiceModel);
            if (false == $sales_customers_result){
                throw new \yii\db\Exception('更新客户信用额度失败!', '05010244');
            }

            //更新信用额度申请记录状态为完成
            /*
            $sales_order_result = \core\models\FinanceSalesInvoice::updateFinishStatusByRepay($financeInvoiceModel);
            if (false == $sales_order_result){
                throw new \yii\db\Exception('更新订单状态失败!', '05010245');
            }
            */
            $transaction->commit();
            return ['status'=>true, 'code'=>'0', 'message'=>'更新信用额度成功'];
        }catch (\yii\db\Exception $e){
            $transaction->rollBack();
            return ['status'=>false, 'code'=>$e->getCode(), 'message'=>$e->getMessage()];
        }
    }

    /**
     * 根据信用额度判断能否签订合同
     * @param $sales_contract
     * @return bool
     */
    public static function canContractByCredit($salesContractModel){
        $salesCustomersModel = $salesContractModel->salesCustomers;
        //判断是否先款后货
        if (\core\models\SalesContract::TYPE_FINANCE_BEFORE == $salesContractModel->sales_contract_settle_mode){
            return ['status'=>true, 'errcode'=>'0', 'errmsg'=>'ok'];
        }
        //判断上一单是否已经回款
        $lastestSaleOrderModels = \core\models\SalesOrder::find()->where([
            'is_del'=>0,
            'sales_customers_id'=>$salesCustomersModel->id,
            'sales_order_settle_mode'=>\core\models\SalesOrder::TYPE_WMS_BEFORE])->all();
        if (!empty($lastestSaleOrderModels)){
            foreach ($lastestSaleOrderModels as $lastestSaleOrderModel){
                $status = \core\models\CommonApproveStatus::getApprovalStatus($lastestSaleOrderModel->sales_order_code, \core\models\CommonDingtalkApproval::SALES_ORDER);
                if (empty($lastestSaleOrderModel->send_out_at)){
                    $send_out_at = 0;
                }else{
                    $send_out_at = $lastestSaleOrderModel->send_out_at;
                }
                if($status == \core\models\DingtalkApproval::COMPLETE_APPROVAL
                    && (time() - $send_out_at > $salesContractModel->sales_contract_aging)
                    && empty($lastestSaleOrderModel->repay_status == 0)){
                    return ['status'=>false, 'errcode'=>'050204', 'errmsg'=>'上一单超账期未回款'];
                }
            }
        }

        //判断信用额度是否已经过期
        $salesCustomersModel = \core\models\SalesCustomers::findOne(['id'=>$salesContractModel->sales_customers_id]);
        if ($salesCustomersModel->sales_customers_credit_end_at < time()){
            return ['status'=>false, 'errcode'=>'050201', 'errmsg'=>'客户资质已经过期'];
        }
        //判断信用额度是否已经不足
        if ($salesCustomersModel->sales_customers_credit_surplus < \common\models\Base::moneyBcmul($salesContractModel->sales_contract_receivables)){
            return ['status'=>false, 'errcode'=>'050202', 'errmsg'=>'客户信用余额不足'];
        }
        return ['status'=>true, 'errcode'=>'0', 'errmsg'=>'ok'];
    }

    /**
     * 根据信用额度判断能否下订单
     * @param $sales_contract
     * @return bool
     */
    public static function canOrderByCredit($salesOrderModel){
        $salesCustomersModel = $salesOrderModel->salesCustomers;
        $salesContractModel = $salesOrderModel->salesContract;
        //判断是否先款后货
        if (\core\models\SalesOrder::TYPE_FINANCE_BEFORE == $salesOrderModel->sales_order_settle_mode){
            return ['status'=>true, 'errcode'=>'0', 'errmsg'=>'ok'];
        }
        //判断上一单是否已经回款
        $lastestSaleOrderModels = \core\models\SalesOrder::find()->where([
            'is_del'=>0,
            'sales_customers_id'=>$salesCustomersModel->id,
            'sales_order_settle_mode'=>\core\models\SalesOrder::TYPE_WMS_BEFORE])->andWhere(['!=', 'id', $salesOrderModel->id])->all();
        if (!empty($lastestSaleOrderModels)){
            foreach ($lastestSaleOrderModels as $lastestSaleOrderModel){
                $status = \core\models\CommonApproveStatus::getApprovalStatus($lastestSaleOrderModel->sales_order_code, \core\models\CommonDingtalkApproval::SALES_ORDER);
                if (empty($lastestSaleOrderModel->send_out_at)){
                    $send_out_at = 0;
                }else{
                    $send_out_at = $lastestSaleOrderModel->send_out_at;
                }
                if($status == \core\models\DingtalkApproval::COMPLETE_APPROVAL
                && (time() - $send_out_at > $salesContractModel->sales_contract_aging)
                && empty($lastestSaleOrderModel->repay_status == 0)){
                    return ['status'=>false, 'errcode'=>'050204', 'errmsg'=>'上一单超账期未回款'];
                }
            }
        }

        //判断信用额度是否已经过期
        $salesCustomersModel = \core\models\SalesCustomers::findOne(['id'=>$salesOrderModel->sales_customers_id]);
        if ($salesCustomersModel->sales_customers_credit_end_at < time()){
            return ['status'=>false, 'errcode'=>'050206', 'errmsg'=>'客户资质已经过期'];
        }
        //判断信用额度是否已经不足
        if ($salesCustomersModel->sales_customers_credit_surplus < $salesOrderModel->sales_order_total_amount){
            return ['status'=>false, 'errcode'=>'050207', 'errmsg'=>'客户信用余额不足'];
        }
        //判断订单额度是否超出合同额度
        if ($salesContractModel->sales_contract_amount < \common\models\Base::moneyBcdiv($salesOrderModel->sales_order_total_amount)){
            return ['status'=>false, 'errcode'=>'050208', 'errmsg'=>'订单总金额超出合同总金额'];
        }
        return ['status'=>true, 'errcode'=>'0', 'errmsg'=>'ok'];
    }

    public static function canCreditApplyByCredit($salesCustomersModel){
        $salesCustomersCreditModels = $salesCustomersModel->salesCustomersCredit;

        if (empty($salesCustomersCreditModels)){
            $return_arr = ['flag'=>true, 'message'=>'信用申请'];
            return $return_arr;
        }else{
            foreach ($salesCustomersCreditModels as $salesCustomersCreditModel){
                $approval = \core\models\CommonDingtalkApproval::SALES_CUSTOMER_CREDIT;
                $status = \core\models\CommonApproveStatus::getApprovalStatus($salesCustomersCreditModel->sales_customers_credit_code, $approval);
                $update_credit_status = $salesCustomersCreditModel->sales_customers_credit_review_status;

                if ($update_credit_status != \core\models\DingtalkApproval::COMPLETE_APPROVAL){
                    $return_arr = ['flag'=>false, 'message'=>''];
                    return $return_arr;
                }

                if ($update_credit_status != \core\models\SalesCustomersCredit::STATUS_FINISH){
                    $return_arr = ['flag'=>false, 'message'=>''];
                    return $return_arr;
                }
            }
            $return_arr = ['flag'=>true, 'message'=>'信用变更申请'];
            return $return_arr;
        }
    }
}

  

《ERP系统》客户信用及风控代码的更多相关文章

  1. 解析大型.NET ERP系统 高质量.NET代码设计模式

    1 缓存 Cache 系统中大量的用到缓存设计模式,对系统登入之后不变的数据进行缓存,不从数据库中直接读取.耗费一些内存,相比从SQL Server中再次读取数据要划算得多.缓存的基本设计模式参考下面 ...

  2. AX2012 ERP “系统慢”调优---跟踪SQL执行,优化代码

    对于用户来说,系统是:慢的,难用的.你看xxx,多好用,多快,多人性化. 对于AX ERP系统也不例外,调优是必须的,调优一般分为几种: 系统性监测针对瓶劲环节提升,如:用户--应用服务器--DB-- ...

  3. 解析大型.NET ERP系统 权限模块设计与实现

    权限模块是ERP系统的核心模块之一,完善的权限控制机制给系统增色不少.总结我接触过的权限模块,以享读者. 1 权限的简明定义 ERP权限管理用一句简单的话来说就是:谁 能否 做 那些 事. 文句 含义 ...

  4. 全面具体介绍一个P2P网贷领域的ERP系统的主要功能

        一般的P2P系统,至少包含PC站点的前端和后端.前端系统的功能.能够參考"P2P系统哪家强,功能事实上都一样" http://blog.csdn.net/fansunion ...

  5. 全面详细介绍一个P2P网贷领域的ERP系统的主要功能

        一般的P2P系统,至少包括PC网站的前端和后端.前端系统的功能,可以参考"P2P系统哪家强,功能其实都一样" http://blog.csdn.net/fansunion/ ...

  6. 解析大型.NET ERP系统 数据审计功能

    数据审计,英语表达是Audit,是追踪数据变化的过程,记录数据变化前后的值,供参考分析.通过设置,ERP可以追踪一个表的所有字段的变化,也可以只记录指定的字段的值变化.欧美企业每年都有独立的审计部门, ...

  7. 解析大型.NET ERP系统 十三种界面设计模式

    成熟的ERP系统的界面应该都是从模板中拷贝出来的,各类功能的界面有规律可遵循.软件界面设计模式化或是艺术性的创作,我认可前者,模式化的界面客户容易举一反三,降低学习门槛.除了一些小部分的功能界面设计特 ...

  8. 解析大型.NET ERP系统 界面与逻辑分离

    Windows Forms程序实现界面与逻辑分离的关键是数据绑定技术(Data Binding),这与微软推出的ASP.NET MVC的原理相同,分离业务代码与界面层,提高系统的可维护性. 数据绑定 ...

  9. 解析大型.NET ERP系统 通用附件管理功能

    大型系统具备一个通用的附件管理功能,对于单据中无法清晰表达的字段,用一个附件图片或附件文档表示是最好的方法了.比如物料清单附加一张CAD图纸,销售订单评审功能中附加客户的各种表格,通用附件功能对系统起 ...

随机推荐

  1. (转)linux下查看已安装的软件与卸载

    因为linux安装软件的方式比较多,所以没有一个通用的办法能查到某些软件是否安装了.总结起来就是这样几类: 1.rpm包安装的,可以用rpm -qa看到,如果要查找某软件包是否安装,用 rpm -qa ...

  2. web安全之攻击

    转自 知乎https://www.zhihu.com/question/22953267 作者:潘良虎链接:https://www.zhihu.com/question/22953267/answer ...

  3. Spring定时任务使用和如何使用邮件监控服务器

    Spring相关的依赖导入进去,即可使用spring的定时任务! <!-- spring核心包 --> <dependency> <groupId>org.spri ...

  4. socket实现聊天功能(二)

    socket实现聊天功能(二) WebSocket协议是建立在HTTP协议之上,因此创建websocket服务时需要调用http模块的createServer方法.将生成的server作为参数传入so ...

  5. 【Atcoder ARC060F】最良表現 / Best Representation

    Atcoder ARC060 F 题意:给一个串,求将其分成最少的没有循环节的串的种数. 思路:先求KMP的\(fail\)数组.然后发现最少的串数只有三种可能:\(1\).\(2\).\(n\). ...

  6. 学习CSS布局 - dispaly属性

    "display"属性 display 是CSS中最重要的用于控制布局的属性. 每个元素都有一个默认的 display 值,这与元素的类型有关. 对于大多数元素它们的默认值通常是  ...

  7. 监控 -- kubernetes -- prometheus

    1.但是Heapster无法做Kubernetes下应用的监控.现在,Heapster作为Kubernetes下的开源监控解决方案已经被其弃用,Prometheus成为Kubernetes官方推荐的监 ...

  8. Codeforces Hello 2019

    Hello 2019 手速场qwq 反正EGH太神仙了啊.jpg 考试的时候不会啊.jpg A 暴力.jpg #include <cstdio> #include <algorith ...

  9. 免安装的Tomcat基本配置和安装

    大家都知道tomcat吧!因为Tomcat 技术先进.性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器,也是运行Servlet和JS ...

  10. python 3.5下安装pycrypto

    pip install --use-wheel --no-index --find-links=https://github.com/sfbahr/PyCrypto-Wheels/raw/master ...