@@ -5,5 +5,11 @@ export namespace server {
 | 
				
			|||||||
    export interface Server {
 | 
					    export interface Server {
 | 
				
			||||||
        getVersion(): string;
 | 
					        getVersion(): string;
 | 
				
			||||||
        getPlayer(name: string): any;
 | 
					        getPlayer(name: string): any;
 | 
				
			||||||
 | 
					        getOnlinePlayers(): any[];
 | 
				
			||||||
 | 
					        getConsoleSender(): any;
 | 
				
			||||||
 | 
					        getService(service: string): any;
 | 
				
			||||||
 | 
					        dispatchCommand(sender: string | any, command: string): boolean;
 | 
				
			||||||
 | 
					        dispatchConsoleCommand(command: string): boolean;
 | 
				
			||||||
 | 
					        sendJson(sender: string | any, json: object | string): void;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										80
									
								
								packages/bukkit/src/enhance/chat.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										80
									
								
								packages/bukkit/src/enhance/chat.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,80 @@
 | 
				
			|||||||
 | 
					/*global Java, base, module, exports, require*/
 | 
				
			||||||
 | 
					var nmsChatSerializerClass;
 | 
				
			||||||
 | 
					var nmsChatSerializerMethod;
 | 
				
			||||||
 | 
					var packetTypeConstructor;
 | 
				
			||||||
 | 
					var nmsChatMessageTypeClass;
 | 
				
			||||||
 | 
					var chatMessageTypes;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					var downgrade = false;
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * 获取NMS版本
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					//@ts-ignore
 | 
				
			||||||
 | 
					var nmsVersion = org.bukkit.Bukkit.server.class.name.split('.')[3];
 | 
				
			||||||
 | 
					/**
 | 
				
			||||||
 | 
					 * 获取NMS类
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					function nmsCls(name) {
 | 
				
			||||||
 | 
					    return base.getClass(['net.minecraft.server', nmsVersion, name].join('.'))
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function init() {
 | 
				
			||||||
 | 
					    nmsChatSerializerClass = nmsCls(nmsVersion.split("_")[1] > 7 ? "IChatBaseComponent$ChatSerializer" : "ChatSerializer");
 | 
				
			||||||
 | 
					    try {
 | 
				
			||||||
 | 
					        nmsChatSerializerMethod = nmsChatSerializerClass.getMethod('a', base.getClass('java.lang.String'))
 | 
				
			||||||
 | 
					    } catch (ex) {
 | 
				
			||||||
 | 
					        nmsChatSerializerMethod = nmsChatSerializerClass.getMethod('func_150699_a', base.getClass('java.lang.String'))
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    var packetTypeClass = nmsCls("PacketPlayOutChat");
 | 
				
			||||||
 | 
					    Java.from(packetTypeClass.constructors).forEach(function(c) {
 | 
				
			||||||
 | 
					        if (c.parameterTypes.length === 2) {
 | 
				
			||||||
 | 
					            packetTypeConstructor = c
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
 | 
					    nmsChatMessageTypeClass = packetTypeConstructor.parameterTypes[1];
 | 
				
			||||||
 | 
					    if (nmsChatMessageTypeClass.isEnum()) {
 | 
				
			||||||
 | 
					        chatMessageTypes = nmsChatMessageTypeClass.getEnumConstants();
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        switch (nmsChatMessageTypeClass.name) {
 | 
				
			||||||
 | 
					            case "int":
 | 
				
			||||||
 | 
					                //@ts-ignore
 | 
				
			||||||
 | 
					                nmsChatMessageTypeClass = java.lang.Integer;
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					            case "byte":
 | 
				
			||||||
 | 
					                //@ts-ignore
 | 
				
			||||||
 | 
					                nmsChatMessageTypeClass = java.lang.Byte;
 | 
				
			||||||
 | 
					                break;
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function json(sender, json) {
 | 
				
			||||||
 | 
					    if (downgrade) {
 | 
				
			||||||
 | 
					        return '/tellraw ' + sender.name + ' ' + json
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					        send(sender, json, 0);
 | 
				
			||||||
 | 
					        return false;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function send(sender, json, type) {
 | 
				
			||||||
 | 
					    //@ts-ignore
 | 
				
			||||||
 | 
					    sendPacket(sender, packetTypeConstructor.newInstance(nmsChatSerializerMethod.invoke(null, json), chatMessageTypes == null ? nmsChatMessageTypeClass.valueOf(java.lang.String.valueOf(type)) : chatMessageTypes[type]))
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function sendPacket(player, p) {
 | 
				
			||||||
 | 
					    player.handle.playerConnection.sendPacket(p);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					try {
 | 
				
			||||||
 | 
					    init();
 | 
				
			||||||
 | 
					} catch (ex) {
 | 
				
			||||||
 | 
					    org.bukkit.Bukkit.getConsoleSender().sendMessage(`§6[§cMS§6][§bbukkit§6][§achat§6] §cNMS Inject Error §4${ex} §cDowngrade to Command Mode...`)
 | 
				
			||||||
 | 
					    downgrade = true;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					let chat = {
 | 
				
			||||||
 | 
					    json
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					export default chat
 | 
				
			||||||
@@ -5,6 +5,7 @@ import { DefaultContainer as container } from '@ms/container'
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import { BukkitConsole } from './console';
 | 
					import { BukkitConsole } from './console';
 | 
				
			||||||
import { BukkitEvent } from './event';
 | 
					import { BukkitEvent } from './event';
 | 
				
			||||||
 | 
					import { BukkitServer } from './server';
 | 
				
			||||||
import { BukkitCommand } from './command';
 | 
					import { BukkitCommand } from './command';
 | 
				
			||||||
import { BukkitTaskManager } from './task';
 | 
					import { BukkitTaskManager } from './task';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -16,7 +17,6 @@ container.bind(server.ServerType).toConstantValue(BukkitServerType);
 | 
				
			|||||||
container.bind(plugin.PluginInstance).toConstantValue(Bukkit.pluginManager.getPlugin('MiaoScript'));
 | 
					container.bind(plugin.PluginInstance).toConstantValue(Bukkit.pluginManager.getPlugin('MiaoScript'));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
container.bind(event.Event).to(BukkitEvent).inSingletonScope();
 | 
					container.bind(event.Event).to(BukkitEvent).inSingletonScope();
 | 
				
			||||||
 | 
					container.bind(server.Server).to(BukkitServer).inSingletonScope();
 | 
				
			||||||
container.bind(command.Command).to(BukkitCommand).inSingletonScope();
 | 
					container.bind(command.Command).to(BukkitCommand).inSingletonScope();
 | 
				
			||||||
container.bind(task.TaskManager).to(BukkitTaskManager).inSingletonScope();
 | 
					container.bind(task.TaskManager).to(BukkitTaskManager).inSingletonScope();
 | 
				
			||||||
 | 
					 | 
				
			||||||
console.debug(`Detect Bukkit Compatible set ServerType to ${BukkitServerType} ...`)
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										43
									
								
								packages/bukkit/src/server.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								packages/bukkit/src/server.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,43 @@
 | 
				
			|||||||
 | 
					import { server } from '@ms/api'
 | 
				
			||||||
 | 
					import { injectable } from '@ms/container';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					import chat from './enhance/chat'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					let Bukkit = org.bukkit.Bukkit;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@injectable()
 | 
				
			||||||
 | 
					export class BukkitServer implements server.Server {
 | 
				
			||||||
 | 
					    getPlayer(name: string) {
 | 
				
			||||||
 | 
					        return Bukkit.getPlayer(name)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getVersion(): string {
 | 
				
			||||||
 | 
					        return Bukkit.getVersion()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getOnlinePlayers() {
 | 
				
			||||||
 | 
					        return Bukkit.getOnlinePlayers() as unknown as any[]
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getConsoleSender() {
 | 
				
			||||||
 | 
					        return Bukkit.getConsoleSender()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getService(service: string) {
 | 
				
			||||||
 | 
					        return Bukkit.getServicesManager().getRegistration(base.getClass(service))?.getProvider()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    dispatchCommand(sender: string | any, command: string): boolean {
 | 
				
			||||||
 | 
					        if (typeof sender === 'string') {
 | 
				
			||||||
 | 
					            sender = this.getPlayer(sender)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return Bukkit.dispatchCommand(sender, command)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    dispatchConsoleCommand(command: string): boolean {
 | 
				
			||||||
 | 
					        return Bukkit.dispatchCommand(Bukkit.getConsoleSender(), command)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    sendJson(sender: string | any, json: object | string): void {
 | 
				
			||||||
 | 
					        if (typeof sender === "string") {
 | 
				
			||||||
 | 
					            sender = this.getPlayer(sender)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        let result = chat.json(sender, json)
 | 
				
			||||||
 | 
					        if (result !== false) {
 | 
				
			||||||
 | 
					            this.dispatchConsoleCommand(result)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@@ -5,6 +5,7 @@ import { DefaultContainer as container } from '@ms/container'
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import { SpongeConsole } from './console';
 | 
					import { SpongeConsole } from './console';
 | 
				
			||||||
import { SpongeEvent } from './event';
 | 
					import { SpongeEvent } from './event';
 | 
				
			||||||
 | 
					import { SpongeServer } from './server';
 | 
				
			||||||
import { SpongeCommand } from './command';
 | 
					import { SpongeCommand } from './command';
 | 
				
			||||||
import { SpongeTaskManager } from './task';
 | 
					import { SpongeTaskManager } from './task';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -16,7 +17,6 @@ container.bind(server.ServerType).toConstantValue(SpongeServerType);
 | 
				
			|||||||
container.bind(plugin.PluginInstance).toConstantValue(Sponge.getPluginManager().getPlugin('MiaoScript').orElse(null));
 | 
					container.bind(plugin.PluginInstance).toConstantValue(Sponge.getPluginManager().getPlugin('MiaoScript').orElse(null));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
container.bind(event.Event).to(SpongeEvent).inSingletonScope();
 | 
					container.bind(event.Event).to(SpongeEvent).inSingletonScope();
 | 
				
			||||||
 | 
					container.bind(server.Server).to(SpongeServer).inSingletonScope();
 | 
				
			||||||
container.bind(command.Command).to(SpongeCommand).inSingletonScope();
 | 
					container.bind(command.Command).to(SpongeCommand).inSingletonScope();
 | 
				
			||||||
container.bind(task.TaskManager).to(SpongeTaskManager).inSingletonScope();
 | 
					container.bind(task.TaskManager).to(SpongeTaskManager).inSingletonScope();
 | 
				
			||||||
 | 
					 | 
				
			||||||
console.debug(`Detect Sponge Compatible set ServerType to ${SpongeServerType} ...`)
 | 
					 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										39
									
								
								packages/sponge/src/server.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								packages/sponge/src/server.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					import { server } from '@ms/api'
 | 
				
			||||||
 | 
					import { injectable } from '@ms/container';
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					let Sponge = org.spongepowered.api.Sponge;
 | 
				
			||||||
 | 
					let TextSerializers = org.spongepowered.api.text.serializer.TextSerializers;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					@injectable()
 | 
				
			||||||
 | 
					export class SpongeServer implements server.Server {
 | 
				
			||||||
 | 
					    getPlayer(name: string) {
 | 
				
			||||||
 | 
					        return Sponge.getServer().getPlayer(name).orElse(null)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getVersion(): string {
 | 
				
			||||||
 | 
					        return `${Sponge.getPlatform().getImplementation().getName()} (${Sponge.getPlatform().getImplementation().getVersion()})`
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getOnlinePlayers() {
 | 
				
			||||||
 | 
					        return Sponge.getServer().getOnlinePlayers()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getConsoleSender() {
 | 
				
			||||||
 | 
					        return Sponge.getServer().getConsole()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    getService(service: string) {
 | 
				
			||||||
 | 
					        return Sponge.getServiceManager().provide(base.getClass(service)).orElse(null)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    dispatchCommand(sender: string | any, command: string): boolean {
 | 
				
			||||||
 | 
					        if (typeof sender === 'string') {
 | 
				
			||||||
 | 
					            sender = this.getPlayer(sender)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        return Sponge.getCommandManager().process(sender, command).getQueryResult()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    dispatchConsoleCommand(command: string): boolean {
 | 
				
			||||||
 | 
					        return Sponge.getCommandManager().process(Sponge.getServer().getConsole(), command).getQueryResult()
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					    sendJson(sender: string | any, json: string): void {
 | 
				
			||||||
 | 
					        if (typeof sender === "string") {
 | 
				
			||||||
 | 
					            sender = this.getPlayer(sender)
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					        sender.sendMessage(TextSerializers.JSON.deserialize(json))
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
		Reference in New Issue
	
	Block a user