1. 全局输入输出结构(数据通过Json String传输)
- 定义全局结构
TYPES: BEGIN OF TY_SD001,
PARTNER TYPE BUT000-PARTNER, "客户编码
BU_GROUP TYPE BUT000-BU_GROUP, "分组
TITLE TYPE BUT000-TITLE, "称谓
NAME_ORG1 TYPE BUT000-NAME_ORG1, "名称
BU_SORT1 TYPE BUT000-BU_SORT1, "搜索项1
BPEXT TYPE BUT000-BPEXT, "搜索项2
STRAS TYPE KNA1-STRAS, "街道
PSTLZ TYPE KNA1-PSTLZ, "邮政编码
ORT01 TYPE KNA1-ORT01, "城市
REGIO TYPE KNA1-REGIO, "省/地区
LAND1 TYPE KNA1-LAND1, "国家
SPRAS TYPE char2, "语言
TELF1 TYPE KNA1-TELF1, "电话
TELFX TYPE KNA1-TELFX, "传真
KATR1 TYPE KNA1-KATR1, "属性1
BRAN1 TYPE KNA1-BRAN1, "行业代码1
KUKLA TYPE KNA1-KUKLA, "客户分类
BUKRS TYPE KNB1-BUKRS, "公司代码
AKONT TYPE KNB1-AKONT, "统驭科目
ZUAWA TYPE KNB1-ZUAWA, "排序码
ZTERM TYPE KNVV-ZTERM, "付款条件
VKORG TYPE KNVV-VKORG, "销售组织
VTWEG TYPE KNVV-VTWEG, "分销渠道
SPART TYPE KNVV-SPART, "产品组
BZIRK TYPE KNVV-BZIRK, "销售区域
KDGRP TYPE KNVV-KDGRP, "客户组
KVGR1 TYPE KNVV-KVGR1, "客户组1
VKBUR TYPE KNVV-VKBUR, "销售部门
VKGRP TYPE KNVV-VKGRP, "销售组
WAERS TYPE KNVV-WAERS, "币种
KONDA TYPE KNVV-KONDA, "价格组
KALKS TYPE KNVV-KALKS, "定价过程
KZAZU TYPE KNVV-KZAZU, "订单组合
VWERK TYPE KNVV-VWERK, "交货工厂
VSBED TYPE KNVV-VSBED, "装运条件
INCO1 TYPE KNVV-INCO1, "国际贸易条款
INCO2_L TYPE KNVV-INCO2_L, "国际贸易位置
KKBER TYPE KNVV-KKBER, "信用控制范围
KTGRD TYPE KNVV-KTGRD, "客户账户分配组
TAXKD TYPE KNVI-TAXKD, "税分类
ALAND TYPE KNVI-ALAND, "国家/地区
TATYP TYPE KNVI-TATYP, "税收类别
TAXTYPE TYPE DFKKBPTAXNUM-TAXTYPE, "税号类别
TAXNUMXL TYPE DFKKBPTAXNUM-TAXNUMXL, "税务登记证号
BANKS TYPE KNBK-BANKS, "银行国家
BANKL TYPE KNBK-BANKL, "银行代码
BANKA TYPE BNKA-BANKA, "银行名称
BANKN TYPE KNBK-BANKN, "银行账户
BKREF TYPE KNBK-BKREF, "参考明细
KOINH TYPE KNBK-KOINH, "账户持有人
LIMIT_RULE TYPE UKMBP_CMS-LIMIT_RULE, "信用参数规则
RISK_CLASS TYPE UKMBP_CMS-RISK_CLASS, "信用风险类
CHECK_RULE TYPE UKMBP_CMS-CHECK_RULE, "信用检查规则
CREDIT_SGMNT TYPE UKMBP_CMS_SGM-CREDIT_SGMNT, "信用段
CREDIT_LIMIT TYPE UKMBP_CMS_SGM-CREDIT_LIMIT, "信用金额
LIMIT_VALID_DATE TYPE UKMBP_CMS_SGM-LIMIT_VALID_DATE, "有效至
ATTRIBUTE1 TYPE CHAR100, "预留字段1
ATTRIBUTE2 TYPE CHAR100, "预留字段2
ATTRIBUTE3 TYPE CHAR100, "预留字段3
ATTRIBUTE4 TYPE CHAR100, "预留字段4
ATTRIBUTE5 TYPE CHAR100, "预留字段5
ATTRIBUTE6 TYPE CHAR100, "预留字段6
ATTRIBUTE7 TYPE CHAR100, "预留字段7
ATTRIBUTE8 TYPE CHAR100, "预留字段8
ATTRIBUTE9 TYPE CHAR100, "预留字段9
ATTRIBUTE10 TYPE CHAR100, "预留字段10
ATTRIBUTE11 TYPE CHAR100, "预留字段11
ATTRIBUTE12 TYPE CHAR100, "预留字段12
ATTRIBUTE13 TYPE CHAR100, "预留字段13
ATTRIBUTE14 TYPE CHAR100, "预留字段14
ATTRIBUTE15 TYPE CHAR100, "预留字段15
END OF TY_SD001.
TYPES: BEGIN OF TY_SD001_O,
PARTNER TYPE BUT000-PARTNER, "客户编码
MSGTY TYPE MSGTY,
MSGTX TYPE MSGTX,
CRM_BP TYPE CHAR20,
END OF TY_SD001_O.
2. 传入参数
{
"PARTNER": "",
"BU_GROUP": "Z020",
"TITLE": "0003",
"NAME_ORG1": "ABCDE",
"BU_SORT1": "ABC",
"BPEXT": "",
"STRAS": "XXX街道XXX号",
"PSTLZ": "322163",
"ORT01": "北京市",
"REGIO": "130",
"LAND1": "CN",
"SPRAS": "ZH",
"TELF1": "0571-89664859",
"TELFX": "0571-89664859",
"KATR1": "01",
"BRAN1": "0013",
"KUKLA": "09",
"BUKRS": "1000",
"AKONT": "1111000002",
"ZUAWA": "009",
"ZTERM": "Z019",
"VKORG": "1100",
"VTWEG": "00",
"SPART": "00",
"BZIRK": "J00001",
"KDGRP": "20",
"KVGR1": "06",
"VKBUR": "0010",
"VKGRP": "023",
"WAERS": "CNY",
"KONDA": "01",
"KALKS": "1",
"KZAZU": "X",
"VWERK": "1000",
"VSBED": "01",
"INCO1": "",
"INCO2_L": "",
"KKBER": "1000",
"KTGRD": "Z2",
"TAXKD": "1",
"ALAND": "CN",
"TATYP": "MWST",
"TAXTYPE": "CN0",
"TAXNUMXL": "91870169396378766W",
"BANKS": "",
"BANKL": "",
"BANKA": "",
"BANKN": "",
"BKREF": "",
"KOINH": "",
"LIMIT_RULE": "STANDARD",
"RISK_CLASS": "B",
"CHECK_RULE": "ZXX01",
"CREDIT_SGMNT": "ZXX01",
"CREDIT_LIMIT": 0,
"LIMIT_VALID_DATE": "0000-00-00",
"ATTRIBUTE1": "",
"ATTRIBUTE2": "",
"ATTRIBUTE3": "",
"ATTRIBUTE4": "",
"ATTRIBUTE5": "",
"ATTRIBUTE6": "",
"ATTRIBUTE7": "",
"ATTRIBUTE8": "",
"ATTRIBUTE9": "",
"ATTRIBUTE10": "",
"ATTRIBUTE11": "",
"ATTRIBUTE12": "",
"ATTRIBUTE13": "",
"ATTRIBUTE14": "",
"ATTRIBUTE15": ""
}
3. 接口函数(示例为单条过账,批量请加Loop循环)
FUNCTION zsd_if00010_crm.
*"----------------------------------------------------------------------
*"*"本地接口:
*" IMPORTING
*" VALUE(IV_INPUT) TYPE STRING OPTIONAL
*" EXPORTING
*" VALUE(EV_OUTPUT) TYPE STRING
*" EXCEPTIONS
*" NUM_RANGE_ERROR
*"----------------------------------------------------------------------
DATA: ls_input TYPE ty_sd001.
DATA: ls_output TYPE ty_sd001_o.
DATA lv_seqnr TYPE zeseqnr.
DATA:ls_cvis_bp_general TYPE cvis_bp_general,
lt_cvis_bp_general LIKE TABLE OF ls_cvis_bp_general,
ls_cvis_bp_role TYPE cvis_bp_role,
lt_cvis_bp_role LIKE TABLE OF ls_cvis_bp_role,
ls_cvis_bp_tax_number TYPE cvis_bp_tax_number,
lt_cvis_bp_tax_number LIKE TABLE OF ls_cvis_bp_tax_number,
ls_cvis_bp_address TYPE cvis_bp_address,
lt_cvis_bp_address LIKE TABLE OF ls_cvis_bp_address,
ls_cvis_bp_address_teleno TYPE cvis_bp_address_teleno, "电话号码
lt_cvis_bp_address_teleno LIKE TABLE OF ls_cvis_bp_address_teleno,
ls_cvis_bp_address_faxno TYPE cvis_bp_address_faxno,
lt_cvis_bp_address_faxno LIKE TABLE OF ls_cvis_bp_address_faxno, "传真号码
ls_cvis_bp_address_email TYPE cvis_bp_address_email,
lt_cvis_bp_address_email LIKE TABLE OF ls_cvis_bp_address_email, "邮箱号码
ls_cvis_bp_finserv TYPE cvis_bp_finserv,
lt_cvis_bp_finserv LIKE TABLE OF cvis_bp_finserv, "分组字符
ls_cvis_customer_company TYPE cvis_customer_company,
lt_cvis_customer_company LIKE TABLE OF ls_cvis_customer_company, "公司代码
ls_cvis_customer_sales TYPE cvis_customer_sales,
lt_cvis_customer_sales LIKE TABLE OF ls_cvis_customer_sales, "销售视图相关
ls_cvis_customer_sales_func TYPE cvis_customer_sales_func,
lt_cvis_customer_sales_func LIKE TABLE OF ls_cvis_customer_sales_func, "伙伴功能
ls_cvis_customer_tax_indicator TYPE cvis_customer_tax_indicator,
lt_cvis_customer_tax_indicator LIKE TABLE OF ls_cvis_customer_tax_indicator, "销售视图税
ls_cvis_customer_general TYPE cvis_customer_general,
lt_cvis_customer_general LIKE TABLE OF ls_cvis_customer_general,
* ls_cvis_supplier_general LIKE cvis_supplier_general,
* lt_cvis_supplier_general LIKE TABLE OF ls_cvis_supplier_general,
* ls_cvis_bp_ident_numbers LIKE cvis_bp_ident_numbers,
* lt_cvis_bp_ident_numbers LIKE TABLE OF ls_cvis_bp_ident_numbers,
ls_cvis_bp_bank_details LIKE cvis_bp_bank_details,
lt_cvis_bp_bank_details LIKE TABLE OF ls_cvis_bp_bank_details,
lt_cvis_bp_return LIKE TABLE OF cvis_bp_return.
DATA: lt_return TYPE ukm_t_monitor_return.
DATA: l_run_id TYPE cvi_run_id,
lv_guid TYPE but000-partner_guid.
/ui2/cl_json=>deserialize( EXPORTING json = iv_input CHANGING data = ls_input ).
CLEAR ls_output.
" check data
IF ls_input-bu_group IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '分组(BU_GROUP):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-title IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '称谓(TITLE):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-name_org1 IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '名称(NAME_ORG1):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-bu_sort1 IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '搜索项1(BU_SORT1):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-stras IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '街道(STRAS):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-land1 IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '国家(LAND1):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-spras IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '语言(SPRAS):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-bukrs IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '公司代码(BUKRS):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-akont IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '统驭科目(AKONT):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-zuawa IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '排序码(ZUAWA):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-zterm IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '付款条件(ZTERM):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-vkorg IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '销售组织(VKORG):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-vtweg IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '分销渠道(VTWEG):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-spart IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '产品组(SPART):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-bzirk IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '销售区域(BZIRK):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-kdgrp IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '客户组(KDGRP):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-vkbur IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '销售部门(VKBUR):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-vkgrp IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '销售组(VKGRP):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-waers IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '币种(WAERS):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-kalks IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '定价过程(KALKS):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-taxkd IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '税分类(TAXKD):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-aland IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '国家/地区(ALAND):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSEIF ls_input-tatyp IS INITIAL.
ls_output-msgty = 'E'.
ls_output-msgtx = '税收类别(TATYP):值必输!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ENDIF.
"Process data
"统驭科目
IF ls_input-partner IS NOT INITIAL.
ls_input-partner = |{ ls_input-partner ALPHA = IN }|.
"Determine UPDATE OR CREATE?
SELECT SINGLE partner_guid INTO lv_guid "业务伙伴是否存在
FROM but000 WHERE partner = ls_input-partner.
IF lv_guid IS NOT INITIAL.
ls_cvis_bp_general-object_task = 'U'. "I:创建BP U:修改BP
ELSE. "输入了值,实际数据库没有
TRY.
CALL METHOD cl_system_uuid=>if_system_uuid_static~create_uuid_c32
RECEIVING
uuid = lv_guid. "唯一标识
CATCH cx_uuid_error .
ENDTRY.
ls_cvis_bp_general-object_task = 'I'. "I:创建BP U:修改BP
CLEAR ls_input-partner.
ENDIF.
ELSE.
TRY.
CALL METHOD cl_system_uuid=>if_system_uuid_static~create_uuid_c32
RECEIVING
uuid = lv_guid. "唯一标识
CATCH cx_uuid_error .
ENDTRY.
ls_cvis_bp_general-object_task = 'I'. "I:创建BP U:修改BP
ENDIF.
ls_input-akont = |{ ls_input-akont ALPHA = IN }|.
l_run_id = '1000000'.
* bp_general 一般数据赋值
ls_cvis_bp_general-run_id = l_run_id. "用于区分不同实例的 CVI 运行标识
ls_cvis_bp_general-category = '2'. "业务伙伴类别
ls_cvis_bp_general-bpartnerguid = lv_guid. "GUID
ls_cvis_bp_general-grouping = ls_input-bu_group. "业务合作伙伴组
ls_cvis_bp_general-title_key = ls_input-title. "称谓
ls_cvis_bp_general-name1 = ls_input-name_org1. "名称
ls_cvis_bp_general-searchterm1 = ls_input-bu_sort1. "搜索项1
ls_cvis_bp_general-searchterm2 = ls_input-bpext. "搜索项2
APPEND ls_cvis_bp_general TO lt_cvis_bp_general.
CLEAR ls_cvis_bp_general.
*bp_address 地址数据
ls_cvis_bp_address-run_id = l_run_id.
ls_cvis_bp_address-guid = lv_guid. "GUID
ls_cvis_bp_address-comm_type = 'INT'. "通讯方法 (关键字)(业务地址服务)
ls_cvis_bp_address-street = ls_input-stras. "街道street-str_suppl1-str_supp2-str_suppl3
ls_cvis_bp_address-postl_cod1 = ls_input-pstlz. "邮编
ls_cvis_bp_address-city = ls_input-ort01. "城市
ls_cvis_bp_address-region = ls_input-regio. "省/地区
ls_cvis_bp_address-country = ls_input-land1. "国家
CALL FUNCTION 'CONVERSION_EXIT_ISOLA_INPUT'
EXPORTING
input = ls_input-spras
IMPORTING
output = ls_cvis_bp_address-langu "语言
EXCEPTIONS
unknown_language = 1
OTHERS = 2.
APPEND ls_cvis_bp_address TO lt_cvis_bp_address.
CLEAR ls_cvis_bp_address.
*bp_Contact
ls_cvis_bp_address_teleno-run_id = l_run_id.
ls_cvis_bp_address_teleno-country = ls_input-land1.
ls_cvis_bp_address_teleno-telephone = ls_input-telf1. "电话
IF strlen( ls_input-telf1 ) = 11.
ls_cvis_bp_address_teleno-r_3_user = '2'."1 电话是缺省陆上电缆电话 2 电话是移动电话不是缺省陆上电缆电话 3 电话是缺省移动电话
ENDIF.
APPEND ls_cvis_bp_address_teleno TO lt_cvis_bp_address_teleno .
CLEAR ls_cvis_bp_address_teleno.
ls_cvis_bp_address_faxno-run_id = l_run_id.
ls_cvis_bp_address_faxno-country = ls_input-land1.
ls_cvis_bp_address_faxno-fax = ls_input-telfx. "传真
APPEND ls_cvis_bp_address_faxno TO lt_cvis_bp_address_faxno.
CLEAR ls_cvis_bp_address_faxno.
*bp_role
ls_cvis_bp_role-run_id = l_run_id.
ls_cvis_bp_role-data_key = 'JPCU01'. "业务伙伴角色
APPEND ls_cvis_bp_role TO lt_cvis_bp_role.
CLEAR ls_cvis_bp_role.
ls_cvis_bp_role-run_id = l_run_id.
ls_cvis_bp_role-data_key = 'JPCU02'. "业务伙伴角色
APPEND ls_cvis_bp_role TO lt_cvis_bp_role.
CLEAR ls_cvis_bp_role.
ls_cvis_bp_role-run_id = l_run_id.
ls_cvis_bp_role-data_key = 'UKM000'. "业务伙伴角色
APPEND ls_cvis_bp_role TO lt_cvis_bp_role.
CLEAR ls_cvis_bp_role.
*bp_cus_general
ls_cvis_customer_general-object_task = ls_cvis_bp_general-object_task.
ls_cvis_customer_general-run_id = l_run_id.
ls_cvis_customer_general-katr1 = ls_input-katr1. "属性1
ls_cvis_customer_general-bran1 = ls_input-bran1. "行业代码1
ls_cvis_customer_general-kukla = ls_input-kukla. "客户分类
APPEND ls_cvis_customer_general TO lt_cvis_customer_general.
CLEAR ls_cvis_customer_general.
ls_cvis_customer_company-run_id = l_run_id.
ls_cvis_customer_company-bukrs = ls_input-bukrs. "公司代码
ls_cvis_customer_company-akont = ls_input-akont . "总帐中的统驭科目
ls_cvis_customer_company-zuawa = ls_input-zuawa. "排序码
ls_cvis_customer_company-zterm = ls_input-zterm. "付款条件
APPEND ls_cvis_customer_company TO lt_cvis_customer_company . "公司代码
CLEAR ls_cvis_customer_company.
*bp_sales
ls_cvis_customer_sales-run_id = l_run_id.
ls_cvis_customer_sales-vkorg = ls_input-bukrs. "销售组织.
ls_cvis_customer_sales-vtweg = ls_input-vtweg. "分销渠道
ls_cvis_customer_sales-spart = ls_input-spart. "产品组
ls_cvis_customer_sales-bzirk = ls_input-bzirk. "销售地区
ls_cvis_customer_sales-kdgrp = ls_input-kdgrp. "客户组
ls_cvis_customer_sales-kvgr1 = ls_input-kvgr1. "客户组1
ls_cvis_customer_sales-vkbur = ls_input-vkbur. "销售部门
ls_cvis_customer_sales-vkgrp = ls_input-vkgrp. "销售组
ls_cvis_customer_sales-waers = ls_input-waers. "币种
ls_cvis_customer_sales-konda = ls_input-konda. "价格组
ls_cvis_customer_sales-kalks = ls_input-kalks. "定价过程
ls_cvis_customer_sales-kzazu = ls_input-kzazu. "订单组合
ls_cvis_customer_sales-vwerk = ls_input-vwerk. "交货工厂
ls_cvis_customer_sales-vsbed = ls_input-vsbed. "装运条件
ls_cvis_customer_sales-inco1 = ls_input-inco1. "国际贸易条款
ls_cvis_customer_sales-zterm = ls_input-zterm. "付款条件
ls_cvis_customer_sales-inco2_l = ls_input-inco2_l. "国际贸易位置
ls_cvis_customer_sales-kkber = ls_input-kkber. "信用控制范围
ls_cvis_customer_sales-ktgrd = ls_input-ktgrd. "客户账户分配组
APPEND ls_cvis_customer_sales TO lt_cvis_customer_sales.
CLEAR ls_cvis_customer_sales.
ls_cvis_customer_sales_func-run_id = l_run_id.
ls_cvis_customer_sales_func-vkorg = ls_input-bukrs."销售组织.
ls_cvis_customer_sales_func-vtweg = ls_input-vtweg. "分销渠道
ls_cvis_customer_sales_func-spart = ls_input-spart. "产品组
ls_cvis_customer_sales_func-parvw = 'AG'."伙伴功能 SP
* LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.
ls_cvis_customer_sales_func-parvw = 'RE'."伙伴功能 BP
* LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.
ls_cvis_customer_sales_func-parvw = 'RG'."伙伴功能 PY
* LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.
ls_cvis_customer_sales_func-parvw = 'WE'."伙伴功能 SH
* LS_CVIS_CUSTOMER_SALES_FUNC-PARTNER = .
APPEND ls_cvis_customer_sales_func TO lt_cvis_customer_sales_func.
CLEAR ls_cvis_customer_sales_func.
*bp_tax
ls_cvis_customer_tax_indicator-run_id = l_run_id.
ls_cvis_customer_tax_indicator-taxkd = ls_input-taxkd. "税分类
ls_cvis_customer_tax_indicator-aland = ls_input-aland. "税-国家/地区
ls_cvis_customer_tax_indicator-tatyp = ls_input-tatyp. "税类别
APPEND ls_cvis_customer_tax_indicator TO lt_cvis_customer_tax_indicator. "销售视图税
CLEAR ls_cvis_customer_tax_indicator.
IF ls_input-taxnumxl IS NOT INITIAL.
ls_cvis_bp_tax_number-run_id = l_run_id.
ls_cvis_bp_tax_number-taxtype = ls_input-taxtype. "税号类别
ls_cvis_bp_tax_number-taxnumber = ls_input-taxnumxl. "税务登记证号
APPEND ls_cvis_bp_tax_number TO lt_cvis_bp_tax_number.
CLEAR ls_cvis_bp_tax_number.
ENDIF.
*bp_bank_detail
IF ls_input-bankl IS NOT INITIAL.
ls_cvis_bp_bank_details-run_id = l_run_id.
ls_cvis_bp_bank_details-bank_ctry = ls_input-banks. "银行国家
ls_cvis_bp_bank_details-bank_key = ls_input-bankl. "银行代码
ls_cvis_bp_bank_details-bank_acct = ls_input-bankn. "银行账号
ls_cvis_bp_bank_details-bank_ref = ls_input-bkref. "银行账号的参考明细
ls_cvis_bp_bank_details-accountholder = ls_input-koinh. "账户持有人
APPEND ls_cvis_bp_bank_details TO lt_cvis_bp_bank_details.
CLEAR ls_cvis_bp_bank_details.
ENDIF.
CALL FUNCTION 'RFC_CVI_EI_INBOUND_MAIN'
EXPORTING
iv_docommit = 'X'
iv_create_applog = 'X' "API Logging 可通过SLG1查看
TABLES
it_bp_general = lt_cvis_bp_general
it_bp_role = lt_cvis_bp_role
it_bp_tax_number = lt_cvis_bp_tax_number
it_bp_address_teleno = lt_cvis_bp_address_teleno "电话号码
it_bp_address_faxno = lt_cvis_bp_address_faxno "传真号码
it_bp_address_email = lt_cvis_bp_address_email "邮箱号码
it_bp_finserv = lt_cvis_bp_finserv "分组字符
* it_bp_ident_numbers = lt_cvis_bp_ident_numbers
it_cust_general = lt_cvis_customer_general
it_cust_company = lt_cvis_customer_company "公司代码
it_cust_sales = lt_cvis_customer_sales "销售视图相关
it_cust_sales_functions = lt_cvis_customer_sales_func "伙伴功能
it_cust_tax_indicator = lt_cvis_customer_tax_indicator "销售视图税
* it_sup_general = lt_cvis_supplier_general
it_bp_bank_details = lt_cvis_bp_bank_details
it_bp_address = lt_cvis_bp_address
ct_return = lt_cvis_bp_return.
IF line_exists( lt_cvis_bp_return[ type = 'E' ] ) OR
line_exists( lt_cvis_bp_return[ type = 'A' ] ).
SELECT SINGLE * FROM
@lt_cvis_bp_return AS a
WHERE type IN ( 'A','E' )
INTO @DATA(wa_cvis_bp_return).
ls_output-msgty = wa_cvis_bp_return-type.
ls_output-msgtx = |创建BP失败!消息号:{ wa_cvis_bp_return-id }{ wa_cvis_bp_return-number } 消息文本:{ wa_cvis_bp_return-message }|.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSE.
ls_output-crm_bp = ls_input-bpext. "CRM BP = 搜索项2
SELECT SINGLE object_key "BP 编号
FROM @lt_cvis_bp_return AS a
WHERE object_key <> ''
AND type = 'S'
INTO @ls_output-partner.
ls_output-msgty = 'S'.
ls_output-msgtx = 'BP创建成功'.
ls_input-partner = ls_output-partner.
PERFORM frm_bp_sgm USING ls_input CHANGING lt_return. "Region 信用段数据维护
IF line_exists( lt_return[ msgty = 'E' ] ) OR
line_exists( lt_return[ msgty = 'A' ] ).
SELECT SINGLE * FROM
@lt_return AS a
WHERE msgty IN ( 'A','E' )
INTO @DATA(wa_return).
ls_output-msgty = wa_return-msgty.
ls_output-msgtx = ls_output-msgtx && '/' && |创建BP失败!消息号:{ wa_return-msgid }{ wa_return-msgno } 消息文本:{ wa_return-message }|.
ev_output = /ui2/cl_json=>serialize( ls_output ).
EXIT.
ELSE.
ls_output-msgtx = ls_output-msgtx && '/' && 'BP信用创建成功!'.
ev_output = /ui2/cl_json=>serialize( ls_output ).
ENDIF.
ENDIF.
REFRESH:lt_cvis_bp_general,
lt_cvis_bp_role,
lt_cvis_bp_tax_number,
lt_cvis_bp_bank_details,
lt_cvis_bp_address_teleno, "电话号码
lt_cvis_bp_address_faxno, "传真号码
lt_cvis_bp_address_email, "邮箱号码
lt_cvis_bp_finserv, "分组字符
* lt_cvis_bp_ident_numbers,
lt_cvis_customer_general,
lt_cvis_customer_company, "公司代码
lt_cvis_customer_sales, "销售视图相关
lt_cvis_customer_tax_indicator, "销售视图税
lt_cvis_customer_sales_func,"伙伴功能
* lt_cvis_supplier_general,
* lt_cvis_bp_bank_details,
lt_cvis_bp_address,
lt_cvis_bp_return.
CLEAR: lt_return,lv_guid.
ENDFUNCTION.
FORM frm_bp_sgm USING p_ls_input TYPE ty_sd001
CHANGING p_return TYPE ukm_t_monitor_return.
DATA : io_facade TYPE REF TO cl_ukm_facade,
io_calculator TYPE REF TO if_ukm_calculator,
io_partner TYPE REF TO cl_ukm_business_partner,
io_bupa_factory TYPE REF TO cl_ukm_bupa_factory,
io_account TYPE REF TO cl_ukm_account,
lw_bp_credit_sgm TYPE ukm_s_bp_cms_sgm,
lw_ukm_s_bp_cms TYPE ukm_s_bp_cms.
IF p_ls_input-risk_class IS NOT INITIAL.
* 创建'MAINTAIN'对象
io_facade = cl_ukm_facade=>create( i_activity = cl_ukm_cnst_eventing=>bp_maintenance ).
io_calculator = io_facade->get_calculator( ).
io_bupa_factory = io_facade->get_bupa_factory( ).
*read businee partner
io_partner = io_bupa_factory->get_business_partner( p_ls_input-partner ).
CALL METHOD io_bupa_factory->get_credit_account
EXPORTING
i_partner = p_ls_input-partner "客户代码
i_credit_sgmnt = p_ls_input-credit_sgmnt "信用段
RECEIVING
ro_credit_account = io_account.
io_account->get_bp_cms_sgm( IMPORTING es_bp_cms_sgm = lw_bp_credit_sgm ).
*信用
lw_ukm_s_bp_cms-risk_class = p_ls_input-risk_class. "风险类
lw_ukm_s_bp_cms-check_rule = p_ls_input-check_rule. "检查规则
lw_ukm_s_bp_cms-limit_rule = p_ls_input-limit_rule."信用参数文件记分规则
io_partner->set_bp_cms( lw_ukm_s_bp_cms ).
*信用段
lw_bp_credit_sgm-credit_limit = p_ls_input-credit_limit."信用金额
lw_bp_credit_sgm-xcritical = 'X'.
lw_bp_credit_sgm-limit_chg_date = sy-datum.
lw_bp_credit_sgm-limit_valid_date = p_ls_input-limit_valid_date. "有效至
io_account->set_bp_cms_sgm( EXPORTING is_bp_cms_sgm = lw_bp_credit_sgm ).
io_bupa_factory->save_all( EXPORTING i_upd_task = abap_false
RECEIVING et_return = p_return ).
IF line_exists( p_return[ msgty = 'E' ] ) OR
line_exists( p_return[ msgty = 'A' ] ).
ROLLBACK WORK.
ELSE.
COMMIT WORK AND WAIT.
ENDIF.
ENDIF.
ENDFORM.
4. 其他
- SLG1可查看RFC_CVI_EI_INBOUND_MAIN创建的错误日志
|