All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.metaeffekt.mirror.download.other.EolDownload Maven / Gradle / Ivy

/*
 * Copyright 2021-2024 the original author or authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.metaeffekt.mirror.download.other;

import com.metaeffekt.artifact.analysis.utils.FileUtils;
import com.metaeffekt.mirror.download.documentation.MirrorMetadata;
import com.metaeffekt.mirror.Retry;
import com.metaeffekt.mirror.download.Download;
import com.metaeffekt.mirror.download.ResourceLocation;
import org.json.JSONArray;

import java.io.File;
import java.io.IOException;
import java.net.URL;
import java.nio.charset.StandardCharsets;

/**
 * 

References:

* *

This download manages the End of Life (EOL) data for various products using their API. * The API provides a list of product identifiers, and for each product, a detailed version history including end-of-life dates.

*

The downloader fetches this list of all products and retrieves their individual version information for each product. * Each product's version data is stored locally in JSON files.

*
.
 * └── eol
 *     ├── java.json
 *     ├── nodejs.json
 *     ├── python.json
 *     └── ...
 * 
*/ @MirrorMetadata(directoryName = "eol", mavenPropertyName = "eolDownload") public class EolDownload extends Download { public EolDownload(File baseMirrorDirectory) { super(baseMirrorDirectory, EolDownload.class); } @Override protected void performDownload() { final URL allProductsUrl = getRemoteResourceLocationUrl(ResourceLocationEOL.EOL_ALL_PRODUCTS); final JSONArray allProducts = new JSONArray(String.join("", super.downloader.fetchResponseBodyFromUrlAsList(allProductsUrl))); for (int i = 0; i < allProducts.length(); i++) { final String product = allProducts.getString(i); final URL productUrl = getRemoteResourceLocationUrl(ResourceLocationEOL.EOL_PRODUCT_VERSIONS, product); final JSONArray productVersions = new Retry<>(() -> new JSONArray(String.join("", super.downloader.fetchResponseBodyFromUrlAsList(productUrl)))) .retryCount(3) .withDelay(1000) .onFailure(e -> { throw new RuntimeException("Failed to fetch EOL product versions.", e); }) .run(); try { FileUtils.write(new File(super.downloadIntoDirectory, product + ".json"), productVersions.toString(), StandardCharsets.UTF_8); } catch (IOException e) { throw new RuntimeException("Failed to write EOL product info to directory.", e); } } } @Override protected boolean additionalIsDownloadRequired() { return false; } @Override public void setRemoteResourceLocation(String location, String url) { super.setRemoteResourceLocation(ResourceLocationEOL.valueOf(location), url); } /** * The ResourceLocationEOL enum defines the URLs for accessing the End of Life (EOL) API. * https://endoflife.date/docs/api */ public enum ResourceLocationEOL implements ResourceLocation { /** * URL for the EOL API that is used to fetch the version information for a single product. *
    *
  1. %s the product identifier to fetch the version information for (example: java)
  2. *
*/ EOL_PRODUCT_VERSIONS("https://endoflife.date/api/%s.json"), /** * URL for the EOL API that is used to fetch all product identifiers.
* Returns an array of strings. */ EOL_ALL_PRODUCTS("https://endoflife.date/api/all.json"); private final String defaultValue; ResourceLocationEOL(String defaultValue) { this.defaultValue = defaultValue; } @Override public String getDefault() { return this.defaultValue; } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy