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

com.intershop.gradle.icm.utils.HttpProbe.kt Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2020 Intershop Communications AG.
 *
 * 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.intershop.gradle.icm.utils

import org.gradle.api.Project
import org.gradle.internal.service.ServiceRegistry
import java.net.URI
import java.net.http.HttpClient
import java.net.http.HttpRequest
import java.net.http.HttpResponse
import java.time.Duration

class HttpProbe(
        private val project : Project,
        serviceRegistrySupplier : () -> ServiceRegistry,
        target : URI,
        requestTimeout : Duration = Duration.ofSeconds(30)) : AbstractProbe(serviceRegistrySupplier) {
    private val client : HttpClient = HttpClient.newHttpClient()
    private var statusCheck : (statusCode : Int) -> Boolean = { statusCode -> statusCode == 200 }
    val request : HttpRequest = HttpRequest.newBuilder().GET().timeout(requestTimeout).uri(target).build()

    override fun executeOnce(): Boolean {
        val reqDesc = describeRequest()
        val response = try {
            project.logger.debug("(Re-)trying to probe a {}", reqDesc)
            client.send(request, HttpResponse.BodyHandlers.ofString())
        } catch (e: Exception) {
            project.logger.debug("Unable to probe {}", reqDesc, e)
            return false
        }
        project.logger.debug("Received response while probing a {}: status={}", reqDesc, response.statusCode())
        return statusCheck.invoke(response.statusCode())
    }

    override fun describeRequest(): String = "HTTP ${request.method()} to ${request.uri()}"

    fun requireHttpStatus(statusCheck : (statusCode : Int) -> Boolean ) : HttpProbe {
        this.statusCheck = statusCheck
        return this
    }

    override fun toString(): String {
        return "HttpProbe using ${request.method()} to '${request.uri()}' retried each $retryInterval timing out " +
               "after $retryTimeout with a request timeout of ${request.timeout()}"
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy