mirror of
https://github.com/abapGit/abapGit.git
synced 2025-04-30 20:03:20 +08:00
Started with BRF+ serialization and fixed some errors from the first attempt (#4797)
* Fixed Version BRF+ Integration * BRF+ serialization * Fixed obsolete parameters and wrong boolean type * Fixed some errors and filtered ComponentReleeases ComponentReleeases in XML Export and Import of BRF+ API can be omitted and works also the same. Next try if I could delete the useless metadata (User, System, etc...) or must leave them empty and fill them manually before deserialization. * Some little changes Removed Parameter iv_marked_option for older releases and removed method wb_request_choice. Changed to transport automatically. Aligned some parameters. Co-authored-by: Lars Hvam <larshp@hotmail.com> Co-authored-by: Marc Bernard <59966492+mbtools@users.noreply.github.com>
This commit is contained in:
parent
3defa2c165
commit
30615e848e
399
src/objects/zcl_abapgit_object_fdt0.clas.abap
Normal file
399
src/objects/zcl_abapgit_object_fdt0.clas.abap
Normal file
|
@ -0,0 +1,399 @@
|
|||
CLASS zcl_abapgit_object_fdt0 DEFINITION
|
||||
PUBLIC
|
||||
INHERITING FROM zcl_abapgit_objects_super
|
||||
FINAL
|
||||
CREATE PUBLIC .
|
||||
PUBLIC SECTION.
|
||||
INTERFACES zif_abapgit_object .
|
||||
ALIASES mo_files
|
||||
FOR zif_abapgit_object~mo_files .
|
||||
PROTECTED SECTION.
|
||||
|
||||
PRIVATE SECTION.
|
||||
|
||||
METHODS check_is_local
|
||||
RETURNING
|
||||
VALUE(rv_is_local) TYPE abap_bool .
|
||||
METHODS get_application_id
|
||||
RETURNING
|
||||
VALUE(rv_application_id) TYPE fdt_admn_0000s-application_id .
|
||||
METHODS before_xml_deserialize
|
||||
IMPORTING
|
||||
!iv_package TYPE devclass
|
||||
EXPORTING
|
||||
!ev_create TYPE abap_bool
|
||||
!ev_is_local TYPE abap_bool
|
||||
CHANGING
|
||||
!co_dom_tree TYPE REF TO if_ixml_document
|
||||
RAISING
|
||||
zcx_abapgit_exception .
|
||||
METHODS filter_xml_serialize
|
||||
CHANGING
|
||||
!co_ixml_element TYPE REF TO if_ixml_element
|
||||
RAISING
|
||||
zcx_abapgit_exception .
|
||||
ENDCLASS.
|
||||
|
||||
|
||||
|
||||
CLASS ZCL_ABAPGIT_OBJECT_FDT0 IMPLEMENTATION.
|
||||
|
||||
|
||||
METHOD before_xml_deserialize.
|
||||
|
||||
DATA lv_application_id TYPE fdt_admn_0000s-application_id.
|
||||
DATA lv_package_xml_value TYPE string.
|
||||
DATA lo_node_local TYPE REF TO if_ixml_element.
|
||||
DATA lo_node_package TYPE REF TO if_ixml_element.
|
||||
DATA lo_node_id TYPE REF TO if_ixml_element.
|
||||
DATA lv_count TYPE i.
|
||||
|
||||
lo_node_local = co_dom_tree->find_from_name( name = 'Local'
|
||||
namespace = 'FDTNS' ).
|
||||
|
||||
IF lo_node_local IS BOUND.
|
||||
ev_is_local = lo_node_local->get_value( ).
|
||||
ENDIF.
|
||||
|
||||
lo_node_package = co_dom_tree->find_from_name(
|
||||
name = 'DevelopmentPackage'
|
||||
namespace = 'FDTNS' ).
|
||||
IF lo_node_package IS BOUND.
|
||||
lv_package_xml_value = iv_package.
|
||||
lo_node_package->set_value( value = lv_package_xml_value ).
|
||||
ENDIF.
|
||||
|
||||
lo_node_id = co_dom_tree->find_from_name(
|
||||
name = 'ApplicationId'
|
||||
namespace = 'FDTNS' ).
|
||||
IF lo_node_id IS BOUND.
|
||||
lv_application_id = lo_node_id->get_value( ).
|
||||
SELECT COUNT( * ) FROM fdt_admn_0000s INTO lv_count
|
||||
WHERE object_type = 'AP'
|
||||
AND id = lv_application_id
|
||||
AND deleted = ''.
|
||||
ev_create = boolc( lv_count = 0 ).
|
||||
ENDIF.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD check_is_local.
|
||||
|
||||
SELECT SINGLE local_object FROM fdt_admn_0000s INTO rv_is_local
|
||||
WHERE object_type = 'AP'
|
||||
AND name = ms_item-obj_name.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD filter_xml_serialize.
|
||||
|
||||
DATA lo_components_node TYPE REF TO if_ixml_element.
|
||||
|
||||
lo_components_node = co_ixml_element->find_from_name( name = 'ComponentReleases'
|
||||
namespace = 'FDTNS' ).
|
||||
IF lo_components_node IS BOUND.
|
||||
co_ixml_element->remove_child( old_child = lo_components_node ).
|
||||
ENDIF.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD get_application_id.
|
||||
|
||||
SELECT SINGLE application_id FROM fdt_admn_0000s INTO rv_application_id
|
||||
WHERE object_type = 'AP'
|
||||
AND name = ms_item-obj_name.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~changed_by.
|
||||
|
||||
DATA lv_ch_user TYPE fdt_admn_0000s-ch_user.
|
||||
|
||||
SELECT SINGLE ch_user FROM fdt_admn_0000s INTO lv_ch_user
|
||||
WHERE object_type = 'AP'
|
||||
AND name = ms_item-obj_name.
|
||||
|
||||
rv_user = lv_ch_user.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~delete.
|
||||
|
||||
DATA lv_is_local TYPE abap_bool.
|
||||
DATA lv_ordernum TYPE trkorr.
|
||||
DATA lt_application_sel TYPE if_fdt_query=>ts_selection.
|
||||
DATA ls_application_sel TYPE if_fdt_query=>s_selection.
|
||||
DATA ls_object_category_sel TYPE if_fdt_query=>s_object_category_sel.
|
||||
DATA lv_failure TYPE abap_bool.
|
||||
|
||||
IF zif_abapgit_object~exists( ) = abap_false.
|
||||
RETURN.
|
||||
ENDIF.
|
||||
|
||||
lv_is_local = check_is_local( ).
|
||||
IF lv_is_local = abap_false.
|
||||
lv_ordernum = zcl_abapgit_default_transport=>get_instance( )->get( )-ordernum.
|
||||
ENDIF.
|
||||
|
||||
ls_application_sel-queryfield = 'NAME'.
|
||||
ls_application_sel-sign = 'I'.
|
||||
ls_application_sel-option = 'EQ'.
|
||||
ls_application_sel-low = ms_item-obj_name.
|
||||
INSERT ls_application_sel INTO TABLE lt_application_sel.
|
||||
|
||||
ls_object_category_sel-system_objects = 'X'.
|
||||
|
||||
TRY.
|
||||
|
||||
IF lv_is_local = abap_true. "Local Object
|
||||
|
||||
cl_fdt_delete_handling=>delete_logical_via_job(
|
||||
EXPORTING
|
||||
its_application_selection = lt_application_sel
|
||||
iv_retention_time = 0
|
||||
iv_background = abap_true
|
||||
iv_local_option = '1'
|
||||
iv_appl_transported_option = '2'
|
||||
iv_obj_transported_option = '2'
|
||||
is_object_category_sel = ls_object_category_sel
|
||||
IMPORTING
|
||||
ev_failure = lv_failure ).
|
||||
|
||||
|
||||
ELSE. "Transportable Object
|
||||
|
||||
cl_fdt_delete_handling=>delete_logical_via_job(
|
||||
EXPORTING
|
||||
its_application_selection = lt_application_sel
|
||||
iv_retention_time = 0
|
||||
iv_background = abap_true
|
||||
iv_local_option = '2'
|
||||
iv_appl_transported_option = '1'
|
||||
iv_obj_transported_option = '1'
|
||||
is_object_category_sel = ls_object_category_sel
|
||||
iv_transport_request_w = lv_ordernum
|
||||
IMPORTING
|
||||
ev_failure = lv_failure ).
|
||||
|
||||
ENDIF.
|
||||
|
||||
IF lv_failure = abap_true.
|
||||
zcx_abapgit_exception=>raise( |Error deleting { ms_item-obj_type } { ms_item-obj_name }| ).
|
||||
ENDIF.
|
||||
|
||||
CATCH cx_fdt_input. "
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~deserialize.
|
||||
|
||||
DATA lo_dexc TYPE REF TO if_fdt_data_exchange.
|
||||
DATA lx_root TYPE REF TO cx_root.
|
||||
DATA lo_dom_tree TYPE REF TO if_ixml_document.
|
||||
DATA lv_is_local TYPE abap_bool.
|
||||
DATA lv_ordernum TYPE trkorr.
|
||||
DATA lt_message TYPE if_fdt_types=>t_message.
|
||||
DATA lv_create TYPE abap_bool.
|
||||
FIELD-SYMBOLS <ls_message> TYPE if_fdt_types=>s_message.
|
||||
|
||||
lo_dom_tree = io_xml->get_raw( ).
|
||||
|
||||
before_xml_deserialize(
|
||||
EXPORTING
|
||||
iv_package = iv_package
|
||||
IMPORTING
|
||||
ev_create = lv_create
|
||||
ev_is_local = lv_is_local
|
||||
CHANGING
|
||||
co_dom_tree = lo_dom_tree ).
|
||||
|
||||
lo_dexc = cl_fdt_factory=>if_fdt_factory~get_instance( )->get_data_exchange( ).
|
||||
|
||||
TRY.
|
||||
|
||||
IF lv_is_local = abap_true. "Local Object
|
||||
|
||||
lo_dexc->import_xml(
|
||||
EXPORTING
|
||||
io_dom_tree = lo_dom_tree
|
||||
iv_create = lv_create
|
||||
iv_activate = abap_true
|
||||
iv_simulate = abap_false
|
||||
IMPORTING
|
||||
et_message = lt_message ).
|
||||
|
||||
ELSE. "Transportable Object
|
||||
|
||||
lv_ordernum = zcl_abapgit_default_transport=>get_instance( )->get( )-ordernum.
|
||||
|
||||
lo_dexc->import_xml(
|
||||
EXPORTING
|
||||
io_dom_tree = lo_dom_tree
|
||||
iv_create = lv_create
|
||||
iv_activate = abap_true
|
||||
iv_simulate = abap_false
|
||||
iv_workbench_trrequest = lv_ordernum
|
||||
IMPORTING
|
||||
et_message = lt_message ).
|
||||
|
||||
ENDIF.
|
||||
|
||||
LOOP AT lt_message ASSIGNING <ls_message>.
|
||||
ii_log->add(
|
||||
iv_msg = <ls_message>-text
|
||||
iv_type = <ls_message>-msgty ).
|
||||
ENDLOOP.
|
||||
|
||||
CATCH cx_fdt_input INTO lx_root. "
|
||||
zcx_abapgit_exception=>raise( lx_root->get_text( ) ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~exists.
|
||||
|
||||
DATA lv_count TYPE i.
|
||||
|
||||
SELECT COUNT( * ) FROM fdt_admn_0000s INTO lv_count
|
||||
WHERE object_type = 'AP'
|
||||
AND name = ms_item-obj_name
|
||||
AND deleted = ''.
|
||||
|
||||
rv_bool = boolc( lv_count > 0 ).
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~get_comparator.
|
||||
|
||||
DATA lo_local_version_output TYPE REF TO zcl_abapgit_xml_output.
|
||||
DATA lo_local_version_input TYPE REF TO zcl_abapgit_xml_input.
|
||||
|
||||
CREATE OBJECT lo_local_version_output.
|
||||
zif_abapgit_object~serialize( lo_local_version_output ).
|
||||
|
||||
CREATE OBJECT lo_local_version_input
|
||||
EXPORTING
|
||||
iv_xml = lo_local_version_output->zif_abapgit_xml_output~render( ).
|
||||
|
||||
CREATE OBJECT ri_comparator TYPE zcl_abapgit_object_tabl_compar
|
||||
EXPORTING
|
||||
ii_local = lo_local_version_input.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~get_deserialize_steps.
|
||||
|
||||
APPEND zif_abapgit_object=>gc_step_id-abap TO rt_steps.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~get_metadata.
|
||||
|
||||
rs_metadata = get_metadata( ).
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~is_active.
|
||||
|
||||
DATA lv_application_id TYPE fdt_admn_0000s-application_id.
|
||||
DATA lx_fdt_input TYPE REF TO cx_fdt_input.
|
||||
DATA lo_instance TYPE REF TO if_fdt_admin_data.
|
||||
DATA lt_version TYPE if_fdt_admin_data=>ts_version.
|
||||
DATA lv_index LIKE sy-tabix.
|
||||
FIELD-SYMBOLS <ls_version> LIKE LINE OF lt_version.
|
||||
|
||||
lv_application_id = get_application_id( ).
|
||||
|
||||
TRY.
|
||||
cl_fdt_factory=>get_instance_generic( EXPORTING iv_id = lv_application_id
|
||||
IMPORTING eo_instance = lo_instance ).
|
||||
CATCH cx_fdt_input INTO lx_fdt_input. "
|
||||
zcx_abapgit_exception=>raise( lx_fdt_input->get_text( ) ).
|
||||
ENDTRY.
|
||||
|
||||
lo_instance->get_versions( IMPORTING ets_version = lt_version ).
|
||||
lv_index = lines( lt_version ).
|
||||
READ TABLE lt_version ASSIGNING <ls_version> INDEX lv_index.
|
||||
|
||||
rv_active = boolc( <ls_version>-state = 'A' ).
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~is_locked.
|
||||
DATA lv_application_id TYPE string.
|
||||
|
||||
lv_application_id = get_application_id( ).
|
||||
rv_is_locked = exists_a_lock_entry_for( iv_lock_object = 'FDT_ENQUEUE_ID'
|
||||
iv_argument = |$ST{ lv_application_id }| ).
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~jump.
|
||||
|
||||
DATA lv_application_id TYPE fdt_admn_0000s-application_id.
|
||||
DATA lx_root TYPE REF TO cx_root.
|
||||
DATA lo_fdt_wd TYPE REF TO if_fdt_wd_factory.
|
||||
|
||||
lv_application_id = get_application_id( ).
|
||||
|
||||
IF lv_application_id IS NOT INITIAL.
|
||||
TRY.
|
||||
lo_fdt_wd = cl_fdt_wd_factory=>if_fdt_wd_factory~get_instance( ).
|
||||
lo_fdt_wd->get_ui_execution( )->execute_workbench( iv_id = lv_application_id ).
|
||||
CATCH cx_root INTO lx_root.
|
||||
zcx_abapgit_exception=>raise( lx_root->get_text( ) ).
|
||||
ENDTRY.
|
||||
ELSE.
|
||||
zcx_abapgit_exception=>raise( 'Could not open BRF+ Workbench' ).
|
||||
ENDIF.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD zif_abapgit_object~serialize.
|
||||
|
||||
DATA lo_dexc TYPE REF TO if_fdt_data_exchange.
|
||||
DATA lv_application_id TYPE fdt_admn_0000s-application_id.
|
||||
DATA lx_root TYPE REF TO cx_root.
|
||||
DATA lv_xml_fdt0_application TYPE string.
|
||||
DATA lo_xml_document TYPE REF TO if_ixml_document.
|
||||
DATA lo_xml_element TYPE REF TO if_ixml_element.
|
||||
|
||||
lv_application_id = get_application_id( ).
|
||||
|
||||
lo_dexc = cl_fdt_factory=>if_fdt_factory~get_instance( )->get_data_exchange( ).
|
||||
TRY.
|
||||
lo_dexc->export_xml_application(
|
||||
EXPORTING
|
||||
iv_application_id = lv_application_id
|
||||
iv_schema = if_fdt_data_exchange=>gc_xml_schema_type_external
|
||||
iv_xml_version = if_fdt_data_exchange=>gc_xml_version
|
||||
IMPORTING
|
||||
ev_string = lv_xml_fdt0_application ).
|
||||
|
||||
lo_xml_document = cl_ixml_80_20=>parse_to_document( stream_string = lv_xml_fdt0_application ).
|
||||
lo_xml_element = lo_xml_document->get_root_element( ).
|
||||
|
||||
filter_xml_serialize( CHANGING co_ixml_element = lo_xml_element ).
|
||||
|
||||
io_xml->set_raw( lo_xml_element ).
|
||||
|
||||
CATCH cx_fdt_input INTO lx_root. "
|
||||
zcx_abapgit_exception=>raise( lx_root->get_text( ) ).
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
ENDCLASS.
|
16
src/objects/zcl_abapgit_object_fdt0.clas.xml
Normal file
16
src/objects/zcl_abapgit_object_fdt0.clas.xml
Normal file
|
@ -0,0 +1,16 @@
|
|||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<abapGit version="v1.0.0" serializer="LCL_OBJECT_CLAS" serializer_version="v1.0.0">
|
||||
<asx:abap xmlns:asx="http://www.sap.com/abapxml" version="1.0">
|
||||
<asx:values>
|
||||
<VSEOCLASS>
|
||||
<CLSNAME>ZCL_ABAPGIT_OBJECT_FDT0</CLSNAME>
|
||||
<LANGU>E</LANGU>
|
||||
<DESCRIPT>FDT0 - BRF+ System Application</DESCRIPT>
|
||||
<STATE>1</STATE>
|
||||
<CLSCCINCL>X</CLSCCINCL>
|
||||
<FIXPT>X</FIXPT>
|
||||
<UNICODE>X</UNICODE>
|
||||
</VSEOCLASS>
|
||||
</asx:values>
|
||||
</asx:abap>
|
||||
</abapGit>
|
Loading…
Reference in New Issue
Block a user