🎉 Initial Commit
This commit is contained in:
119
.gitignore
vendored
Normal file
119
.gitignore
vendored
Normal file
@@ -0,0 +1,119 @@
|
||||
# User-specific stuff
|
||||
.idea/
|
||||
|
||||
*.iml
|
||||
*.ipr
|
||||
*.iws
|
||||
|
||||
# IntelliJ
|
||||
out/
|
||||
# mpeltonen/sbt-idea plugin
|
||||
.idea_modules/
|
||||
|
||||
# JIRA plugin
|
||||
atlassian-ide-plugin.xml
|
||||
|
||||
# Compiled class file
|
||||
*.class
|
||||
|
||||
# Log file
|
||||
*.log
|
||||
|
||||
# BlueJ files
|
||||
*.ctxt
|
||||
|
||||
# Package Files #
|
||||
*.jar
|
||||
*.war
|
||||
*.nar
|
||||
*.ear
|
||||
*.zip
|
||||
*.tar.gz
|
||||
*.rar
|
||||
|
||||
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
|
||||
hs_err_pid*
|
||||
|
||||
*~
|
||||
|
||||
# temporary files which can be created if a process still has a handle open of a deleted file
|
||||
.fuse_hidden*
|
||||
|
||||
# KDE directory preferences
|
||||
.directory
|
||||
|
||||
# Linux trash folder which might appear on any partition or disk
|
||||
.Trash-*
|
||||
|
||||
# .nfs files are created when an open file is removed but is still being accessed
|
||||
.nfs*
|
||||
|
||||
# General
|
||||
.DS_Store
|
||||
.AppleDouble
|
||||
.LSOverride
|
||||
|
||||
# Icon must end with two \r
|
||||
Icon
|
||||
|
||||
# Thumbnails
|
||||
._*
|
||||
|
||||
# Files that might appear in the root of a volume
|
||||
.DocumentRevisions-V100
|
||||
.fseventsd
|
||||
.Spotlight-V100
|
||||
.TemporaryItems
|
||||
.Trashes
|
||||
.VolumeIcon.icns
|
||||
.com.apple.timemachine.donotpresent
|
||||
|
||||
# Directories potentially created on remote AFP share
|
||||
.AppleDB
|
||||
.AppleDesktop
|
||||
Network Trash Folder
|
||||
Temporary Items
|
||||
.apdisk
|
||||
|
||||
# Windows thumbnail cache files
|
||||
Thumbs.db
|
||||
Thumbs.db:encryptable
|
||||
ehthumbs.db
|
||||
ehthumbs_vista.db
|
||||
|
||||
# Dump file
|
||||
*.stackdump
|
||||
|
||||
# Folder config file
|
||||
[Dd]esktop.ini
|
||||
|
||||
# Recycle Bin used on file shares
|
||||
$RECYCLE.BIN/
|
||||
|
||||
# Windows Installer files
|
||||
*.cab
|
||||
*.msi
|
||||
*.msix
|
||||
*.msm
|
||||
*.msp
|
||||
|
||||
# Windows shortcuts
|
||||
*.lnk
|
||||
|
||||
.gradle
|
||||
build/
|
||||
|
||||
# Ignore Gradle GUI config
|
||||
gradle-app.setting
|
||||
|
||||
# Cache of project
|
||||
.gradletasknamecache
|
||||
|
||||
**/build/
|
||||
|
||||
# Common working directory
|
||||
run/
|
||||
runs/
|
||||
|
||||
# Avoid ignoring Gradle wrapper jar file (.jar files are usually ignored)
|
||||
!gradle-wrapper.jar
|
48
build.gradle.kts
Normal file
48
build.gradle.kts
Normal file
@@ -0,0 +1,48 @@
|
||||
plugins {
|
||||
kotlin("jvm") version "2.1.20-Beta2"
|
||||
kotlin("plugin.serialization") version "2.1.10"
|
||||
id("com.github.johnrengelman.shadow") version "8.1.1"
|
||||
}
|
||||
|
||||
group = "dev.solsynth"
|
||||
version = "1.0-SNAPSHOT"
|
||||
|
||||
repositories {
|
||||
mavenCentral()
|
||||
maven("https://hub.spigotmc.org/nexus/content/repositories/snapshots/") {
|
||||
name = "spigotmc-repo"
|
||||
}
|
||||
maven("https://oss.sonatype.org/content/groups/public/") {
|
||||
name = "sonatype"
|
||||
}
|
||||
maven("https://jitpack.io") {
|
||||
name = "jitpack"
|
||||
}
|
||||
}
|
||||
|
||||
dependencies {
|
||||
compileOnly("org.spigotmc:spigot-api:1.21.4-R0.1-SNAPSHOT")
|
||||
compileOnly("com.github.MilkBowl:VaultAPI:1.7")
|
||||
implementation("org.jetbrains.kotlinx:kotlinx-datetime:0.6.1")
|
||||
implementation("org.jetbrains.kotlinx:kotlinx-serialization-json:1.8.0")
|
||||
implementation("com.squareup.okhttp3:okhttp:4.12.0")
|
||||
implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
|
||||
}
|
||||
|
||||
val targetJavaVersion = 21
|
||||
kotlin {
|
||||
jvmToolchain(targetJavaVersion)
|
||||
}
|
||||
|
||||
tasks.build {
|
||||
dependsOn("shadowJar")
|
||||
}
|
||||
|
||||
tasks.processResources {
|
||||
val props = mapOf("version" to version)
|
||||
inputs.properties(props)
|
||||
filteringCharset = "UTF-8"
|
||||
filesMatching("plugin.yml") {
|
||||
expand(props)
|
||||
}
|
||||
}
|
0
gradle.properties
Normal file
0
gradle.properties
Normal file
1
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
1
gradle/wrapper/gradle-wrapper.properties
vendored
Normal file
@@ -0,0 +1 @@
|
||||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.8-bin.zip
|
1
settings.gradle.kts
Normal file
1
settings.gradle.kts
Normal file
@@ -0,0 +1 @@
|
||||
rootProject.name = "SolarNetworkConnect"
|
@@ -0,0 +1,64 @@
|
||||
package dev.solsynth.snConnect
|
||||
|
||||
import dev.solsynth.snConnect.commands.SnCommand
|
||||
import dev.solsynth.snConnect.commands.SnCommandCompleter
|
||||
import dev.solsynth.snConnect.services.SnService
|
||||
import net.milkbowl.vault.economy.Economy
|
||||
import org.bukkit.Bukkit
|
||||
import org.bukkit.plugin.java.JavaPlugin
|
||||
|
||||
|
||||
class SolarNetworkConnect : JavaPlugin() {
|
||||
private var economy: Economy? = null
|
||||
private var sn: SnService? = null
|
||||
|
||||
override fun onEnable() {
|
||||
logger.info(String.format("Enabling Version %s", description.version));
|
||||
|
||||
this.saveDefaultConfig()
|
||||
|
||||
if (!setupNetwork()) {
|
||||
logger.severe("Failed to setup Solar Network Network, check your configuration.")
|
||||
}
|
||||
if (!setupEconomy()) {
|
||||
logger.warning(
|
||||
"Failed to load vault, economy related features will not available."
|
||||
)
|
||||
}
|
||||
|
||||
Bukkit.getPluginCommand("solar")!!.setExecutor(SnCommand(this.sn!!))
|
||||
Bukkit.getPluginCommand("solar")!!.tabCompleter = SnCommandCompleter()
|
||||
|
||||
logger.info(
|
||||
String.format(
|
||||
"Successfully loaded Solar Network Connect connected with %s",
|
||||
config.getString("sn.endpoint")
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
override fun onDisable() {
|
||||
logger.info(String.format("Disabled Version %s", description.version));
|
||||
}
|
||||
|
||||
private fun setupNetwork(): Boolean {
|
||||
val baseUrl = config.getString("sn.endpoint") ?: return false;
|
||||
val clientId = config.getString("sn.client_id") ?: return false;
|
||||
val clientSecret = config.getString("sn.client_secret") ?: return false;
|
||||
sn = SnService(baseUrl, clientId, clientSecret);
|
||||
return true;
|
||||
}
|
||||
|
||||
private fun setupEconomy(): Boolean {
|
||||
if (server.pluginManager.getPlugin("Vault") == null) {
|
||||
logger.warning(
|
||||
"No Vault dependency found!"
|
||||
);
|
||||
return false
|
||||
}
|
||||
val rsp = server.servicesManager.getRegistration(Economy::class.java) ?: return false
|
||||
economy = rsp.provider
|
||||
@Suppress("KotlinConstantConditions")
|
||||
return economy != null
|
||||
}
|
||||
}
|
63
src/main/kotlin/dev/solsynth/snConnect/commands/SnCommand.kt
Normal file
63
src/main/kotlin/dev/solsynth/snConnect/commands/SnCommand.kt
Normal file
@@ -0,0 +1,63 @@
|
||||
package dev.solsynth.snConnect.commands
|
||||
|
||||
import dev.solsynth.snConnect.services.SnOrderService
|
||||
import dev.solsynth.snConnect.services.SnService
|
||||
import net.md_5.bungee.api.chat.ClickEvent
|
||||
import net.md_5.bungee.api.chat.TextComponent
|
||||
import org.bukkit.ChatColor
|
||||
import org.bukkit.command.Command
|
||||
import org.bukkit.command.CommandExecutor
|
||||
import org.bukkit.command.CommandSender
|
||||
import org.bukkit.command.TabCompleter
|
||||
import org.bukkit.entity.Player
|
||||
|
||||
class SnCommand(private val sn: SnService) : CommandExecutor {
|
||||
override fun onCommand(p0: CommandSender, p1: Command, p2: String, p3: Array<out String>): Boolean {
|
||||
if (p0 !is Player) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (p3.isEmpty()) return false;
|
||||
|
||||
when (p3[0].lowercase()) {
|
||||
"deposit" -> {
|
||||
if (p3.size < 2) {
|
||||
p0.sendMessage(ChatColor.RED.toString() + "You need to specific an amount to deposit.")
|
||||
return true;
|
||||
}
|
||||
|
||||
val amount = p3[1].toDoubleOrNull();
|
||||
if (amount == null) {
|
||||
p0.sendMessage(ChatColor.RED.toString() + "You need to specific an amount of number to deposit.")
|
||||
return true;
|
||||
}
|
||||
|
||||
val orderSrv = SnOrderService(sn);
|
||||
val order = orderSrv.createOrder("Deposit to Highland MC", amount / 100);
|
||||
|
||||
val linkComponent = TextComponent(ChatColor.GOLD.toString() + "Click here to payment page")
|
||||
linkComponent.clickEvent =
|
||||
ClickEvent(ClickEvent.Action.OPEN_URL, "https://solsynth.dev/orders/${order.id}");
|
||||
p0.spigot().sendMessage(linkComponent);
|
||||
}
|
||||
|
||||
else -> return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
class SnCommandCompleter : TabCompleter {
|
||||
override fun onTabComplete(
|
||||
p0: CommandSender,
|
||||
p1: Command,
|
||||
p2: String,
|
||||
p3: Array<out String>
|
||||
): MutableList<String> {
|
||||
return when (p3.size) {
|
||||
1 -> mutableListOf("deposit", "withdraw");
|
||||
else -> mutableListOf();
|
||||
}
|
||||
}
|
||||
}
|
@@ -0,0 +1,69 @@
|
||||
package dev.solsynth.snConnect.services
|
||||
|
||||
import kotlinx.datetime.Instant
|
||||
import kotlinx.serialization.SerialName
|
||||
import kotlinx.serialization.Serializable
|
||||
import kotlinx.serialization.json.Json
|
||||
import okhttp3.MediaType.Companion.toMediaTypeOrNull
|
||||
import okhttp3.Request
|
||||
import okhttp3.RequestBody.Companion.toRequestBody
|
||||
import java.io.IOException
|
||||
|
||||
@Serializable
|
||||
class SnOrderRequest(
|
||||
@SerialName("client_id")
|
||||
val clientId: String,
|
||||
@SerialName("client_secret")
|
||||
val clientSecret: String,
|
||||
val remark: String,
|
||||
val amount: Double
|
||||
)
|
||||
|
||||
@Serializable
|
||||
data class SnOrder(
|
||||
val id: Long,
|
||||
@SerialName("created_at")
|
||||
val createdAt: Instant,
|
||||
@SerialName("updated_at")
|
||||
val updatedAt: Instant,
|
||||
@SerialName("deleted_at")
|
||||
val deletedAt: Instant? = null,
|
||||
val status: Long,
|
||||
val remark: String,
|
||||
val amount: String,
|
||||
@SerialName("payer_id")
|
||||
val payerID: Int? = null,
|
||||
@SerialName("payee_id")
|
||||
val payeeID: Int? = null,
|
||||
@SerialName("transaction_id")
|
||||
val transactionID: Int? = null,
|
||||
@SerialName("client_id")
|
||||
val clientID: Long
|
||||
)
|
||||
|
||||
class SnOrderService(private val sn: SnService) {
|
||||
private val json = Json {
|
||||
ignoreUnknownKeys = true
|
||||
}
|
||||
|
||||
fun createOrder(remark: String, amount: Double): SnOrder {
|
||||
val body = SnOrderRequest(
|
||||
sn.clientId,
|
||||
sn.clientSecret,
|
||||
remark,
|
||||
amount,
|
||||
);
|
||||
val request = Request.Builder()
|
||||
.url(sn.getUrl("wa", "/orders"))
|
||||
.post(Json.encodeToString(body).toRequestBody("application/json".toMediaTypeOrNull()))
|
||||
.build()
|
||||
|
||||
sn.client.newCall(request).execute().use { response ->
|
||||
if (!response.isSuccessful) throw IOException("Unexpected code $response")
|
||||
val responseBody = response.body!!.string()
|
||||
val out = json.decodeFromString<SnOrder>(responseBody)
|
||||
|
||||
return out
|
||||
}
|
||||
}
|
||||
}
|
11
src/main/kotlin/dev/solsynth/snConnect/services/SnService.kt
Normal file
11
src/main/kotlin/dev/solsynth/snConnect/services/SnService.kt
Normal file
@@ -0,0 +1,11 @@
|
||||
package dev.solsynth.snConnect.services
|
||||
|
||||
import okhttp3.OkHttpClient
|
||||
|
||||
class SnService(private val baseUrl: String, val clientId: String, val clientSecret: String) {
|
||||
val client = OkHttpClient.Builder().build();
|
||||
|
||||
fun getUrl(service: String, segment: String): String {
|
||||
return "$baseUrl/cgi/$service$segment"
|
||||
}
|
||||
}
|
4
src/main/resources/config.yml
Normal file
4
src/main/resources/config.yml
Normal file
@@ -0,0 +1,4 @@
|
||||
sn:
|
||||
endpoint: https://api.sn.solsynth.dev
|
||||
client_id: highland-mc
|
||||
client_secret: 12345678
|
23
src/main/resources/plugin.yml
Normal file
23
src/main/resources/plugin.yml
Normal file
@@ -0,0 +1,23 @@
|
||||
name: SolarNetworkConnect
|
||||
version: '1.0-SNAPSHOT'
|
||||
main: dev.solsynth.snConnect.SolarNetworkConnect
|
||||
api-version: '1.21'
|
||||
authors: [ LittleSheepOvO ]
|
||||
description: Solar Network Connect provide features connect with Solar Network
|
||||
loadbefore:
|
||||
- CMI
|
||||
- CMIEInjector
|
||||
- CMILib
|
||||
depend:
|
||||
- Vault
|
||||
commands:
|
||||
solar:
|
||||
description: Solar Network Related Command
|
||||
usage: §e/solar §r<deposit/withdraw>
|
||||
aliases: ['sn']
|
||||
permission: solar-network.command.sn
|
||||
permission-message: §cYou don't have the permission -> §6[solar-network.command.sn]
|
||||
permissions:
|
||||
solar-network.command.sn:
|
||||
description: Permission of uses Solar Network Command
|
||||
default: true
|
Reference in New Issue
Block a user