2021-05-14 01:50:33 +02:00
|
|
|
import org.apache.commons.codec.Charsets
|
2021-04-05 15:47:34 +02:00
|
|
|
import org.apache.http.HttpEntity
|
2021-05-14 01:50:33 +02:00
|
|
|
import org.apache.http.HttpResponse
|
|
|
|
import org.apache.http.client.HttpClient
|
|
|
|
import org.apache.http.client.config.CookieSpecs
|
|
|
|
import org.apache.http.client.config.RequestConfig
|
2021-04-05 15:47:34 +02:00
|
|
|
import org.apache.http.client.methods.CloseableHttpResponse
|
|
|
|
import org.apache.http.client.methods.HttpPost
|
|
|
|
import org.apache.http.entity.ContentType
|
|
|
|
import org.apache.http.entity.mime.MultipartEntityBuilder
|
|
|
|
import org.apache.http.impl.client.CloseableHttpClient
|
2021-05-14 01:50:33 +02:00
|
|
|
import org.apache.http.impl.client.HttpClientBuilder
|
2021-04-05 15:47:34 +02:00
|
|
|
import org.apache.http.impl.client.HttpClients
|
2021-05-14 01:50:33 +02:00
|
|
|
import org.apache.http.client.methods.HttpGet
|
2021-05-18 04:39:06 +02:00
|
|
|
import com.google.gson.Gson
|
|
|
|
|
|
|
|
|
|
|
|
apply plugin: 'java'
|
|
|
|
apply plugin: 'maven-publish'
|
|
|
|
apply plugin: 'idea'
|
2021-04-05 15:47:34 +02:00
|
|
|
|
|
|
|
buildscript {
|
|
|
|
repositories {
|
|
|
|
maven {url "https://plugins.gradle.org/m2/"}
|
|
|
|
mavenCentral()
|
|
|
|
mavenLocal()
|
2021-05-18 04:39:06 +02:00
|
|
|
jcenter()
|
2021-04-05 15:47:34 +02:00
|
|
|
}
|
|
|
|
dependencies {
|
|
|
|
classpath "org.apache.httpcomponents:httpmime:4.5.13"
|
2021-05-18 04:39:06 +02:00
|
|
|
classpath "com.google.code.gson:gson:2.8.6"
|
|
|
|
classpath "org.apache.httpcomponents:httpclient:4.5.13"
|
2021-04-05 15:47:34 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
def branch = System.getenv("GITHUB_REF");
|
|
|
|
def sha = System.getenv("GITHUB_SHA");
|
2021-05-12 03:52:43 +02:00
|
|
|
def isDevBranch = branch == null || !(branch.startsWith("refs/tags/") && !branch.contains("-"))
|
2021-04-05 15:47:34 +02:00
|
|
|
|
2021-04-05 16:07:56 +02:00
|
|
|
group = 'com.sekwah.advancedportals'
|
2021-05-05 03:14:25 +02:00
|
|
|
version = getPluginData("version") + (isDevBranch ? '-SNAPSHOT' : '')
|
2021-04-05 16:07:56 +02:00
|
|
|
|
2018-07-23 02:43:29 +02:00
|
|
|
description = ""
|
|
|
|
|
|
|
|
sourceCompatibility = 1.8
|
|
|
|
targetCompatibility = 1.8
|
|
|
|
|
|
|
|
tasks.withType(JavaCompile) {
|
|
|
|
options.encoding = 'UTF-8'
|
|
|
|
}
|
|
|
|
|
2019-05-31 05:04:33 +02:00
|
|
|
String getPluginData(String tag) {
|
2019-08-12 10:40:06 +02:00
|
|
|
File file = file("src/main/resources/plugin.yml")
|
2019-05-31 05:04:33 +02:00
|
|
|
String version = "notfound"
|
|
|
|
file.readLines("UTF-8").each {String line ->
|
|
|
|
line = line.trim()
|
|
|
|
if(line.startsWith(tag)) {
|
|
|
|
version = line.substring(tag.length() + 2, line.length())
|
|
|
|
}
|
|
|
|
}
|
2019-06-02 05:39:08 +02:00
|
|
|
println "Advanced Portals v" + version
|
2019-05-31 05:04:33 +02:00
|
|
|
return version
|
|
|
|
}
|
|
|
|
|
2018-07-23 02:43:29 +02:00
|
|
|
configurations {
|
|
|
|
// configuration that holds jars to copy into lib
|
|
|
|
includeLibs
|
|
|
|
}
|
|
|
|
|
|
|
|
repositories {
|
2020-01-20 11:55:18 +01:00
|
|
|
maven { url "https://repo.maven.apache.org/maven2" }
|
2018-07-23 02:43:29 +02:00
|
|
|
maven { url "https://hub.spigotmc.org/nexus/content/repositories/snapshots/" }
|
2020-01-20 11:55:18 +01:00
|
|
|
maven { url "https://oss.sonatype.org/content/repositories/snapshots/" }
|
2020-12-30 03:49:45 +01:00
|
|
|
maven { url "https://nexus.velocitypowered.com/repository/maven-public/" }
|
2021-05-09 04:45:31 +02:00
|
|
|
maven { url 'https://papermc.io/repo/repository/maven-public/' }
|
2018-07-23 02:43:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// includeLibs just says to include the library in the final jar
|
|
|
|
dependencies {
|
2021-05-14 01:50:33 +02:00
|
|
|
|
2020-06-26 01:42:39 +02:00
|
|
|
//implementation "org.bukkit:bukkit:1.16.1-R0.1-SNAPSHOT"
|
|
|
|
implementation "org.spigotmc:spigot-api:1.16.1-R0.1-SNAPSHOT"
|
2020-01-20 11:55:18 +01:00
|
|
|
implementation "net.md-5:bungeecord-api:1.15-SNAPSHOT"
|
|
|
|
|
2020-12-30 03:49:45 +01:00
|
|
|
implementation "com.velocitypowered:velocity-api:1.1.0-SNAPSHOT"
|
|
|
|
annotationProcessor "com.velocitypowered:velocity-api:1.1.0-SNAPSHOT"
|
|
|
|
|
2019-12-30 16:18:14 +01:00
|
|
|
implementation "io.netty:netty-all:4.0.4.Final"
|
2021-05-09 04:45:31 +02:00
|
|
|
compileOnly 'com.destroystokyo.paper:paper-api:1.16.5-R0.1-SNAPSHOT'
|
2020-06-21 03:49:18 +02:00
|
|
|
|
|
|
|
//compile fileTree(dir: 'libs', include: ['*.jar'])
|
2018-07-23 02:43:29 +02:00
|
|
|
}
|
|
|
|
|
2021-04-05 15:47:34 +02:00
|
|
|
/** For pre-releases and testers to be able to try the latest commits if they want.
|
|
|
|
* If the builds start exceeding 8MB then we may want to upload to s3 instead and periodically clear.
|
|
|
|
* TODO possibly add a task that announces when builds are made?
|
|
|
|
* Though add a note that it may take a while for Curse to approve the files.
|
|
|
|
*/
|
|
|
|
task discordupload {
|
|
|
|
dependsOn(jar)
|
|
|
|
doLast {
|
|
|
|
String discordWebhook = System.getenv("DISCORD_WEBHOOK")
|
|
|
|
|
|
|
|
if(discordWebhook != null) {
|
|
|
|
println("Logging Into Discord")
|
|
|
|
|
|
|
|
CloseableHttpClient httpClient = HttpClients.createDefault()
|
|
|
|
HttpPost uploadFile = new HttpPost(discordWebhook)
|
|
|
|
|
|
|
|
MultipartEntityBuilder builder = MultipartEntityBuilder.create()
|
|
|
|
builder.addTextBody("content", "New automated dev build\n\n" +
|
2021-05-14 03:10:38 +02:00
|
|
|
"Current Features: <${project.github}/blob/${sha}/docs/CHANGELOG.md>")
|
2021-04-05 15:47:34 +02:00
|
|
|
|
|
|
|
builder.addBinaryBody("file", file(jar.archiveFile).newInputStream(), ContentType.APPLICATION_OCTET_STREAM, jar.archiveName)
|
|
|
|
|
|
|
|
HttpEntity multipart = builder.build()
|
|
|
|
|
|
|
|
uploadFile.setEntity(multipart)
|
|
|
|
CloseableHttpResponse response = httpClient.execute(uploadFile)
|
|
|
|
response.getEntity()
|
|
|
|
|
|
|
|
println("Posted build")
|
|
|
|
|
|
|
|
} else {
|
|
|
|
println("Discord webhook unspecified")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-05-14 01:50:33 +02:00
|
|
|
String getValueFromCurseAPI(apiKey, endpoint) {
|
|
|
|
String API_BASE_URL = 'https://minecraft.curseforge.com'
|
|
|
|
|
2021-05-18 04:39:06 +02:00
|
|
|
Gson gson = new Gson()
|
|
|
|
|
2021-05-14 01:50:33 +02:00
|
|
|
HttpClient client = HttpClientBuilder.create()
|
|
|
|
.setDefaultRequestConfig(RequestConfig.custom()
|
|
|
|
.setCookieSpec(CookieSpecs.IGNORE_COOKIES).build()).build()
|
|
|
|
|
|
|
|
HttpGet get = new HttpGet(API_BASE_URL + endpoint)
|
|
|
|
get.setHeader('X-Api-Token', apiKey)
|
|
|
|
|
|
|
|
HttpResponse response = client.execute(get)
|
|
|
|
|
|
|
|
int statusCode = response.statusLine.statusCode
|
|
|
|
|
|
|
|
if (statusCode == 200) {
|
|
|
|
byte[] data = response.entity.content.bytes
|
|
|
|
return new String(data, Charsets.UTF_8)
|
|
|
|
} else {
|
|
|
|
if (response.getFirstHeader('content-type').value.contains('json')) {
|
|
|
|
InputStreamReader reader = new InputStreamReader(response.entity.content)
|
|
|
|
reader.close()
|
|
|
|
throw new RuntimeException("[CurseForge] Error")
|
|
|
|
} else {
|
|
|
|
throw new RuntimeException("[CurseForge] HTTP Error Code $response.statusLine.statusCode: $response.statusLine.reasonPhrase")
|
|
|
|
}
|
2021-04-05 15:47:34 +02:00
|
|
|
}
|
2021-05-14 01:50:33 +02:00
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2021-05-18 04:39:06 +02:00
|
|
|
/**
|
|
|
|
* Upload a single file (in case you also want to upload the other files like source n stuff)
|
|
|
|
* @param json
|
|
|
|
* @param file
|
|
|
|
* @return
|
|
|
|
* @throws IOException
|
|
|
|
* @throws URISyntaxException
|
|
|
|
*/
|
|
|
|
UploadResponse uploadFile(Metadata metadata, File file, String apiKey, Gson gson) throws IOException, URISyntaxException {
|
|
|
|
String API_BASE_URL = 'https://minecraft.curseforge.com'
|
|
|
|
String UPLOAD_URL = "/api/projects/%s/upload-file"
|
|
|
|
// Upload
|
|
|
|
// Important info
|
|
|
|
String uploadUrl = String.format(API_BASE_URL + UPLOAD_URL, project.curse_project_id)
|
|
|
|
|
|
|
|
HttpClient client = HttpClientBuilder.create()
|
|
|
|
.setDefaultRequestConfig(RequestConfig.custom()
|
|
|
|
.setCookieSpec(CookieSpecs.IGNORE_COOKIES).build()).build()
|
|
|
|
|
|
|
|
HttpPost post = new HttpPost(uploadUrl)
|
|
|
|
post.setHeader('X-Api-Token', apiKey)
|
|
|
|
|
|
|
|
|
|
|
|
// https://support.curseforge.com/en/support/solutions/articles/9000197321-curseforge-api
|
|
|
|
post.setEntity(MultipartEntityBuilder.create()
|
|
|
|
.addTextBody('metadata', gson.toJson(metadata), ContentType.APPLICATION_JSON)
|
|
|
|
.addBinaryBody('file', file)
|
|
|
|
.build())
|
|
|
|
|
|
|
|
HttpResponse response = client.execute(post)
|
|
|
|
InputStreamReader reader = new InputStreamReader(response.entity.content)
|
|
|
|
UploadResponse uploadResponse = gson.fromJson(reader, UploadResponse)
|
|
|
|
reader.close()
|
|
|
|
return uploadResponse
|
2021-05-14 01:50:33 +02:00
|
|
|
}
|
2021-04-05 15:47:34 +02:00
|
|
|
|
2021-05-14 01:50:33 +02:00
|
|
|
class GameVersion {
|
|
|
|
int id
|
|
|
|
int gameVersionTypeID
|
|
|
|
String name
|
|
|
|
String slug
|
|
|
|
}
|
|
|
|
|
2021-05-18 04:39:06 +02:00
|
|
|
/**
|
|
|
|
* As described here https://support.curseforge.com/en/support/solutions/articles/9000197321-curseforge-api
|
|
|
|
*/
|
|
|
|
class Metadata {
|
|
|
|
String changelog
|
|
|
|
String changelogType
|
|
|
|
int[] gameVersions
|
|
|
|
String releaseType
|
|
|
|
}
|
|
|
|
|
|
|
|
class UploadResponse {
|
|
|
|
int id;
|
|
|
|
}
|
|
|
|
|
2021-05-14 01:50:33 +02:00
|
|
|
|
|
|
|
// Based on https://github.com/matthewprenger/CurseGradle as it didnt support Bukkit uploads at the time.
|
|
|
|
task curseforge {
|
|
|
|
dependsOn(jar)
|
|
|
|
doLast {
|
|
|
|
String apiKey = null
|
|
|
|
|
|
|
|
if (System.getenv("CURSE_API") != null) {
|
|
|
|
apiKey = System.getenv("CURSE_API")
|
|
|
|
}
|
|
|
|
|
|
|
|
if(apiKey != null) {
|
2021-05-18 04:39:06 +02:00
|
|
|
|
|
|
|
Gson gson = new Gson()
|
|
|
|
|
|
|
|
//String VERSION_TYPES_URL = "/api/game/version-types"
|
|
|
|
int gameVersionTypeID = 1
|
2021-05-14 01:50:33 +02:00
|
|
|
String VERSION_URL = "/api/game/versions"
|
|
|
|
println("Uploading to CurseForge")
|
|
|
|
|
2021-05-18 04:39:06 +02:00
|
|
|
// Get game versions
|
|
|
|
String gameVersionsString = getValueFromCurseAPI(apiKey, VERSION_URL)
|
|
|
|
GameVersion[] gameVersions = gson.fromJson(gameVersionsString, GameVersion[].class)
|
|
|
|
def versions = gameVersions.findAll {it.gameVersionTypeID == gameVersionTypeID}
|
|
|
|
|
|
|
|
String[] supportedVersions = [
|
|
|
|
"1.16",
|
|
|
|
"1.15",
|
|
|
|
"1.14",
|
|
|
|
"1.13"
|
|
|
|
]
|
|
|
|
|
|
|
|
def supportedGameVersions = versions.findAll {supportedVersions.contains(it.name)}
|
|
|
|
int[] supportedGameVersionIds = supportedGameVersions.collect {it.id}.toArray()
|
|
|
|
|
|
|
|
println("Supported Version Id's ${supportedGameVersionIds}")
|
|
|
|
|
|
|
|
Metadata uploadMetadata = new Metadata();
|
|
|
|
|
|
|
|
uploadMetadata.changelog = "${project.github}/blob/${sha}/CHANGELOG.md"
|
|
|
|
uploadMetadata.changelogType = "markdown"
|
|
|
|
uploadMetadata.releaseType = isDevBranch ? "beta" : "release"
|
|
|
|
uploadMetadata.gameVersions = supportedGameVersionIds
|
|
|
|
|
|
|
|
def uploadId = uploadFile(uploadMetadata, file(jar.archiveFile), apiKey, gson)
|
|
|
|
|
|
|
|
println("Uploaded with ID: ${uploadId.id}")
|
2021-05-14 01:50:33 +02:00
|
|
|
|
|
|
|
println("Published build")
|
|
|
|
|
|
|
|
} else {
|
|
|
|
println("Discord webhook unspecified")
|
2021-04-05 15:47:34 +02:00
|
|
|
}
|
|
|
|
}
|
2021-05-14 01:50:33 +02:00
|
|
|
// id = project.curse_project_id
|
|
|
|
// // TODO add code to reference this but also cut the latest change logs in for the files
|
|
|
|
// changelog = "${project.github}/blob/${sha}/CHANGELOG.md"
|
|
|
|
// changelogType = 'markdown'
|
|
|
|
// releaseType = 'release'
|
2021-04-05 15:47:34 +02:00
|
|
|
}
|
|
|
|
|
2019-06-02 05:39:08 +02:00
|
|
|
task copyPlugin {
|
|
|
|
doLast {
|
|
|
|
copy {
|
|
|
|
if(System.env.MC_SERVER_LOC == null) {
|
2020-01-22 17:30:59 +01:00
|
|
|
throw new Exception('You must set the server location and jar to use')
|
2019-06-02 05:39:08 +02:00
|
|
|
}
|
|
|
|
println "$buildDir/libs/Advanced-Portals-${version}.jar"
|
|
|
|
println "${System.env.MC_SERVER_LOC}/plugins/Advanced-Portals-${version}.jar"
|
|
|
|
try {
|
|
|
|
delete fileTree("${System.env.MC_SERVER_LOC}/plugins/") {
|
|
|
|
include "*.jar"
|
|
|
|
}
|
|
|
|
}
|
2019-12-30 15:52:00 +01:00
|
|
|
catch(RuntimeException e) {
|
2019-06-02 05:39:08 +02:00
|
|
|
println e.getLocalizedMessage()
|
|
|
|
}
|
|
|
|
from file("$buildDir/libs/Advanced-Portals-${version}.jar")
|
|
|
|
into file("${System.env.MC_SERVER_LOC}/plugins/")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-07-23 02:43:29 +02:00
|
|
|
|
|
|
|
// Set SPIGOT_LOC to the location of your server and SPIGOT_JAR as the name of the jar file in the server you want to run
|
|
|
|
// DIReallyKnowWhatIAmDoingISwear is to remove the stupid pause spigot has at the start
|
|
|
|
task runJar() {
|
|
|
|
doLast {
|
2019-06-02 05:39:08 +02:00
|
|
|
if(System.env.MC_SERVER_LOC == null || System.env.MC_SERVER_JAR == null) {
|
2020-01-22 17:30:59 +01:00
|
|
|
throw new Exception('You must set the server location and jar to use MC_SERVER_LOC and MC_SERVER_JAR')
|
2019-06-02 05:39:08 +02:00
|
|
|
}
|
2018-07-23 02:43:29 +02:00
|
|
|
javaexec {
|
|
|
|
main "-jar"
|
|
|
|
args "${System.env.MC_SERVER_LOC}\\${System.env.MC_SERVER_JAR}.jar"
|
2018-08-27 22:43:02 +02:00
|
|
|
jvmArgs = ["-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005", "-DIReallyKnowWhatIAmDoingISwear=true"]
|
2018-07-23 02:43:29 +02:00
|
|
|
workingDir "${System.env.MC_SERVER_LOC}"
|
|
|
|
}
|
|
|
|
}
|
2019-12-30 15:52:00 +01:00
|
|
|
}
|
2021-05-12 02:19:01 +02:00
|
|
|
|
2021-05-14 03:06:23 +02:00
|
|
|
/**
|
|
|
|
* These are needed as standard-version doesnt allow for the ability to skip tag versions for the changelog.
|
|
|
|
* Well it does but not on purpose and it breaks things.
|
2021-05-19 01:49:41 +02:00
|
|
|
*
|
|
|
|
* Tagging is skipped so that the release can be merged and confirmed (A little long winded but just to stop mistakes)
|
2021-05-14 03:06:23 +02:00
|
|
|
*/
|
|
|
|
task updateChangelog {
|
|
|
|
doLast{
|
|
|
|
exec {
|
2021-05-14 12:14:53 +02:00
|
|
|
commandLine 'cmd', '/c', 'npx standard-version@9.3.0 -i docs/CHANGELOG.md -t (v)[0-9]+.[0-0]+.[0-0]+(?!-) --skip.tag'
|
2021-05-14 03:06:23 +02:00
|
|
|
ext.output = {
|
|
|
|
return standardOutput.toString()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
exec {
|
2021-05-19 01:49:41 +02:00
|
|
|
commandLine 'cmd', '/c', 'npx standard-version@9.3.0 --skip.changelog --skip.bump --skip.tag'
|
2021-05-14 03:06:23 +02:00
|
|
|
ext.output = {
|
|
|
|
return standardOutput.toString()
|
|
|
|
}
|
|
|
|
}
|
2021-05-12 02:19:01 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
task updateChangelogPreRelease(type: Exec) {
|
2021-05-19 02:01:01 +02:00
|
|
|
commandLine 'cmd', '/c', 'npx standard-version@9.3.0 --prerelease -i docs/SNAPSHOT_CHANGELOG.md --skip.tag'
|
|
|
|
ext.output = {
|
|
|
|
return standardOutput.toString()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Just to stop having to manually tagging. Probably could do this easier but meh stops typos or other issues.
|
|
|
|
*/
|
|
|
|
task tagRelease(type: Exec) {
|
|
|
|
commandLine 'cmd', '/c', 'npx standard-version@9.3.0 --prerelease -i docs/SNAPSHOT_CHANGELOG.md --skip.changelog --skip.bump'
|
2021-05-12 02:19:01 +02:00
|
|
|
ext.output = {
|
|
|
|
return standardOutput.toString()
|
|
|
|
}
|
|
|
|
}
|