mirror of
https://github.com/abapGit/abapGit.git
synced 2025-05-01 12:20:51 +08:00
Merge branch 'master'
Conflicts: src/zabapgit_definitions.prog.abap src/zabapgit_objects_impl.prog.abap src/zabapgit_persistence.prog.abap src/zabapgit_repo_impl.prog.abap src/zabapgit_unit_test.prog.abap src/zabapgit_view_repo.prog.abap
This commit is contained in:
commit
0f8c9bbe85
|
@ -3,7 +3,7 @@ REPORT zabapgit LINE-SIZE 100.
|
|||
* See http://www.abapgit.org
|
||||
|
||||
CONSTANTS: gc_xml_version TYPE string VALUE 'v1.0.0', "#EC NOTEXT
|
||||
gc_abap_version TYPE string VALUE 'v1.18.6'. "#EC NOTEXT
|
||||
gc_abap_version TYPE string VALUE 'v1.19.1'. "#EC NOTEXT
|
||||
|
||||
********************************************************************************
|
||||
* The MIT License (MIT)
|
||||
|
|
|
@ -6,6 +6,7 @@ CLASS lcl_gui DEFINITION DEFERRED.
|
|||
CLASS lcl_persistence_user DEFINITION DEFERRED.
|
||||
CLASS lcl_repo_srv DEFINITION DEFERRED.
|
||||
CLASS lcl_persistence_db DEFINITION DEFERRED.
|
||||
CLASS lcl_persistence_settings DEFINITION DEFERRED.
|
||||
|
||||
*----------------------------------------------------------------------*
|
||||
* CLASS lcl_app DEFINITION
|
||||
|
@ -31,10 +32,14 @@ CLASS lcl_app DEFINITION FINAL.
|
|||
CLASS-METHODS db
|
||||
RETURNING VALUE(ro_db) TYPE REF TO lcl_persistence_db.
|
||||
|
||||
CLASS-METHODS settings
|
||||
RETURNING VALUE(ro_settings) TYPE REF TO lcl_persistence_settings.
|
||||
|
||||
PRIVATE SECTION.
|
||||
CLASS-DATA: go_gui TYPE REF TO lcl_gui,
|
||||
go_current_user TYPE REF TO lcl_persistence_user,
|
||||
go_db TYPE REF TO lcl_persistence_db,
|
||||
go_repo_srv TYPE REF TO lcl_repo_srv.
|
||||
go_repo_srv TYPE REF TO lcl_repo_srv,
|
||||
go_settings TYPE REF TO lcl_persistence_settings.
|
||||
|
||||
ENDCLASS. "lcl_app
|
|
@ -60,4 +60,11 @@ CLASS lcl_app IMPLEMENTATION.
|
|||
|
||||
ENDMETHOD. "repo_srv
|
||||
|
||||
METHOD settings.
|
||||
IF go_settings IS NOT BOUND.
|
||||
CREATE OBJECT go_settings.
|
||||
ENDIF.
|
||||
ro_settings = go_settings.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS. "lcl_app
|
|
@ -22,6 +22,7 @@ TYPES: BEGIN OF ty_file.
|
|||
TYPES: data TYPE xstring,
|
||||
END OF ty_file.
|
||||
TYPES: ty_files_tt TYPE STANDARD TABLE OF ty_file WITH DEFAULT KEY.
|
||||
TYPES: ty_file_signatures_tt TYPE STANDARD TABLE OF ty_file_signature WITH DEFAULT KEY.
|
||||
|
||||
TYPES: ty_string_tt TYPE STANDARD TABLE OF string WITH DEFAULT KEY.
|
||||
TYPES: tt_w3urls TYPE STANDARD TABLE OF w3url WITH DEFAULT KEY.
|
||||
|
@ -201,5 +202,6 @@ CONSTANTS: BEGIN OF gc_action,
|
|||
go_branch_overview TYPE string VALUE 'go_branch_overview',
|
||||
go_playground TYPE string VALUE 'go_playground',
|
||||
go_debuginfo TYPE string VALUE 'go_debuginfo',
|
||||
go_settings type string value 'go_settings',
|
||||
jump TYPE string VALUE 'jump',
|
||||
END OF gc_action.
|
|
@ -337,13 +337,17 @@ CLASS lcl_git_transport IMPLEMENTATION.
|
|||
|
||||
DATA: lv_data TYPE string,
|
||||
lv_uri TYPE string,
|
||||
lv_expect_potentual_auth TYPE abap_bool.
|
||||
lv_expect_potentual_auth TYPE abap_bool,
|
||||
lo_settings TYPE REF TO lcl_settings.
|
||||
|
||||
lo_settings = lcl_app=>settings( )->read( ).
|
||||
|
||||
cl_http_client=>create_by_url(
|
||||
EXPORTING
|
||||
url = lcl_url=>host( iv_url )
|
||||
ssl_id = 'ANONYM'
|
||||
url = lcl_url=>host( iv_url )
|
||||
ssl_id = 'ANONYM'
|
||||
proxy_host = lo_settings->get_proxy_url( )
|
||||
proxy_service = lo_settings->get_proxy_port( )
|
||||
IMPORTING
|
||||
client = ei_client ).
|
||||
|
||||
|
|
|
@ -15,4 +15,5 @@ INCLUDE zabapgit_page_diff.
|
|||
INCLUDE zabapgit_page_explore.
|
||||
INCLUDE zabapgit_page_main.
|
||||
INCLUDE zabapgit_page_stage.
|
||||
INCLUDE zabapgit_page_debug.
|
||||
INCLUDE zabapgit_page_debug.
|
||||
INCLUDE zabapgit_page_settings.
|
|
@ -73,11 +73,12 @@ CLASS lcl_gui_router IMPLEMENTATION.
|
|||
|
||||
CASE iv_action.
|
||||
" General routing
|
||||
WHEN gc_action-go_main " Go Main page
|
||||
WHEN gc_action-go_main " Go Main page
|
||||
OR gc_action-go_explore " Go Explore page
|
||||
OR gc_action-go_db " Go DB util page
|
||||
OR gc_action-go_background_run " Go background run page
|
||||
OR gc_action-go_debuginfo. " Go debug info page
|
||||
OR gc_action-go_debuginfo " Go debug info page
|
||||
OR gc_action-go_settings. " Go settings page
|
||||
ei_page = get_page_by_name( iv_action ).
|
||||
ev_state = gc_event_state-new_page.
|
||||
WHEN gc_action-go_background. " Go Background page
|
||||
|
|
|
@ -74,10 +74,6 @@ CLASS lcl_html_action_utils DEFINITION FINAL.
|
|||
IMPORTING it_postdata TYPE cnht_post_data_tab
|
||||
EXPORTING es_fields TYPE any.
|
||||
|
||||
* CLASS-METHODS repo_key_encode
|
||||
* IMPORTING iv_key TYPE lcl_persistence_repo=>ty_repo-key
|
||||
* RETURNING VALUE(rv_string) TYPE string.
|
||||
|
||||
CLASS-METHODS decode_bg_update
|
||||
IMPORTING iv_getdata TYPE clike
|
||||
RETURNING VALUE(rs_fields) TYPE lcl_persistence_background=>ty_background.
|
||||
|
@ -311,16 +307,6 @@ CLASS lcl_html_action_utils IMPLEMENTATION.
|
|||
|
||||
ENDMETHOD. "parse_commit_request
|
||||
|
||||
* METHOD repo_key_encode.
|
||||
*
|
||||
* DATA: lt_fields TYPE tihttpnvp.
|
||||
*
|
||||
* add_field( EXPORTING name = 'KEY' iv = iv_key CHANGING ct = lt_fields ).
|
||||
*
|
||||
* rv_string = cl_http_utility=>if_http_utility~fields_to_string( lt_fields ).
|
||||
*
|
||||
* ENDMETHOD. "repo_key_encode
|
||||
|
||||
METHOD decode_bg_update.
|
||||
|
||||
DATA: lt_fields TYPE tihttpnvp.
|
||||
|
|
|
@ -137,7 +137,7 @@ CLASS lcl_object_dtel IMPLEMENTATION.
|
|||
EXCEPTIONS
|
||||
illegal_input = 1
|
||||
OTHERS = 2.
|
||||
IF sy-subrc <> 0 or ls_dd04v IS INITIAL.
|
||||
IF sy-subrc <> 0 OR ls_dd04v IS INITIAL.
|
||||
lcx_exception=>raise( 'Error from DDIF_DTEL_GET' ).
|
||||
ENDIF.
|
||||
|
||||
|
@ -151,6 +151,7 @@ CLASS lcl_object_dtel IMPLEMENTATION.
|
|||
ls_dd04v-leng,
|
||||
ls_dd04v-decimals,
|
||||
ls_dd04v-outputlen,
|
||||
ls_dd04v-valexi,
|
||||
ls_dd04v-lowercase,
|
||||
ls_dd04v-signflag,
|
||||
ls_dd04v-convexit,
|
||||
|
@ -218,7 +219,7 @@ CLASS lcl_object_dtel IMPLEMENTATION.
|
|||
lv_name = ms_item-obj_name.
|
||||
|
||||
" Collect additional languages
|
||||
SELECT DISTINCT ddlanguage as langu INTO TABLE lt_i18n_langs
|
||||
SELECT DISTINCT ddlanguage AS langu INTO TABLE lt_i18n_langs
|
||||
FROM dd04v
|
||||
WHERE rollname = lv_name
|
||||
AND ddlanguage <> mv_language. " Skip master lang - it was serialized already
|
||||
|
|
|
@ -14,6 +14,13 @@ CLASS lcl_object_enho DEFINITION INHERITING FROM lcl_objects_super FINAL.
|
|||
ALIASES mo_files FOR lif_object~mo_files.
|
||||
|
||||
PRIVATE SECTION.
|
||||
TYPES: BEGIN OF ty_spaces,
|
||||
full_name TYPE string.
|
||||
TYPES: spaces TYPE STANDARD TABLE OF i WITH DEFAULT KEY,
|
||||
END OF ty_spaces.
|
||||
|
||||
TYPES: ty_spaces_tt TYPE STANDARD TABLE OF ty_spaces WITH DEFAULT KEY.
|
||||
|
||||
METHODS deserialize_badi
|
||||
IMPORTING io_xml TYPE REF TO lcl_xml_input
|
||||
iv_package TYPE devclass
|
||||
|
@ -34,6 +41,15 @@ CLASS lcl_object_enho DEFINITION INHERITING FROM lcl_objects_super FINAL.
|
|||
ii_enh_tool TYPE REF TO if_enh_tool
|
||||
RAISING lcx_exception.
|
||||
|
||||
METHODS hook_impl_serialize
|
||||
EXPORTING et_spaces TYPE ty_spaces_tt
|
||||
CHANGING ct_impl TYPE enh_hook_impl_it
|
||||
RAISING lcx_exception.
|
||||
METHODS hook_impl_deserialize
|
||||
IMPORTING it_spaces TYPE ty_spaces_tt
|
||||
CHANGING ct_impl TYPE enh_hook_impl_it
|
||||
RAISING lcx_exception.
|
||||
|
||||
ENDCLASS. "lcl_object_enho DEFINITION
|
||||
|
||||
*----------------------------------------------------------------------*
|
||||
|
@ -55,6 +71,53 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
rv_user = c_user_unknown. " todo
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD hook_impl_serialize.
|
||||
* handle normalization of XML values
|
||||
* i.e. remove leading spaces
|
||||
|
||||
FIELD-SYMBOLS: <ls_impl> LIKE LINE OF ct_impl,
|
||||
<ls_space> LIKE LINE OF et_spaces,
|
||||
<lv_space> TYPE i,
|
||||
<lv_line> TYPE string.
|
||||
|
||||
|
||||
LOOP AT ct_impl ASSIGNING <ls_impl>.
|
||||
APPEND INITIAL LINE TO et_spaces ASSIGNING <ls_space>.
|
||||
<ls_space>-full_name = <ls_impl>-full_name.
|
||||
LOOP AT <ls_impl>-source ASSIGNING <lv_line>.
|
||||
APPEND INITIAL LINE TO <ls_space>-spaces ASSIGNING <lv_space>.
|
||||
WHILE strlen( <lv_line> ) >= 1 AND <lv_line>(1) = ` `.
|
||||
<lv_line> = <lv_line>+1.
|
||||
<lv_space> = <lv_space> + 1.
|
||||
ENDWHILE.
|
||||
ENDLOOP.
|
||||
ENDLOOP.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD hook_impl_deserialize.
|
||||
|
||||
FIELD-SYMBOLS: <ls_impl> LIKE LINE OF ct_impl,
|
||||
<lv_line> TYPE string,
|
||||
<lv_space> TYPE i,
|
||||
<ls_spaces> LIKE LINE OF it_spaces.
|
||||
|
||||
|
||||
LOOP AT ct_impl ASSIGNING <ls_impl>.
|
||||
READ TABLE it_spaces ASSIGNING <ls_spaces> WITH KEY full_name = <ls_impl>-full_name.
|
||||
IF sy-subrc = 0.
|
||||
LOOP AT <ls_impl>-source ASSIGNING <lv_line>.
|
||||
READ TABLE <ls_spaces>-spaces ASSIGNING <lv_space> INDEX sy-tabix.
|
||||
IF sy-subrc = 0 AND <lv_space> > 0.
|
||||
DO <lv_space> TIMES.
|
||||
CONCATENATE space <lv_line> INTO <lv_line> RESPECTING BLANKS.
|
||||
ENDDO.
|
||||
ENDIF.
|
||||
ENDLOOP.
|
||||
ENDIF.
|
||||
ENDLOOP.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~exists.
|
||||
|
||||
DATA: ls_tadir TYPE tadir.
|
||||
|
@ -82,7 +145,9 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
|
||||
lv_enh_id = ms_item-obj_name.
|
||||
TRY.
|
||||
li_enh_tool = cl_enh_factory=>get_enhancement( lv_enh_id ).
|
||||
li_enh_tool = cl_enh_factory=>get_enhancement(
|
||||
enhancement_id = lv_enh_id
|
||||
bypassing_buffer = abap_true ).
|
||||
CATCH cx_enh_root.
|
||||
lcx_exception=>raise( 'Error from CL_ENH_FACTORY' ).
|
||||
ENDTRY.
|
||||
|
@ -196,6 +261,7 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
lv_enhname TYPE enhname,
|
||||
lv_package TYPE devclass,
|
||||
ls_original_object TYPE enh_hook_admin,
|
||||
lt_spaces TYPE ty_spaces_tt,
|
||||
lt_enhancements TYPE enh_hook_impl_it.
|
||||
|
||||
FIELD-SYMBOLS: <ls_enhancement> LIKE LINE OF lt_enhancements.
|
||||
|
@ -207,6 +273,11 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
CHANGING cg_data = ls_original_object ).
|
||||
io_xml->read( EXPORTING iv_name = 'ENHANCEMENTS'
|
||||
CHANGING cg_data = lt_enhancements ).
|
||||
io_xml->read( EXPORTING iv_name = 'SPACES'
|
||||
CHANGING cg_data = lt_spaces ).
|
||||
|
||||
hook_impl_deserialize( EXPORTING it_spaces = lt_spaces
|
||||
CHANGING ct_impl = lt_enhancements ).
|
||||
|
||||
lv_enhname = ms_item-obj_name.
|
||||
lv_package = iv_package.
|
||||
|
@ -279,6 +350,7 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
DATA: lv_shorttext TYPE string,
|
||||
lo_hook_impl TYPE REF TO cl_enh_tool_hook_impl,
|
||||
ls_original_object TYPE enh_hook_admin,
|
||||
lt_spaces TYPE ty_spaces_tt,
|
||||
lt_enhancements TYPE enh_hook_impl_it.
|
||||
|
||||
|
||||
|
@ -296,6 +368,10 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
ls_original_object-include_bound = lo_hook_impl->get_include_bound( ).
|
||||
lt_enhancements = lo_hook_impl->get_hook_impls( ).
|
||||
|
||||
hook_impl_serialize(
|
||||
IMPORTING et_spaces = lt_spaces
|
||||
CHANGING ct_impl = lt_enhancements ).
|
||||
|
||||
io_xml->add( iv_name = 'TOOL'
|
||||
ig_data = iv_tool ).
|
||||
io_xml->add( ig_data = lv_shorttext
|
||||
|
@ -304,6 +380,8 @@ CLASS lcl_object_enho IMPLEMENTATION.
|
|||
iv_name = 'ORIGINAL_OBJECT' ).
|
||||
io_xml->add( iv_name = 'ENHANCEMENTS'
|
||||
ig_data = lt_enhancements ).
|
||||
io_xml->add( iv_name = 'SPACES'
|
||||
ig_data = lt_spaces ).
|
||||
|
||||
ENDMETHOD. "serialize_hook
|
||||
|
||||
|
|
|
@ -6,6 +6,7 @@
|
|||
* CLASS lcl_object_enhs DEFINITION
|
||||
*----------------------------------------------------------------------*
|
||||
CLASS lcl_object_enhs DEFINITION INHERITING FROM lcl_objects_super FINAL.
|
||||
|
||||
PUBLIC SECTION.
|
||||
INTERFACES lif_object.
|
||||
ALIASES mo_files FOR lif_object~mo_files.
|
||||
|
@ -22,10 +23,24 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
ENDMETHOD. "lif_object~has_changed_since
|
||||
|
||||
METHOD lif_object~changed_by.
|
||||
rv_user = c_user_unknown. " todo
|
||||
|
||||
DATA: lv_spot_name TYPE enhspotname,
|
||||
li_spot_ref TYPE REF TO if_enh_spot_tool.
|
||||
|
||||
|
||||
lv_spot_name = ms_item-obj_name.
|
||||
|
||||
TRY.
|
||||
li_spot_ref = cl_enh_factory=>get_enhancement_spot( lv_spot_name ).
|
||||
li_spot_ref->get_attributes( IMPORTING changedby = rv_user ).
|
||||
CATCH cx_enh_root.
|
||||
rv_user = c_user_unknown.
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_object~deserialize.
|
||||
|
||||
DATA: lv_message TYPE string,
|
||||
lv_parent TYPE enhspotcompositename,
|
||||
lv_spot_name TYPE enhspotname,
|
||||
|
@ -86,22 +101,24 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
ENDMETHOD. "deserialize
|
||||
|
||||
METHOD lif_object~serialize.
|
||||
DATA: lv_message TYPE string,
|
||||
lv_spot_name TYPE enhspotname,
|
||||
|
||||
DATA: lv_spot_name TYPE enhspotname,
|
||||
lv_enh_shtext TYPE string,
|
||||
lv_parent TYPE enhspotcompositename,
|
||||
lt_enh_badi TYPE enh_badi_data_it,
|
||||
lv_tool TYPE enhspottooltype,
|
||||
lx_root TYPE REF TO cx_root,
|
||||
li_spot_ref TYPE REF TO if_enh_spot_tool,
|
||||
lo_badidef_tool TYPE REF TO cl_enh_tool_badi_def.
|
||||
|
||||
|
||||
lv_spot_name = ms_item-obj_name.
|
||||
|
||||
TRY.
|
||||
li_spot_ref = cl_enh_factory=>get_enhancement_spot( lv_spot_name ).
|
||||
lv_tool = li_spot_ref->get_tool( ).
|
||||
|
||||
lo_badidef_tool ?= li_spot_ref.
|
||||
|
||||
lv_enh_shtext = lo_badidef_tool->if_enh_object_docu~get_shorttext( ).
|
||||
|
||||
"get parent = composite enhs (ENHC)
|
||||
|
@ -109,6 +126,8 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
"get subsequent BADI definitions
|
||||
lt_enh_badi = lo_badidef_tool->get_badi_defs( ).
|
||||
|
||||
io_xml->add( ig_data = lv_tool
|
||||
iv_name = 'TOOL' ).
|
||||
io_xml->add( ig_data = lv_parent
|
||||
iv_name = 'PARENT_COMP' ).
|
||||
io_xml->add( ig_data = lv_enh_shtext
|
||||
|
@ -117,9 +136,8 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
iv_name = 'BADI_DATA' ).
|
||||
|
||||
CATCH cx_enh_root INTO lx_root.
|
||||
lv_message = `Error occured while serializing EHNS: `
|
||||
&& lx_root->get_text( ) ##NO_TEXT.
|
||||
lcx_exception=>raise( lv_message ).
|
||||
lcx_exception=>raise( `Error occured while serializing EHNS: `
|
||||
&& lx_root->get_text( ) ) ##NO_TEXT.
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD. "serialize
|
||||
|
@ -127,6 +145,7 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
METHOD lif_object~exists.
|
||||
|
||||
DATA: lv_spot_name TYPE enhspotname,
|
||||
lv_tool TYPE enhspottooltype,
|
||||
li_spot_ref TYPE REF TO if_enh_spot_tool.
|
||||
|
||||
|
||||
|
@ -135,12 +154,14 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
TRY.
|
||||
li_spot_ref = cl_enh_factory=>get_enhancement_spot( lv_spot_name ).
|
||||
|
||||
* Check that is is realy a BAdI
|
||||
IF li_spot_ref->get_tool( ) = cl_enh_tool_badi_def=>tooltype.
|
||||
rv_bool = abap_true.
|
||||
ELSE.
|
||||
rv_bool = abap_false.
|
||||
ENDIF.
|
||||
lv_tool = li_spot_ref->get_tool( ).
|
||||
CASE lv_tool.
|
||||
WHEN cl_enh_tool_badi_def=>tooltype.
|
||||
rv_bool = abap_true.
|
||||
WHEN OTHERS.
|
||||
* todo: implement additional tool types
|
||||
rv_bool = abap_false.
|
||||
ENDCASE.
|
||||
CATCH cx_enh_root.
|
||||
rv_bool = abap_false.
|
||||
ENDTRY.
|
||||
|
@ -148,6 +169,7 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
ENDMETHOD. "exists
|
||||
|
||||
METHOD lif_object~delete.
|
||||
|
||||
DATA: lv_spot_name TYPE enhspotname,
|
||||
lv_message TYPE string,
|
||||
lx_root TYPE REF TO cx_root,
|
||||
|
@ -159,19 +181,18 @@ CLASS lcl_object_enhs IMPLEMENTATION.
|
|||
TRY.
|
||||
li_spot_ref = cl_enh_factory=>get_enhancement_spot(
|
||||
spot_name = lv_spot_name
|
||||
lock = 'X' ).
|
||||
lock = abap_true ).
|
||||
|
||||
IF li_spot_ref IS BOUND.
|
||||
lo_badidef_tool ?= li_spot_ref.
|
||||
lo_badidef_tool->if_enh_object~delete(
|
||||
nevertheless_delete = 'X'
|
||||
run_dark = 'X' ).
|
||||
nevertheless_delete = abap_true
|
||||
run_dark = abap_true ).
|
||||
ENDIF.
|
||||
lo_badidef_tool->if_enh_object~unlock( ).
|
||||
CATCH cx_enh_root INTO lx_root.
|
||||
lv_message = `Error occured while deleting EHNS: `
|
||||
&& lx_root->get_text( ) ##NO_TEXT.
|
||||
lcx_exception=>raise( lv_message ).
|
||||
lcx_exception=>raise( `Error occured while deleting EHNS: `
|
||||
&& lx_root->get_text( ) ) ##NO_TEXT.
|
||||
ENDTRY.
|
||||
|
||||
ENDMETHOD. "delete
|
||||
|
|
|
@ -159,8 +159,10 @@ CLASS lcl_gui_page_main IMPLEMENTATION.
|
|||
ENDIF.
|
||||
ENDIF.
|
||||
|
||||
IF lv_show_old <> mv_show.
|
||||
CREATE OBJECT mo_repo_content EXPORTING iv_key = mv_show. " Reinit content state
|
||||
IF lv_show_old <> mv_show AND NOT mv_show IS INITIAL.
|
||||
CREATE OBJECT mo_repo_content
|
||||
EXPORTING
|
||||
iv_key = mv_show. " Reinit content state
|
||||
ENDIF.
|
||||
|
||||
ENDMETHOD. "retrieve_active_repo
|
||||
|
@ -179,6 +181,7 @@ CLASS lcl_gui_page_main IMPLEMENTATION.
|
|||
lo_betasub->add( iv_txt = 'Object to files' iv_act = gc_action-zip_object ) ##NO_TEXT.
|
||||
lo_betasub->add( iv_txt = 'Page playground' iv_act = gc_action-go_playground ) ##NO_TEXT.
|
||||
lo_betasub->add( iv_txt = 'Debug info' iv_act = gc_action-go_debuginfo ) ##NO_TEXT.
|
||||
lo_betasub->add( iv_txt = 'Settings' iv_act = gc_action-go_settings ) ##NO_TEXT.
|
||||
|
||||
ro_menu->add( iv_txt = 'Clone' iv_act = gc_action-repo_clone ) ##NO_TEXT.
|
||||
ro_menu->add( iv_txt = 'Explore' iv_act = gc_action-go_explore ) ##NO_TEXT.
|
||||
|
|
169
src/zabapgit_page_settings.prog.abap
Normal file
169
src/zabapgit_page_settings.prog.abap
Normal file
|
@ -0,0 +1,169 @@
|
|||
*&---------------------------------------------------------------------*
|
||||
*& Include ZABAPGIT_PAGE_SETTINGS
|
||||
*&---------------------------------------------------------------------*
|
||||
|
||||
CLASS lcl_gui_page_settings DEFINITION FINAL INHERITING FROM lcl_gui_page_super.
|
||||
PUBLIC SECTION.
|
||||
METHODS lif_gui_page~render REDEFINITION.
|
||||
METHODS lif_gui_page~on_event REDEFINITION.
|
||||
CONSTANTS:
|
||||
BEGIN OF c_action,
|
||||
save_settings TYPE string VALUE 'save_settings',
|
||||
END OF c_action.
|
||||
PRIVATE SECTION.
|
||||
METHODS styles
|
||||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html_helper.
|
||||
METHODS render_proxy
|
||||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html_helper.
|
||||
METHODS render_form_begin
|
||||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html_helper.
|
||||
METHODS render_form_end
|
||||
RETURNING VALUE(ro_html) TYPE REF TO lcl_html_helper.
|
||||
METHODS build_settings
|
||||
IMPORTING
|
||||
it_post_fields TYPE tihttpnvp.
|
||||
METHODS validate_settings.
|
||||
METHODS parse_post
|
||||
IMPORTING
|
||||
it_postdata TYPE cnht_post_data_tab
|
||||
RETURNING
|
||||
VALUE(rt_post_fields) TYPE tihttpnvp.
|
||||
METHODS persist_settings
|
||||
RAISING
|
||||
lcx_exception.
|
||||
METHODS read_settings.
|
||||
DATA:
|
||||
mo_settings TYPE REF TO lcl_settings,
|
||||
mv_error TYPE abap_bool.
|
||||
ENDCLASS.
|
||||
|
||||
CLASS lcl_gui_page_settings IMPLEMENTATION.
|
||||
|
||||
METHOD lif_gui_page~render.
|
||||
CREATE OBJECT ro_html.
|
||||
|
||||
read_settings( ).
|
||||
|
||||
ro_html->add( header( io_include_style = styles( ) ) ).
|
||||
ro_html->add( title( 'Settings' ) ).
|
||||
|
||||
ro_html->add( render_form_begin( ) ).
|
||||
ro_html->add( render_proxy( ) ).
|
||||
ro_html->add( render_form_end( ) ).
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD styles.
|
||||
CREATE OBJECT ro_html.
|
||||
|
||||
_add '/* settings STYLES */'.
|
||||
_add 'div.settings_container {'.
|
||||
_add ' padding: 0.5em;'.
|
||||
_add ' font-size: 10pt;'.
|
||||
_add ' color: #444;'.
|
||||
_add ' background-color: #f2f2f2;'.
|
||||
_add '}'.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD render_proxy.
|
||||
CREATE OBJECT ro_html.
|
||||
ro_html->add( |<h2>Proxy</h2>| ).
|
||||
ro_html->add( |<label for="proxy_url">Proxy URL</label>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( `<input name="proxy_url" type="text" size="50" value="` && mo_settings->get_proxy_url( ) && `">` ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<label for="proxy_port">Proxy Port</label>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( `<input name="proxy_port" type="text" size="5" value="` && mo_settings->get_proxy_port( ) && `">` ).
|
||||
ro_html->add( |<br>| ).
|
||||
ro_html->add( |<br>| ).
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD lif_gui_page~on_event.
|
||||
DATA:
|
||||
lt_post_fields TYPE tihttpnvp.
|
||||
CASE iv_action.
|
||||
WHEN c_action-save_settings.
|
||||
lt_post_fields = parse_post( it_postdata ).
|
||||
|
||||
build_settings( lt_post_fields ).
|
||||
|
||||
validate_settings( ).
|
||||
|
||||
IF mv_error = abap_true.
|
||||
MESSAGE 'Error when saving settings. Open an issue at https://github.com/larshp/abapGit' TYPE 'E'.
|
||||
ELSE.
|
||||
persist_settings( ).
|
||||
ENDIF.
|
||||
|
||||
ev_state = gc_event_state-go_back.
|
||||
ENDCASE.
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD build_settings.
|
||||
DATA ls_post_field TYPE ihttpnvp.
|
||||
|
||||
CREATE OBJECT mo_settings.
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'proxy_url'.
|
||||
IF sy-subrc <> 0.
|
||||
mv_error = abap_true.
|
||||
ENDIF.
|
||||
mo_settings->set_proxy_url( ls_post_field-value ).
|
||||
|
||||
READ TABLE it_post_fields INTO ls_post_field WITH KEY name = 'proxy_port'.
|
||||
IF sy-subrc <> 0.
|
||||
mv_error = abap_true.
|
||||
ENDIF.
|
||||
mo_settings->set_proxy_port( ls_post_field-value ).
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD validate_settings.
|
||||
IF ( mo_settings->get_proxy_url( ) IS NOT INITIAL AND mo_settings->get_proxy_port( ) IS INITIAL ) OR
|
||||
( mo_settings->get_proxy_url( ) IS INITIAL AND mo_settings->get_proxy_port( ) IS NOT INITIAL ).
|
||||
MESSAGE 'If specifying proxy, specify both URL and port' TYPE 'W'.
|
||||
ENDIF.
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD parse_post.
|
||||
DATA lv_serialized_post_data TYPE string.
|
||||
|
||||
CONCATENATE LINES OF it_postdata INTO lv_serialized_post_data.
|
||||
rt_post_fields = cl_http_utility=>if_http_utility~string_to_fields( lv_serialized_post_data ).
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD persist_settings.
|
||||
|
||||
DATA lo_settings_persistence TYPE REF TO lcl_persistence_settings.
|
||||
|
||||
lo_settings_persistence = lcl_app=>settings( ).
|
||||
lo_settings_persistence->modify( mo_settings ).
|
||||
MESSAGE 'Settings succesfully saved' TYPE 'S'.
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD render_form_begin.
|
||||
CREATE OBJECT ro_html.
|
||||
ro_html->add( '<div class="settings_container">' ).
|
||||
ro_html->add( `<form id="settings_form" method="post" action="sapevent:` && c_action-save_settings && `">` ).
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD render_form_end.
|
||||
CREATE OBJECT ro_html.
|
||||
ro_html->add( '<input type="submit" value="Save" class="submit">' ).
|
||||
ro_html->add( '</form>' ).
|
||||
ro_html->add( '</div>' ).
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD read_settings.
|
||||
|
||||
DATA lo_settings_persistence TYPE REF TO lcl_persistence_settings.
|
||||
lo_settings_persistence = lcl_app=>settings( ).
|
||||
mo_settings = lo_settings_persistence->read( ).
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
48
src/zabapgit_page_settings.prog.xml
Normal file
48
src/zabapgit_page_settings.prog.xml
Normal file
|
@ -0,0 +1,48 @@
|
|||
<?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_PAGE_SETTINGS</NAME>
|
||||
<STATE>A</STATE>
|
||||
<SQLX/>
|
||||
<EDTX/>
|
||||
<VARCL>X</VARCL>
|
||||
<DBAPL/>
|
||||
<DBNA/>
|
||||
<CLAS/>
|
||||
<TYPE/>
|
||||
<OCCURS/>
|
||||
<SUBC>I</SUBC>
|
||||
<APPL/>
|
||||
<SECU/>
|
||||
<CNAM/>
|
||||
<CDAT>0000-00-00</CDAT>
|
||||
<UNAM/>
|
||||
<UDAT>0000-00-00</UDAT>
|
||||
<VERN/>
|
||||
<LEVL/>
|
||||
<RSTAT/>
|
||||
<RMAND/>
|
||||
<RLOAD>E</RLOAD>
|
||||
<FIXPT/>
|
||||
<SSET/>
|
||||
<SDATE>0000-00-00</SDATE>
|
||||
<STIME/>
|
||||
<IDATE>0000-00-00</IDATE>
|
||||
<ITIME/>
|
||||
<LDBNAME/>
|
||||
<UCCHECK>X</UCCHECK>
|
||||
</PROGDIR>
|
||||
<TPOOL>
|
||||
<item>
|
||||
<ID>R</ID>
|
||||
<KEY/>
|
||||
<ENTRY>Include ZABAPGIT_PAGE_SETTINGS</ENTRY>
|
||||
<LENGTH>30</LENGTH>
|
||||
<SPLIT/>
|
||||
</item>
|
||||
</TPOOL>
|
||||
</asx:values>
|
||||
</asx:abap>
|
||||
</abapGit>
|
|
@ -1,4 +1,4 @@
|
|||
*&---------------------------------------------------------------------*
|
||||
*&----------------------------
|
||||
*& Include ZABAPGIT_PERSISTENCE
|
||||
*&---------------------------------------------------------------------*
|
||||
|
||||
|
@ -147,8 +147,8 @@ CLASS lcl_persistence_repo DEFINITION FINAL.
|
|||
RAISING lcx_exception.
|
||||
|
||||
METHODS update_offline
|
||||
IMPORTING iv_key TYPE ty_repo-key
|
||||
iv_offline TYPE ty_repo_xml-offline
|
||||
IMPORTING iv_key TYPE ty_repo-key
|
||||
iv_offline TYPE ty_repo_xml-offline
|
||||
RAISING lcx_exception.
|
||||
|
||||
METHODS add
|
||||
|
@ -240,7 +240,7 @@ CLASS lcl_persistence_background DEFINITION FINAL.
|
|||
RAISING lcx_exception.
|
||||
|
||||
METHODS exists
|
||||
IMPORTING iv_key TYPE ty_background-key
|
||||
IMPORTING iv_key TYPE ty_background-key
|
||||
RETURNING VALUE(rv_yes) TYPE abap_bool
|
||||
RAISING lcx_exception.
|
||||
|
||||
|
@ -384,22 +384,22 @@ CLASS lcl_persistence_user DEFINITION FINAL CREATE PRIVATE FRIENDS lcl_app.
|
|||
RAISING lcx_exception.
|
||||
|
||||
METHODS set_repo_username
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
iv_username TYPE string
|
||||
RAISING lcx_exception.
|
||||
|
||||
METHODS get_repo_username
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
RETURNING VALUE(rv_username) TYPE string
|
||||
RAISING lcx_exception.
|
||||
|
||||
METHODS set_repo_email
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
iv_email TYPE string
|
||||
RAISING lcx_exception.
|
||||
|
||||
METHODS get_repo_email
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
RETURNING VALUE(rv_email) TYPE string
|
||||
RAISING lcx_exception.
|
||||
|
||||
|
@ -425,9 +425,9 @@ CLASS lcl_persistence_user DEFINITION FINAL CREATE PRIVATE FRIENDS lcl_app.
|
|||
DATA: mv_user TYPE xubname.
|
||||
|
||||
TYPES: BEGIN OF ty_repo_config,
|
||||
url TYPE lcl_persistence_repo=>ty_repo-url,
|
||||
username TYPE string,
|
||||
email TYPE string,
|
||||
url TYPE lcl_persistence_repo=>ty_repo-url,
|
||||
username TYPE string,
|
||||
email TYPE string,
|
||||
END OF ty_repo_config.
|
||||
TYPES: ty_repo_config_tt TYPE STANDARD TABLE OF ty_repo_config WITH DEFAULT KEY.
|
||||
|
||||
|
@ -461,12 +461,12 @@ CLASS lcl_persistence_user DEFINITION FINAL CREATE PRIVATE FRIENDS lcl_app.
|
|||
RAISING lcx_exception.
|
||||
|
||||
METHODS read_repo_config
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
RETURNING VALUE(rs_repo_config) TYPE ty_repo_config
|
||||
RAISING lcx_exception.
|
||||
|
||||
METHODS update_repo_config
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
IMPORTING iv_url TYPE lcl_persistence_repo=>ty_repo-url
|
||||
is_repo_config TYPE ty_repo_config
|
||||
RAISING lcx_exception.
|
||||
|
||||
|
@ -1345,4 +1345,239 @@ CLASS lcl_persistence_migrate IMPLEMENTATION.
|
|||
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
CLASS lcl_settings DEFINITION FINAL.
|
||||
|
||||
PUBLIC SECTION.
|
||||
METHODS set_proxy_url
|
||||
IMPORTING
|
||||
iv_url TYPE string.
|
||||
METHODS set_proxy_port
|
||||
IMPORTING
|
||||
iv_port TYPE string.
|
||||
METHODS get_proxy_url
|
||||
RETURNING
|
||||
VALUE(rv_proxy_url) TYPE string.
|
||||
METHODS get_proxy_port
|
||||
RETURNING
|
||||
VALUE(rv_port) TYPE string.
|
||||
PROTECTED SECTION.
|
||||
|
||||
PRIVATE SECTION.
|
||||
DATA mv_proxy_url TYPE string.
|
||||
DATA mv_proxy_port TYPE string.
|
||||
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
CLASS lcl_settings IMPLEMENTATION.
|
||||
|
||||
|
||||
METHOD set_proxy_url.
|
||||
mv_proxy_url = iv_url.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD get_proxy_url.
|
||||
rv_proxy_url = mv_proxy_url.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD set_proxy_port.
|
||||
mv_proxy_port = iv_port.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD get_proxy_port.
|
||||
rv_port = mv_proxy_port.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
|
||||
CLASS lcl_persistence_settings DEFINITION FINAL.
|
||||
|
||||
PUBLIC SECTION.
|
||||
METHODS modify
|
||||
IMPORTING
|
||||
io_settings TYPE REF TO lcl_settings
|
||||
RAISING
|
||||
lcx_exception.
|
||||
METHODS read
|
||||
RETURNING
|
||||
VALUE(ro_settings) TYPE REF TO lcl_settings.
|
||||
|
||||
PROTECTED SECTION.
|
||||
|
||||
PRIVATE SECTION.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
CLASS lcl_persistence_settings IMPLEMENTATION.
|
||||
|
||||
|
||||
METHOD modify.
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_URL'
|
||||
iv_data = io_settings->get_proxy_url( ) ).
|
||||
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_PORT'
|
||||
iv_data = io_settings->get_proxy_port( ) ).
|
||||
ENDMETHOD.
|
||||
|
||||
|
||||
METHOD read.
|
||||
CREATE OBJECT ro_settings.
|
||||
TRY.
|
||||
ro_settings->set_proxy_url(
|
||||
lcl_app=>db( )->read(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_URL'
|
||||
) ).
|
||||
CATCH lcx_not_found.
|
||||
ro_settings->set_proxy_url( '' ).
|
||||
ENDTRY.
|
||||
TRY.
|
||||
ro_settings->set_proxy_port(
|
||||
lcl_app=>db( )->read(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_PORT'
|
||||
) ).
|
||||
CATCH lcx_not_found.
|
||||
ro_settings->set_proxy_port( '' ).
|
||||
ENDTRY.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
||||
|
||||
CLASS ltcl_persistence_settings DEFINITION FINAL FOR TESTING
|
||||
DURATION SHORT
|
||||
RISK LEVEL HARMLESS.
|
||||
|
||||
PRIVATE SECTION.
|
||||
METHODS:
|
||||
setup,
|
||||
modify_settings_proxy_url FOR TESTING,
|
||||
modify_settings_proxy_port FOR TESTING,
|
||||
read_settings FOR TESTING,
|
||||
read_not_found_url FOR TESTING,
|
||||
read_not_found_port FOR TESTING.
|
||||
DATA:
|
||||
mo_persistence_settings TYPE REF TO lcl_persistence_settings,
|
||||
mo_settings TYPE REF TO lcl_settings.
|
||||
ENDCLASS.
|
||||
|
||||
CLASS ltcl_persistence_settings IMPLEMENTATION.
|
||||
METHOD setup.
|
||||
CREATE OBJECT mo_persistence_settings.
|
||||
"These tests may fail if you are locking the entries (e.g. the ZABAPGIT transaction is open)
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD modify_settings_proxy_url.
|
||||
DATA lv_proxy_url TYPE string.
|
||||
TRY.
|
||||
CREATE OBJECT mo_settings.
|
||||
mo_settings->set_proxy_url( 'http://proxy' ).
|
||||
|
||||
mo_persistence_settings->modify( mo_settings ).
|
||||
|
||||
lv_proxy_url = lcl_app=>db( )->read(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_URL' ).
|
||||
|
||||
cl_abap_unit_assert=>assert_equals(
|
||||
act = lv_proxy_url
|
||||
exp = 'http://proxy' ).
|
||||
CATCH cx_root.
|
||||
cl_abap_unit_assert=>fail( 'Unexpected exception' ).
|
||||
ENDTRY.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD modify_settings_proxy_port.
|
||||
DATA lv_proxy_port TYPE string.
|
||||
TRY.
|
||||
CREATE OBJECT mo_settings.
|
||||
mo_settings->set_proxy_port( '8080' ).
|
||||
|
||||
mo_persistence_settings->modify( mo_settings ).
|
||||
|
||||
lv_proxy_port = lcl_app=>db( )->read(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_PORT' ).
|
||||
|
||||
cl_abap_unit_assert=>assert_equals(
|
||||
act = lv_proxy_port
|
||||
exp = '8080' ).
|
||||
CATCH cx_root.
|
||||
cl_abap_unit_assert=>fail( 'Unexpected exception' ).
|
||||
ENDTRY.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD read_settings.
|
||||
TRY.
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_URL'
|
||||
iv_data = 'A_URL' ).
|
||||
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_PORT'
|
||||
iv_data = '1000' ).
|
||||
|
||||
mo_settings = mo_persistence_settings->read( ).
|
||||
|
||||
cl_abap_unit_assert=>assert_equals(
|
||||
act = mo_settings->get_proxy_url( )
|
||||
exp = 'A_URL' ).
|
||||
cl_abap_unit_assert=>assert_equals(
|
||||
act = mo_settings->get_proxy_port( )
|
||||
exp = '1000' ).
|
||||
CATCH cx_root.
|
||||
cl_abap_unit_assert=>fail( 'Unexpected exception' ).
|
||||
ENDTRY.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD read_not_found_port.
|
||||
TRY.
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_URL'
|
||||
iv_data = 'A_URL' ).
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_PORT'
|
||||
iv_data = '' ).
|
||||
|
||||
mo_settings = mo_persistence_settings->read( ).
|
||||
|
||||
cl_abap_unit_assert=>assert_equals(
|
||||
act = mo_settings->get_proxy_port( )
|
||||
exp = '' ).
|
||||
CATCH cx_root.
|
||||
cl_abap_unit_assert=>fail( 'Unexpected exception' ).
|
||||
ENDTRY.
|
||||
ENDMETHOD.
|
||||
|
||||
METHOD read_not_found_url.
|
||||
TRY.
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_PORT'
|
||||
iv_data = '1000' ).
|
||||
lcl_app=>db( )->modify(
|
||||
iv_type = 'SETTINGS'
|
||||
iv_value = 'PROXY_URL'
|
||||
iv_data = '' ).
|
||||
mo_settings = mo_persistence_settings->read( ).
|
||||
|
||||
cl_abap_unit_assert=>assert_equals(
|
||||
act = mo_settings->get_proxy_url( )
|
||||
exp = '' ).
|
||||
CATCH cx_root.
|
||||
cl_abap_unit_assert=>fail( 'Unexpected exception' ).
|
||||
ENDTRY.
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS.
|
|
@ -46,6 +46,8 @@ CLASS lcl_repo DEFINITION ABSTRACT FRIENDS lcl_repo_srv.
|
|||
update_local_checksums
|
||||
IMPORTING it_files TYPE ty_file_signatures_tt
|
||||
RAISING lcx_exception,
|
||||
refresh_local_checksums
|
||||
RAISING lcx_exception,
|
||||
is_offline
|
||||
RETURNING VALUE(rv_offline) TYPE abap_bool
|
||||
RAISING lcx_exception.
|
||||
|
|
|
@ -430,6 +430,10 @@ CLASS lcl_repo IMPLEMENTATION.
|
|||
set( it_checksums = lt_checksums ).
|
||||
ENDMETHOD. " update_local_checksums
|
||||
|
||||
METHOD refresh_local_checksums.
|
||||
set( it_checksums = build_local_checksums( ) ).
|
||||
ENDMETHOD. "refresh_local_checksums
|
||||
|
||||
METHOD deserialize.
|
||||
|
||||
DATA: lt_updated_files TYPE ty_file_signatures_tt.
|
||||
|
|
|
@ -1745,7 +1745,6 @@ CLASS ltcl_path IMPLEMENTATION.
|
|||
|
||||
|
||||
ENDMETHOD.
|
||||
|
||||
ENDCLASS. "ltcl_path
|
||||
|
||||
CLASS ltcl_file_status DEFINITION
|
||||
|
|
|
@ -339,6 +339,9 @@ CLASS lcl_gui_view_repo_content IMPLEMENTATION.
|
|||
WHEN c_actions-toggle_changes. " Toggle changes only view
|
||||
mv_changes_only = lcl_app=>user( )->toggle_changes_only( ).
|
||||
ev_state = gc_event_state-re_render.
|
||||
WHEN 'update_checksums'.
|
||||
mo_repo->refresh_local_checksums( ).
|
||||
ev_state = gc_event_state-re_render.
|
||||
ENDCASE.
|
||||
|
||||
ENDMETHOD. "lif_gui_page~on_event
|
||||
|
|
Loading…
Reference in New Issue
Block a user