From 392b1834072ab20622f53d0be1aa48903f9e899a Mon Sep 17 00:00:00 2001 From: Marc Bernard Date: Tue, 12 Mar 2024 17:48:02 +0000 Subject: [PATCH] Version 2.0 Based on Exit Factory for abapGit --- .abapgit.xml | 8 +++ src/zcl_abaplint_abapgit_ext_agent.clas.abap | 33 +++++++--- src/zcl_abaplint_abapgit_ext_annot.clas.abap | 11 +++- src/zcl_abaplint_abapgit_ext_chkrn.clas.abap | 28 +++++--- src/zcl_abaplint_abapgit_ext_exit.clas.abap | 68 ++++++++++---------- src/zcl_abaplint_abapgit_ext_issue.clas.abap | 11 +++- src/zcl_abaplint_abapgit_ext_logo.clas.abap | 11 +++- src/zcl_abaplint_abapgit_ext_ui.clas.abap | 29 ++++++--- 8 files changed, 135 insertions(+), 64 deletions(-) diff --git a/.abapgit.xml b/.abapgit.xml index 7c0506a..03cc7fe 100644 --- a/.abapgit.xml +++ b/.abapgit.xml @@ -2,9 +2,17 @@ + abapgit-ext-abaplint E /src/ PREFIX + + + SAP_BASIS + 702 + + + ZCL_ABAPLINT_ABAPGIT_EXT_EXIT=>C_VERSION diff --git a/src/zcl_abaplint_abapgit_ext_agent.clas.abap b/src/zcl_abaplint_abapgit_ext_agent.clas.abap index db726c4..b7de7ca 100644 --- a/src/zcl_abaplint_abapgit_ext_agent.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_agent.clas.abap @@ -3,8 +3,17 @@ CLASS zcl_abaplint_abapgit_ext_agent DEFINITION FINAL CREATE PRIVATE. - " Calling Github API for check runs and annotations - " https://docs.github.com/en/rest/reference/checks +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ +* Calling Github API for check runs and annotations +* https://docs.github.com/en/rest/reference/checks +************************************************************************ PUBLIC SECTION. CONSTANTS c_github_api_version TYPE string VALUE '2022-11-28'. @@ -19,11 +28,13 @@ CLASS zcl_abaplint_abapgit_ext_agent DEFINITION VALUE(ro_instance) TYPE REF TO zcl_abaplint_abapgit_ext_agent RAISING zcx_abapgit_exception. + METHODS constructor IMPORTING !iv_url TYPE string RAISING zcx_abapgit_exception. + METHODS get_annotations IMPORTING !iv_check_run TYPE string @@ -32,14 +43,16 @@ CLASS zcl_abaplint_abapgit_ext_agent DEFINITION RAISING zcx_abapgit_exception zcx_abapgit_ajson_error. + METHODS get_check_runs IMPORTING - !iv_commit TYPE zif_abaplint_abapgit_ext=>ty_sha1 + !iv_commit TYPE zcl_abaplint_abapgit_ext_exit=>ty_sha1 RETURNING VALUE(ri_json) TYPE REF TO zif_abapgit_ajson RAISING zcx_abapgit_exception zcx_abapgit_ajson_error. + PROTECTED SECTION. PRIVATE SECTION. @@ -47,17 +60,19 @@ CLASS zcl_abaplint_abapgit_ext_agent DEFINITION BEGIN OF ty_instance, url TYPE string, instanace TYPE REF TO zcl_abaplint_abapgit_ext_agent, - END OF ty_instance . + END OF ty_instance. + + CLASS-DATA gt_instance TYPE HASHED TABLE OF ty_instance WITH UNIQUE KEY url. + + DATA: + mv_url TYPE string, + mo_agent TYPE REF TO zif_abapgit_http_agent. - CLASS-DATA: - gt_instance TYPE HASHED TABLE OF ty_instance WITH UNIQUE KEY url . - DATA mv_url TYPE string . - DATA mo_agent TYPE REF TO zif_abapgit_http_agent . ENDCLASS. -CLASS zcl_abaplint_abapgit_ext_agent IMPLEMENTATION. +CLASS ZCL_ABAPLINT_ABAPGIT_EXT_AGENT IMPLEMENTATION. METHOD constructor. diff --git a/src/zcl_abaplint_abapgit_ext_annot.clas.abap b/src/zcl_abaplint_abapgit_ext_annot.clas.abap index 060a22b..cf83828 100644 --- a/src/zcl_abaplint_abapgit_ext_annot.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_annot.clas.abap @@ -3,8 +3,17 @@ CLASS zcl_abaplint_abapgit_ext_annot DEFINITION FINAL CREATE PUBLIC. +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ * GitHub REST API for Checks - Annotation * https://docs.github.com/en/rest/reference/checks +************************************************************************ PUBLIC SECTION. TYPES: @@ -58,7 +67,7 @@ ENDCLASS. -CLASS zcl_abaplint_abapgit_ext_annot IMPLEMENTATION. +CLASS ZCL_ABAPLINT_ABAPGIT_EXT_ANNOT IMPLEMENTATION. METHOD constructor. diff --git a/src/zcl_abaplint_abapgit_ext_chkrn.clas.abap b/src/zcl_abaplint_abapgit_ext_chkrn.clas.abap index b04aa13..003c2cf 100644 --- a/src/zcl_abaplint_abapgit_ext_chkrn.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_chkrn.clas.abap @@ -1,10 +1,19 @@ CLASS zcl_abaplint_abapgit_ext_chkrn DEFINITION PUBLIC FINAL - CREATE PUBLIC . - + CREATE PUBLIC. + +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ * GitHub REST API for Checks - Check Run * https://docs.github.com/en/rest/reference/checks +************************************************************************ PUBLIC SECTION. TYPES: @@ -23,25 +32,28 @@ CLASS zcl_abaplint_abapgit_ext_chkrn DEFINITION METHODS constructor IMPORTING !iv_url TYPE string - !iv_commit TYPE zif_abaplint_abapgit_ext=>ty_sha1 + !iv_commit TYPE zcl_abaplint_abapgit_ext_exit=>ty_sha1 RAISING - zcx_abapgit_exception . + zcx_abapgit_exception. + METHODS get RETURNING VALUE(rs_check_run) TYPE ty_check_run RAISING - zcx_abapgit_exception . + zcx_abapgit_exception. + PROTECTED SECTION. PRIVATE SECTION. - DATA mv_url TYPE string . - DATA mv_commit TYPE zif_abaplint_abapgit_ext=>ty_sha1 . + DATA: + mv_url TYPE string, + mv_commit TYPE zcl_abaplint_abapgit_ext_exit=>ty_sha1. ENDCLASS. -CLASS zcl_abaplint_abapgit_ext_chkrn IMPLEMENTATION. +CLASS ZCL_ABAPLINT_ABAPGIT_EXT_CHKRN IMPLEMENTATION. METHOD constructor. diff --git a/src/zcl_abaplint_abapgit_ext_exit.clas.abap b/src/zcl_abaplint_abapgit_ext_exit.clas.abap index 0c01351..988a4ee 100644 --- a/src/zcl_abaplint_abapgit_ext_exit.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_exit.clas.abap @@ -1,27 +1,31 @@ CLASS zcl_abaplint_abapgit_ext_exit DEFINITION PUBLIC + INHERITING FROM zcl_abapgit_user_exit_super FINAL - CREATE PRIVATE. - + CREATE PUBLIC. + +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ PUBLIC SECTION. - CLASS-METHODS get_instance - RETURNING - VALUE(ro_instance) TYPE REF TO zcl_abaplint_abapgit_ext_exit. - METHODS on_event - IMPORTING - !ii_event TYPE REF TO zif_abapgit_gui_event - RETURNING - VALUE(rs_handled) TYPE zif_abapgit_gui_event_handler=>ty_handling_result - RAISING - zcx_abapgit_exception. - METHODS wall_message_repo - IMPORTING - !is_repo_meta TYPE zif_abapgit_persistence=>ty_repo - !ii_html TYPE REF TO zif_abapgit_html. - METHODS get_last_url + CONSTANTS c_version TYPE string VALUE '2.0.0' ##NEEDED. + + TYPES ty_sha1 TYPE c LENGTH 40. + + METHODS: + zif_abapgit_user_exit~on_event REDEFINITION, + zif_abapgit_user_exit~wall_message_repo REDEFINITION. + + CLASS-METHODS get_last_url RETURNING VALUE(rv_url) TYPE string. + PROTECTED SECTION. PRIVATE SECTION. @@ -34,14 +38,16 @@ CLASS zcl_abaplint_abapgit_ext_exit DEFINITION CONSTANTS: BEGIN OF c_action, - go_abaplint TYPE string VALUE 'go_abaplint', + go_abaplint TYPE string VALUE 'mbt_go_abaplint', END OF c_action. + CONSTANTS: BEGIN OF c_git_status, queued TYPE string VALUE 'queued', in_progress TYPE string VALUE 'in_progress', completed TYPE string VALUE 'completed', END OF c_git_status. + CONSTANTS: BEGIN OF c_git_conclusion, neutral TYPE string VALUE 'neutral', @@ -53,10 +59,10 @@ CLASS zcl_abaplint_abapgit_ext_exit DEFINITION stale TYPE string VALUE 'stale', timed_out TYPE string VALUE 'timed_out', END OF c_git_conclusion. - CLASS-DATA go_instance TYPE REF TO zcl_abaplint_abapgit_ext_exit. - DATA: - mt_wall TYPE HASHED TABLE OF ty_wall WITH UNIQUE KEY commit. - DATA mv_last_url TYPE string. + + CLASS-DATA gv_last_url TYPE string. + + DATA mt_wall TYPE HASHED TABLE OF ty_wall WITH UNIQUE KEY commit. METHODS _wall_message_abaplint IMPORTING @@ -71,20 +77,12 @@ ENDCLASS. CLASS zcl_abaplint_abapgit_ext_exit IMPLEMENTATION. - METHOD get_instance. - IF go_instance IS INITIAL. - CREATE OBJECT go_instance. - ENDIF. - ro_instance = go_instance. - ENDMETHOD. - - METHOD get_last_url. - rv_url = mv_last_url. + rv_url = gv_last_url. ENDMETHOD. - METHOD on_event. + METHOD zif_abapgit_user_exit~on_event. IF ii_event->mv_action = c_action-go_abaplint. rs_handled-page = zcl_abaplint_abapgit_ext_ui=>create( @@ -97,12 +95,12 @@ CLASS zcl_abaplint_abapgit_ext_exit IMPLEMENTATION. ENDMETHOD. - METHOD wall_message_repo. + METHOD zif_abapgit_user_exit~wall_message_repo. DATA: lx_error TYPE REF TO zcx_abapgit_exception, lo_repo_online TYPE REF TO zcl_abapgit_repo_online, - lv_commit TYPE zif_abaplint_abapgit_ext=>ty_sha1, + lv_commit TYPE zcl_abaplint_abapgit_ext_exit=>ty_sha1, ls_wall TYPE ty_wall, lo_check_run TYPE REF TO zcl_abaplint_abapgit_ext_chkrn, ls_check_run TYPE zcl_abaplint_abapgit_ext_chkrn=>ty_check_run, @@ -165,7 +163,7 @@ CLASS zcl_abaplint_abapgit_ext_exit IMPLEMENTATION. ii_html->add( ls_wall-html->render( ) ). " Remember URL of last shown check run - mv_last_url = ls_wall-url. + gv_last_url = ls_wall-url. ENDMETHOD. diff --git a/src/zcl_abaplint_abapgit_ext_issue.clas.abap b/src/zcl_abaplint_abapgit_ext_issue.clas.abap index ae0e2c9..53ef4ec 100644 --- a/src/zcl_abaplint_abapgit_ext_issue.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_issue.clas.abap @@ -3,7 +3,16 @@ CLASS zcl_abaplint_abapgit_ext_issue DEFINITION FINAL CREATE PUBLIC . +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ * Derive abapGit issue from abaplint annotation +************************************************************************ PUBLIC SECTION. TYPES: @@ -132,7 +141,7 @@ ENDCLASS. -CLASS zcl_abaplint_abapgit_ext_issue IMPLEMENTATION. +CLASS ZCL_ABAPLINT_ABAPGIT_EXT_ISSUE IMPLEMENTATION. METHOD constructor. diff --git a/src/zcl_abaplint_abapgit_ext_logo.clas.abap b/src/zcl_abaplint_abapgit_ext_logo.clas.abap index fc344c9..be94b81 100644 --- a/src/zcl_abaplint_abapgit_ext_logo.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_logo.clas.abap @@ -3,6 +3,14 @@ CLASS zcl_abaplint_abapgit_ext_logo DEFINITION FINAL CREATE PUBLIC. +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ PUBLIC SECTION. CONSTANTS c_logo TYPE string VALUE 'abaplint_logo.png'. @@ -19,6 +27,7 @@ CLASS zcl_abaplint_abapgit_ext_logo DEFINITION RETURNING VALUE(rv_html) TYPE string. + PROTECTED SECTION. PRIVATE SECTION. CONSTANTS c_mime TYPE string VALUE 'ZABAPLINT_LOGO'. @@ -27,7 +36,7 @@ ENDCLASS. -CLASS zcl_abaplint_abapgit_ext_logo IMPLEMENTATION. +CLASS ZCL_ABAPLINT_ABAPGIT_EXT_LOGO IMPLEMENTATION. METHOD get_logo_html. diff --git a/src/zcl_abaplint_abapgit_ext_ui.clas.abap b/src/zcl_abaplint_abapgit_ext_ui.clas.abap index f4439ce..b944720 100644 --- a/src/zcl_abaplint_abapgit_ext_ui.clas.abap +++ b/src/zcl_abaplint_abapgit_ext_ui.clas.abap @@ -4,6 +4,14 @@ CLASS zcl_abaplint_abapgit_ext_ui DEFINITION FINAL CREATE PRIVATE. +************************************************************************ +* abaplint Extension for abapGit +* +* https://github.com/Marc-Bernard-Tools/abaplint-Ext-for-abapGit +* +* Copyright 2023 Marc Bernard +* SPDX-License-Identifier: MIT +************************************************************************ PUBLIC SECTION. INTERFACES zif_abapgit_gui_event_handler. @@ -28,6 +36,7 @@ CLASS zcl_abaplint_abapgit_ext_ui DEFINITION RAISING zcx_abapgit_exception. + PROTECTED SECTION. PRIVATE SECTION. CONSTANTS: @@ -40,14 +49,16 @@ CLASS zcl_abaplint_abapgit_ext_ui DEFINITION toggle_view_source TYPE string VALUE 'toggle_view_source', END OF c_action. - CONSTANTS c_lines_before TYPE i VALUE 5. - CONSTANTS c_lines_after TYPE i VALUE 5. + CONSTANTS: + c_lines_before TYPE i VALUE 5, + c_lines_after TYPE i VALUE 5. - DATA mo_repo TYPE REF TO zcl_abapgit_repo_online. - DATA mv_check_run TYPE string. - DATA mv_count_total TYPE i. - DATA mt_issues TYPE zcl_abaplint_abapgit_ext_issue=>ty_issues. - DATA mv_view_source TYPE abap_bool. + DATA: + mo_repo TYPE REF TO zcl_abapgit_repo_online, + mv_check_run TYPE string, + mv_count_total TYPE i, + mt_issues TYPE zcl_abaplint_abapgit_ext_issue=>ty_issues, + mv_view_source TYPE abap_bool. METHODS _get_issues RETURNING @@ -85,7 +96,7 @@ ENDCLASS. -CLASS zcl_abaplint_abapgit_ext_ui IMPLEMENTATION. +CLASS ZCL_ABAPLINT_ABAPGIT_EXT_UI IMPLEMENTATION. METHOD constructor. @@ -301,7 +312,7 @@ CLASS zcl_abaplint_abapgit_ext_ui IMPLEMENTATION. DATA lv_url TYPE string. - lv_url = zcl_abaplint_abapgit_ext_exit=>get_instance( )->get_last_url( ). + lv_url = zcl_abaplint_abapgit_ext_exit=>get_last_url( ). CREATE OBJECT ri_html TYPE zcl_abapgit_html.