From 9a88998f9508ecd7780c099388616d500bb9e1b2 Mon Sep 17 00:00:00 2001 From: Him188 Date: Tue, 25 May 2021 12:17:55 +0800 Subject: [PATCH] Fix build --- .../main/kotlin/MiraiConsoleBuildPlugin.kt | 57 +---- buildSrc/src/main/kotlin/PublishingHelpers.kt | 1 - buildSrc/src/main/kotlin/upload/GitHub.kt | 214 ------------------ 3 files changed, 4 insertions(+), 268 deletions(-) delete mode 100644 buildSrc/src/main/kotlin/upload/GitHub.kt diff --git a/buildSrc/src/main/kotlin/MiraiConsoleBuildPlugin.kt b/buildSrc/src/main/kotlin/MiraiConsoleBuildPlugin.kt index 97b642409..8b72f64ea 100644 --- a/buildSrc/src/main/kotlin/MiraiConsoleBuildPlugin.kt +++ b/buildSrc/src/main/kotlin/MiraiConsoleBuildPlugin.kt @@ -1,10 +1,10 @@ /* - * Copyright 2019-2020 Mamoe Technologies and contributors. + * Copyright 2019-2021 Mamoe Technologies and contributors. * - * 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证. - * Use of this source code is governed by the GNU AFFERO GENERAL PUBLIC LICENSE version 3 license that can be found through the following link. + * 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证. + * Use of this source code is governed by the GNU AGPLv3 license that can be found through the following link. * - * https://github.com/mamoe/mirai/blob/master/LICENSE + * https://github.com/mamoe/mirai/blob/master/LICENSE */ @file:Suppress("UnstableApiUsage") @@ -46,55 +46,6 @@ class MiraiConsoleBuildPlugin : Plugin { } } } - - tasks.create("githubUpload") { - group = "mirai" - dependsOn(tasks.getByName("shadowJar")) - - doFirst { - timeout.set(java.time.Duration.ofHours(3)) - findLatestFile().let { (_, file) -> - val filename = file.name - println("Uploading file $filename") - runCatching { - upload.GitHub.upload( - file, - project, - "mirai-repo", - "shadow/${project.name}/${filename.replace("-all", "")}" - ) - }.exceptionOrNull()?.let { - System.err.println("GitHub Upload failed") - it.printStackTrace() // force show stacktrace - throw it - } - } - } - } - - tasks.create("cuiCloudUpload") { - group = "mirai" - dependsOn(tasks.getByName("shadowJar")) - - doFirst { - timeout.set(java.time.Duration.ofHours(3)) - findLatestFile().let { (_, file) -> - val filename = file.name - println("Uploading file $filename") - runCatching { - upload.CuiCloud.upload( - file, - project - ) - }.exceptionOrNull()?.let { - System.err.println("CuiCloud Upload failed") - it.printStackTrace() // force show stacktrace - throw it - } - } - } - - } } } diff --git a/buildSrc/src/main/kotlin/PublishingHelpers.kt b/buildSrc/src/main/kotlin/PublishingHelpers.kt index 046ba9d52..f344a436f 100644 --- a/buildSrc/src/main/kotlin/PublishingHelpers.kt +++ b/buildSrc/src/main/kotlin/PublishingHelpers.kt @@ -15,7 +15,6 @@ import org.gradle.api.publish.maven.MavenPublication import org.gradle.api.tasks.TaskContainer import org.gradle.api.tasks.bundling.Jar import org.gradle.kotlin.dsl.* -import upload.Bintray import java.util.* import kotlin.reflect.KProperty diff --git a/buildSrc/src/main/kotlin/upload/GitHub.kt b/buildSrc/src/main/kotlin/upload/GitHub.kt deleted file mode 100644 index 5a9ed545c..000000000 --- a/buildSrc/src/main/kotlin/upload/GitHub.kt +++ /dev/null @@ -1,214 +0,0 @@ -/* - * Copyright 2019-2020 Mamoe Technologies and contributors. - * - * 此源代码的使用受 GNU AFFERO GENERAL PUBLIC LICENSE version 3 许可证的约束, 可以在以下链接找到该许可证. - * Use of this source code is governed by the GNU AFFERO GENERAL PUBLIC LICENSE version 3 license that can be found through the following link. - * - * https://github.com/mamoe/mirai/blob/master/LICENSE - */ - -@file:Suppress("EXPERIMENTAL_API_USAGE") - -package upload - -import com.google.gson.JsonObject -import com.google.gson.JsonParser -import io.ktor.client.* -import io.ktor.client.engine.cio.* -import io.ktor.client.features.* -import io.ktor.client.request.* -import kotlinx.coroutines.Dispatchers -import kotlinx.coroutines.delay -import kotlinx.coroutines.runBlocking -import kotlinx.coroutines.withContext -import org.gradle.api.Project -import org.gradle.kotlin.dsl.provideDelegate -import org.jsoup.Connection -import org.jsoup.Jsoup -import java.io.File -import java.util.* - -internal val Http = HttpClient(CIO) { - engine { - requestTimeout = 6000_000 - } - install(HttpTimeout) { - socketTimeoutMillis = 6000_000 - requestTimeoutMillis = 6000_000 - connectTimeoutMillis = 6000_000 - } -} - -object GitHub { - - private fun getGithubToken(project: Project): String { - kotlin.runCatching { - @Suppress("UNUSED_VARIABLE", "LocalVariableName") - val github_token: String by project - return github_token - } - - System.getProperty("github_token", null)?.let { - return it.trim() - } - - File(File(System.getProperty("user.dir")).parent, "/token.txt").let { local -> - if (local.exists()) { - return local.readText().trim() - } - } - - File(File(System.getProperty("user.dir")), "/token.txt").let { local -> - if (local.exists()) { - return local.readText().trim() - } - } - - project.file("token.txt").let { local -> - if (local.exists()) { - return local.readText().trim() - } - } - - project.rootProject.file("token.txt").let { local -> - if (local.exists()) { - return local.readText().trim() - } - } - - error( - "Cannot find github token, " + - "please specify by creating a file token.txt in project dir, " + - "or by providing JVM parameter 'github_token'" - ) - } - - fun upload(file: File, project: Project, repo: String, targetFilePath: String) = runBlocking { - val token = getGithubToken(project) - println("token.length=${token.length}") - val url = "https://api.github.com/repos/project-mirai/$repo/contents/$targetFilePath" - retryCatching(100, onFailure = { - it.printStackTrace() - delay(30_000) - }) { // 403 forbidden? - Http.put("$url?access_token=$token") { - val sha = retryCatching(3, onFailure = { delay(30_000) }) { - getGithubSha( - repo, - targetFilePath, - "master", - project - ) - }.getOrNull() - println("sha=$sha") - val content = String(Base64.getEncoder().encode(file.readBytes())) - body = """ - { - "message": "Automatically upload on release ${project.name}:${project.version}", - "content": "$content" - ${if (sha == null) "" else """, "sha": "$sha" """} - } - """.trimIndent() - }.let { - println("Upload response: $it") - } - delay(1000) - }.getOrThrow() - } - - - private suspend fun getGithubSha( - repo: String, - filePath: String, - branch: String, - project: Project - ): String? { - fun String.asJson(): JsonObject { - return JsonParser.parseString(this).asJsonObject - } - - /* - * 只能获取1M以内/branch为master的sha - * */ - class TargetTooLargeException : Exception("Target TOO Large") - - suspend fun getShaSmart(repo: String, filePath: String, project: Project): String? { - return withContext(Dispatchers.IO) { - val response = Jsoup - .connect( - "https://api.github.com/repos/project-mirai/$repo/contents/$filePath?access_token=" + getGithubToken( - project - ) - ) - .ignoreContentType(true) - .ignoreHttpErrors(true) - .method(Connection.Method.GET) - .execute() - if (response.statusCode() == 404) { - null - } else { - val p = response.body().asJson() - if (p.has("message") && p["message"].asString == "This API returns blobs up to 1 MB in size. The requested blob is too large to fetch via the API, but you can use the Git Data API to request blobs up to 100 MB in size.") { - throw TargetTooLargeException() - } - p.get("sha").asString - } - } - } - - suspend fun getShaStupid( - repo: String, - filePath: String, - branch: String, - project: Project - ): String? { - val resp = withContext(Dispatchers.IO) { - Jsoup - .connect( - "https://api.github.com/repos/project-mirai/$repo/git/ref/heads/$branch?access_token=" + getGithubToken( - project - ) - ) - .ignoreContentType(true) - .ignoreHttpErrors(true) - .method(Connection.Method.GET) - .execute() - } - if (resp.statusCode() == 404) { - println("Branch Not Found") - return null - } - val info = resp.body().asJson().get("object").asJsonObject.get("url").asString - var parentNode = withContext(Dispatchers.IO) { - Jsoup.connect(info + "?access_token=" + getGithubToken(project)).ignoreContentType(true) - .method(Connection.Method.GET) - .execute().body().asJson().get("tree").asJsonObject.get("url").asString - } - filePath.split("/").forEach { subPath -> - withContext(Dispatchers.IO) { - Jsoup.connect(parentNode + "?access_token=" + getGithubToken(project)).ignoreContentType(true) - .method(Connection.Method.GET).execute().body().asJson().get("tree").asJsonArray - }.forEach list@{ - with(it.asJsonObject) { - if (this.get("path").asString == subPath) { - parentNode = this.get("url").asString - return@list - } - } - } - } - check(parentNode.contains("/blobs/")) - return parentNode.substringAfterLast("/") - } - - return if (branch == "master") { - try { - getShaSmart(repo, filePath, project) - } catch (e: TargetTooLargeException) { - getShaStupid(repo, filePath, branch, project) - } - } else { - getShaStupid(repo, filePath, branch, project) - } - } -} \ No newline at end of file