2020-06-22 17:02:36 +00:00
|
|
|
/*
|
|
|
|
Mangadex@Home
|
|
|
|
Copyright (c) 2020, MangaDex Network
|
|
|
|
This file is part of MangaDex@Home.
|
|
|
|
|
|
|
|
MangaDex@Home is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
MangaDex@Home is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this MangaDex@Home. If not, see <http://www.gnu.org/licenses/>.
|
2021-01-25 02:25:49 +00:00
|
|
|
*/
|
2021-01-24 04:55:11 +00:00
|
|
|
package mdnet.server
|
2020-06-12 19:56:51 +00:00
|
|
|
|
2020-07-04 19:00:59 +00:00
|
|
|
import mdnet.BuildInfo
|
2021-01-24 04:55:11 +00:00
|
|
|
import mdnet.Constants
|
|
|
|
import mdnet.logging.warn
|
2020-06-12 19:56:51 +00:00
|
|
|
import org.http4k.core.Filter
|
|
|
|
import org.http4k.core.HttpHandler
|
|
|
|
import org.http4k.core.Request
|
|
|
|
import org.http4k.core.Response
|
|
|
|
import org.http4k.core.Status
|
|
|
|
import org.slf4j.LoggerFactory
|
2021-01-24 04:55:11 +00:00
|
|
|
import java.time.ZoneOffset
|
|
|
|
import java.time.ZonedDateTime
|
|
|
|
import java.time.format.DateTimeFormatter
|
|
|
|
import java.util.*
|
2020-06-12 19:56:51 +00:00
|
|
|
|
|
|
|
private val HTTP_TIME_FORMATTER = DateTimeFormatter.ofPattern("EEE, dd MMM yyyy HH:mm:ss O", Locale.ENGLISH)
|
|
|
|
private val LOGGER = LoggerFactory.getLogger("Application")
|
|
|
|
|
|
|
|
fun addCommonHeaders(): Filter {
|
|
|
|
return Filter { next: HttpHandler ->
|
|
|
|
{ request: Request ->
|
|
|
|
val response = next(request)
|
|
|
|
response.header("Date", HTTP_TIME_FORMATTER.format(ZonedDateTime.now(ZoneOffset.UTC)))
|
2021-01-24 04:55:11 +00:00
|
|
|
.header("Server", "MangaDex@Home Node ${BuildInfo.VERSION} (${Constants.CLIENT_BUILD})")
|
2020-06-12 19:56:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fun catchAllHideDetails(): Filter {
|
|
|
|
return Filter { next: HttpHandler ->
|
|
|
|
{ request: Request ->
|
|
|
|
try {
|
|
|
|
next(request)
|
|
|
|
} catch (e: Exception) {
|
2021-02-23 17:18:47 +00:00
|
|
|
val cleanedUri = request.uri.path.replaceBefore("/data", "/{token}")
|
|
|
|
LOGGER.warn(e) { "Request for $cleanedUri errored" }
|
2020-07-04 19:39:11 +00:00
|
|
|
|
2020-06-12 19:56:51 +00:00
|
|
|
Response(Status.INTERNAL_SERVER_ERROR)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|