From 8f0c4d805f729da6737f7b27ef96b0856287a101 Mon Sep 17 00:00:00 2001 From: strahi-linux Date: Tue, 1 Oct 2024 09:36:15 +0200 Subject: [PATCH] Added option to reindex only current daily update needed stuff --- .github/workflows/boardCardReleaseTest.yaml | 2 +- .gitignore | 7 +++++++ scripts/index.py | 14 ++++++++++++-- 3 files changed, 20 insertions(+), 3 deletions(-) diff --git a/.github/workflows/boardCardReleaseTest.yaml b/.github/workflows/boardCardReleaseTest.yaml index 302759ee5..7dc0dd467 100644 --- a/.github/workflows/boardCardReleaseTest.yaml +++ b/.github/workflows/boardCardReleaseTest.yaml @@ -94,7 +94,7 @@ jobs: MIKROE_NECTO_AWS: ${{ secrets.MIKROE_NECTO_AWS }} run: | echo "Indexing to Test." - python -u scripts/index.py ${{ github.repository }} ${{ secrets.GITHUB_TOKEN }} ${{ steps.changelog_update.outputs.sdk_tag_name }} ${{ secrets.ES_INDEX_TEST }} "False" + python -u scripts/index.py ${{ github.repository }} ${{ secrets.GITHUB_TOKEN }} ${{ steps.changelog_update.outputs.sdk_tag_name }} ${{ secrets.ES_INDEX_TEST }} "False" "--board_card_only" "True" - name: Trigger database update in Core repo run: | diff --git a/.gitignore b/.gitignore index e41750b50..cc352bca6 100644 --- a/.gitignore +++ b/.gitignore @@ -4,3 +4,10 @@ output __pycache__ *.7z tmp +install +.cache +.meproject +build* +.clangd +compile_commands.json +settings.json diff --git a/scripts/index.py b/scripts/index.py index 7696e58b4..00c652520 100644 --- a/scripts/index.py +++ b/scripts/index.py @@ -187,7 +187,7 @@ def fetch_current_indexed_version(es : Elasticsearch, index_name, package_name): return None # Function to index release details into Elasticsearch -def index_release_to_elasticsearch(es : Elasticsearch, index_name, release_details, token): +def index_release_to_elasticsearch(es : Elasticsearch, index_name, release_details, token, board_card_only=False): # Iterate over each asset in the release and previous release metadata_content = [] for each_release_details in release_details: @@ -243,6 +243,15 @@ def index_release_to_elasticsearch(es : Elasticsearch, index_name, release_detai name_without_extension = os.path.splitext(os.path.basename(asset['name']))[0] package_id = name_without_extension + ## Index only current date assets if board_card_only is True, + ## but re-index images always! + if board_card_only and name_without_extension != 'images': + asset_date = datetime.strptime(asset['created_at'], "%Y-%m-%dT%H:%M:%SZ") + if asset_date.date() != datetime.utcnow().date(): + logger.info("Asset %s not indexed" % name_without_extension) + bar() + continue + # Increase bar value bar.text(name_without_extension) bar() @@ -486,6 +495,7 @@ def str2bool(v): parser.add_argument("release_version", help="Selected release version to index", type=str) parser.add_argument("select_index", help="Provided index name") parser.add_argument("promote_release_to_latest", help="Sets current release as latest", type=str2bool, default=False) + parser.add_argument("--board_card_only", help="Will reindex only things needed for current daily update", type=bool, default=False) args = parser.parse_args() # Elasticsearch instance used for indexing @@ -507,7 +517,7 @@ def str2bool(v): index_release_to_elasticsearch( es, args.select_index, fetch_release_details(args.repo, args.token, args.release_version), - args.token + args.token, args.board_card_only ) # And then promote to latest if requested