mirror of
https://github.com/abapGit/abapGit.git
synced 2025-04-30 20:03:20 +08:00
SFPI support #99
This commit is contained in:
parent
42e618c89b
commit
fd468a2b77
|
@ -29,6 +29,7 @@ INCLUDE zabapgit_object_pinf.
|
|||
INCLUDE zabapgit_object_prog.
|
||||
INCLUDE zabapgit_object_sfbf.
|
||||
INCLUDE zabapgit_object_sfbs.
|
||||
INCLUDE zabapgit_object_sfpi.
|
||||
INCLUDE zabapgit_object_sfsw.
|
||||
INCLUDE zabapgit_object_shi3.
|
||||
INCLUDE zabapgit_object_shlp.
|
||||
|
|
168
src/zabapgit_object_sfpi.prog.abap
Normal file
168
src/zabapgit_object_sfpi.prog.abap
Normal file
|
@ -0,0 +1,168 @@
|
|||
*&---------------------------------------------------------------------*
|
||||
*& Include ZABAPGIT_OBJECT_DOMA
|
||||
*&---------------------------------------------------------------------*
|
||||
|
||||
*----------------------------------------------------------------------*
|
||||
* CLASS lcl_object_doma DEFINITION
|
||||
*----------------------------------------------------------------------*
|
||||
*
|
||||
*----------------------------------------------------------------------*
|
||||
CLASS lcl_object_sfpi DEFINITION INHERITING FROM lcl_objects_super FINAL.
|
||||
|
||||
PUBLIC SECTION.
|
||||
INTERFACES lif_object.
|
||||
ALIASES mo_files FOR lif_object~mo_files.
|
||||
|
||||
PRIVATE SECTION.
|
||||
METHODS:
|
||||
load
|
||||
RETURNING VALUE(ri_wb_interface) TYPE REF TO if_fp_wb_interface
|
||||
RAISING lcx_exception,
|
||||
interface_to_xstring
|
||||
RETURNING VALUE(rv_xstr) TYPE xstring
|
||||
RAISING lcx_exception.
|
||||
|
||||
ENDCLASS. "lcl_object_doma DEFINITION
|
||||
|
||||
*----------------------------------------------------------------------*
|
||||
* CLASS lcl_object_doma IMPLEMENTATION
|
||||
*----------------------------------------------------------------------*
|
||||
*
|
||||
*----------------------------------------------------------------------*
|
||||
CLASS lcl_object_sfpi IMPLEMENTATION.
|
||||
|
||||
METHOD lif_object~has_changed_since.
|
||||
rv_changed = abap_true.
|
||||
ENDMETHOD. "lif_object~has_changed_since
|
||||
|
||||
METHOD lif_object~changed_by.
|
||||
|
||||
SELECT SINGLE lastuser FROM fpinterface
|
||||
INTO rv_user
|
||||
WHERE name = ms_item-obj_name
|
||||
AND state = 'A'.
|
||||
IF rv_user IS INITIAL.
|
||||
SELECT SINGLE firstuser FROM fpinterface
|
||||
INTO rv_user
|
||||
WHERE name = ms_item-obj_name
|
||||
AND state = 'A'.
|
||||
ENDIF.
|
||||
IF rv_user IS INITIAL.
|
||||
rv_user = c_user_unknown.
|
||||
ENDIF.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~get_metadata.
|
||||
rs_metadata = get_metadata( ).
|
||||
ENDMETHOD. "lif_object~get_metadata
|
||||
|
||||
METHOD lif_object~exists.
|
||||
|
||||
DATA: lv_name TYPE fpinterface-name.
|
||||
|
||||
SELECT SINGLE name FROM fpinterface
|
||||
INTO lv_name
|
||||
WHERE name = ms_item-obj_name
|
||||
AND state = 'A'.
|
||||
rv_bool = boolc( sy-subrc = 0 ).
|
||||
|
||||
ENDMETHOD. "lif_object~exists
|
||||
|
||||
METHOD lif_object~jump.
|
||||
lcx_exception=>raise( 'todo, SFPI jump' ).
|
||||
ENDMETHOD. "jump
|
||||
|
||||
METHOD lif_object~delete.
|
||||
|
||||
DATA: lv_name TYPE fpname,
|
||||
lo_wb_interface TYPE REF TO cl_fp_wb_interface.
|
||||
|
||||
|
||||
lo_wb_interface ?= load( ).
|
||||
|
||||
lv_name = ms_item-obj_name.
|
||||
|
||||
TRY.
|
||||
lo_wb_interface->delete( lv_name ).
|
||||
CATCH cx_fp_api.
|
||||
lcx_exception=>raise( 'SFPI error, delete' ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD. "delete
|
||||
|
||||
METHOD load.
|
||||
|
||||
DATA: lv_name TYPE fpname.
|
||||
|
||||
|
||||
lv_name = ms_item-obj_name.
|
||||
|
||||
TRY.
|
||||
ri_wb_interface = cl_fp_wb_interface=>load( lv_name ).
|
||||
CATCH cx_fp_api.
|
||||
lcx_exception=>raise( 'SFPI error, load' ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD interface_to_xstring.
|
||||
|
||||
DATA: lv_xstr TYPE xstring,
|
||||
li_fp_interface TYPE REF TO if_fp_interface,
|
||||
li_wb_interface TYPE REF TO if_fp_wb_interface.
|
||||
|
||||
|
||||
TRY.
|
||||
li_wb_interface = load( ).
|
||||
li_fp_interface ?= li_wb_interface->get_object( ).
|
||||
rv_xstr = cl_fp_helper=>convert_interface_to_xstring( li_fp_interface ).
|
||||
CATCH cx_fp_api.
|
||||
lcx_exception=>raise( 'SFPI error, interface_to_xstring' ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~serialize.
|
||||
|
||||
DATA: lv_xstr TYPE xstring,
|
||||
li_document TYPE REF TO if_ixml_document.
|
||||
|
||||
|
||||
lv_xstr = interface_to_xstring( ).
|
||||
li_document = cl_ixml_80_20=>parse_to_document( stream_xstring = lv_xstr ).
|
||||
io_xml->set_raw( li_document->get_root_element( ) ).
|
||||
|
||||
ENDMETHOD. "serialize
|
||||
|
||||
METHOD lif_object~deserialize.
|
||||
|
||||
DATA: lv_xstr TYPE xstring,
|
||||
lv_name TYPE fpname,
|
||||
li_wb_object TYPE REF TO if_fp_wb_interface,
|
||||
li_interface TYPE REF TO if_fp_interface.
|
||||
|
||||
|
||||
lv_name = ms_item-obj_name.
|
||||
lv_xstr = cl_ixml_80_20=>render_to_xstring( io_xml->get_raw( ) ).
|
||||
|
||||
TRY.
|
||||
li_interface = cl_fp_helper=>convert_xstring_to_interface( lv_xstr ).
|
||||
tadir_insert( iv_package ).
|
||||
li_wb_object = cl_fp_wb_interface=>create( i_name = lv_name
|
||||
i_interface = li_interface ).
|
||||
li_wb_object->save( ).
|
||||
li_wb_object->free( ).
|
||||
CATCH cx_fp_api.
|
||||
lcx_exception=>raise( 'SFPI error, deserialize' ).
|
||||
ENDTRY.
|
||||
|
||||
lcl_objects_activation=>add_item( ms_item ).
|
||||
|
||||
ENDMETHOD. "deserialize
|
||||
|
||||
METHOD lif_object~compare_to_remote_version.
|
||||
CREATE OBJECT ro_comparison_result TYPE lcl_null_comparison_result.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS. "lcl_object_doma IMPLEMENTATION
|
22
src/zabapgit_object_sfpi.prog.xml
Normal file
22
src/zabapgit_object_sfpi.prog.xml
Normal file
|
@ -0,0 +1,22 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<abapGit version="v1.0.0" serializer="LCL_OBJECT_PROG" serializer_version="v1.0.0">
|
||||
<asx:abap xmlns:asx="http://www.sap.com/abapxml" version="1.0">
|
||||
<asx:values>
|
||||
<PROGDIR>
|
||||
<NAME>ZABAPGIT_OBJECT_SFPI</NAME>
|
||||
<STATE>A</STATE>
|
||||
<VARCL>X</VARCL>
|
||||
<SUBC>I</SUBC>
|
||||
<RLOAD>E</RLOAD>
|
||||
<UCCHECK>X</UCCHECK>
|
||||
</PROGDIR>
|
||||
<TPOOL>
|
||||
<item>
|
||||
<ID>R</ID>
|
||||
<ENTRY>Include ZABAPGIT_OBJECT_DOMA</ENTRY>
|
||||
<LENGTH>28</LENGTH>
|
||||
</item>
|
||||
</TPOOL>
|
||||
</asx:values>
|
||||
</asx:abap>
|
||||
</abapGit>
|
|
@ -200,7 +200,7 @@ CLASS lcl_object_ssfo IMPLEMENTATION.
|
|||
CREATE OBJECT lo_sf.
|
||||
|
||||
* set "created by" and "changed by" to current user
|
||||
li_iterator = io_xml->get_raw( )->create_iterator( ).
|
||||
li_iterator = io_xml->get_raw( )->get_root_element( )->create_iterator( ).
|
||||
li_node = li_iterator->get_next( ).
|
||||
WHILE NOT li_node IS INITIAL.
|
||||
lv_name = li_node->get_name( ).
|
||||
|
@ -226,7 +226,7 @@ CLASS lcl_object_ssfo IMPLEMENTATION.
|
|||
mode = 'INSERT'
|
||||
formname = lv_formname ).
|
||||
|
||||
lo_sf->xml_upload( EXPORTING dom = io_xml->get_raw( )
|
||||
lo_sf->xml_upload( EXPORTING dom = io_xml->get_raw( )->get_root_element( )
|
||||
formname = lv_formname
|
||||
language = mv_language
|
||||
CHANGING sform = lo_res ).
|
||||
|
|
|
@ -294,7 +294,7 @@ CLASS lcl_xml_input DEFINITION FINAL INHERITING FROM lcl_xml CREATE PUBLIC.
|
|||
CHANGING cg_data TYPE any
|
||||
RAISING lcx_exception,
|
||||
get_raw
|
||||
RETURNING VALUE(ri_raw) TYPE REF TO if_ixml_node,
|
||||
RETURNING VALUE(ri_raw) TYPE REF TO if_ixml_document,
|
||||
* todo, add read_xml to match add_xml in lcl_xml_output
|
||||
get_metadata
|
||||
RETURNING VALUE(rs_metadata) TYPE ty_metadata.
|
||||
|
@ -320,7 +320,7 @@ CLASS lcl_xml_input IMPLEMENTATION.
|
|||
ENDMETHOD. "constructor
|
||||
|
||||
METHOD get_raw.
|
||||
ri_raw = mi_xml_doc->get_root_element( ).
|
||||
ri_raw = mi_xml_doc.
|
||||
ENDMETHOD. "get_raw
|
||||
|
||||
METHOD fix_xml.
|
||||
|
|
Loading…
Reference in New Issue
Block a user