⁠
rednesto: Fix #2391 Add authorization capability to project creator
Supports in-IDE credentials, and sourcing from Maven's settings.xml and Gradle's gradle.properties
Supports in-IDE credentials, and sourcing from Maven's settings.xml and Gradle's gradle.properties
- /*
- * Minecraft Development for IntelliJ
- *
- * https://mcdev.io/
- *
- * Copyright (C) 2024 minecraft-dev
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, version 3.0 only.
- *
- * This program 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 Lesser General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
- package com.demonwav.mcdev.creator
- import com.demonwav.mcdev.update.PluginUtil
- import com.github.kittinunf.fuel.core.FuelManager
- import com.github.kittinunf.fuel.core.requests.suspendable
- import java.io.IOException
- import java.util.function.Predicate
- import javax.xml.stream.XMLInputFactory
- import javax.xml.stream.events.XMLEvent
- @Throws(IOException::class)
- suspend fun collectMavenVersions(url: String, filter: Predicate<String> = Predicate { true }): List<String> {
- val manager = FuelManager()
- manager.proxy = selectProxy(url)
- val response = manager.get(url)
- .header("User-Agent", PluginUtil.useragent)
- .allowRedirects(true)
- .suspendable()
- .await()
- val result = mutableListOf<String>()
- response.body().toStream().use { stream ->
- val inputFactory = XMLInputFactory.newInstance()
- @Suppress("UNCHECKED_CAST")
- val reader = inputFactory.createXMLEventReader(stream) as Iterator<XMLEvent>
- for (event in reader) {
- if (!event.isStartElement) {
- continue
- }
- val start = event.asStartElement()
- val name = start.name.localPart
- if (name != "version") {
- continue
- }
- val versionEvent = reader.next()
- if (!versionEvent.isCharacters) {
- continue
- }
- val version = versionEvent.asCharacters().data
- if (filter.test(version)) {
- result += version
- }
- }
- }
- return result
- }
- @Throws(IOException::class)
- suspend fun scrapeArtifactoryDirectoryListing(url: String): List<String> {
- val manager = FuelManager()
- manager.proxy = selectProxy(url)
- val response = manager.get(url)
- .header("User-Agent", PluginUtil.useragent)
- .allowRedirects(true)
- .suspendable()
- .await()
- val result = mutableListOf<String>()
- response.body().toStream().use { stream ->
- val inputFactory = XMLInputFactory.newInstance()
- @Suppress("UNCHECKED_CAST")
- val reader = inputFactory.createXMLEventReader(stream) as Iterator<XMLEvent>
- for (event in reader) {
- if (!event.isStartElement) {
- continue
- }
- val start = event.asStartElement()
- val name = start.name.localPart
- if (name != "a") {
- continue
- }
- val childPathEvent = reader.next()
- if (!childPathEvent.isCharacters) {
- continue
- }
- val childPath = childPathEvent.asCharacters().data
- if (childPath != "../") {
- result += childPath
- }
- }
- }
- return result
- }
- /*
- * Minecraft Development for IntelliJ
- *
- * https://mcdev.io/
- *
- * Copyright (C) 2024 minecraft-dev
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published
- * by the Free Software Foundation, version 3.0 only.
- *
- * This program 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 Lesser General Public License
- * along with this program. If not, see <https://www.gnu.org/licenses/>.
- */
- package com.demonwav.mcdev.creator
- import com.demonwav.mcdev.update.PluginUtil
- import com.github.kittinunf.fuel.core.FuelManager
- import com.github.kittinunf.fuel.core.Request
- import com.github.kittinunf.fuel.core.requests.suspendable
- import java.io.IOException
- import java.util.function.Function
- import java.util.function.Predicate
- import javax.xml.stream.XMLInputFactory
- import javax.xml.stream.events.XMLEvent
- @Throws(IOException::class)
- suspend fun collectMavenVersions(
- url: String,
- requestCustomizer: Function<Request, Request>? = null,
- filter: Predicate<String> = Predicate { true }
- ): List<String> {
- val manager = FuelManager()
- manager.proxy = selectProxy(url)
- val response = manager.get(url)
- .header("User-Agent", PluginUtil.useragent)
- .allowRedirects(true)
- .let { requestCustomizer?.apply(it) ?: it }
- .suspendable()
- .await()
- val result = mutableListOf<String>()
- response.body().toStream().use { stream ->
- val inputFactory = XMLInputFactory.newInstance()
- @Suppress("UNCHECKED_CAST")
- val reader = inputFactory.createXMLEventReader(stream) as Iterator<XMLEvent>
- for (event in reader) {
- if (!event.isStartElement) {
- continue
- }
- val start = event.asStartElement()
- val name = start.name.localPart
- if (name != "version") {
- continue
- }
- val versionEvent = reader.next()
- if (!versionEvent.isCharacters) {
- continue
- }
- val version = versionEvent.asCharacters().data
- if (filter.test(version)) {
- result += version
- }
- }
- }
- return result
- }
- @Throws(IOException::class)
- suspend fun scrapeArtifactoryDirectoryListing(url: String): List<String> {
- val manager = FuelManager()
- manager.proxy = selectProxy(url)
- val response = manager.get(url)
- .header("User-Agent", PluginUtil.useragent)
- .allowRedirects(true)
- .suspendable()
- .await()
- val result = mutableListOf<String>()
- response.body().toStream().use { stream ->
- val inputFactory = XMLInputFactory.newInstance()
- @Suppress("UNCHECKED_CAST")
- val reader = inputFactory.createXMLEventReader(stream) as Iterator<XMLEvent>
- for (event in reader) {
- if (!event.isStartElement) {
- continue
- }
- val start = event.asStartElement()
- val name = start.name.localPart
- if (name != "a") {
- continue
- }
- val childPathEvent = reader.next()
- if (!childPathEvent.isCharacters) {
- continue
- }
- val childPath = childPathEvent.asCharacters().data
- if (childPath != "../") {
- result += childPath
- }
- }
- }
- return result
- }