mirror of
https://e.coding.net/circlecloud/Yum.git
synced 2025-09-02 04:46:55 +00:00
@ -15,16 +15,16 @@ import java.util.Map.Entry;
|
||||
import org.bukkit.command.CommandSender;
|
||||
import org.bukkit.configuration.file.FileConfiguration;
|
||||
|
||||
import cn.citycraft.Yum.repository.Package;
|
||||
import cn.citycraft.Yum.repository.Plugin;
|
||||
import cn.citycraft.Yum.repository.PluginInfo;
|
||||
import cn.citycraft.Yum.repository.Repository;
|
||||
|
||||
import com.google.common.base.Charsets;
|
||||
import com.google.gson.Gson;
|
||||
import com.google.gson.JsonSyntaxException;
|
||||
import com.google.gson.reflect.TypeToken;
|
||||
|
||||
import cn.citycraft.Yum.repository.Package;
|
||||
import cn.citycraft.Yum.repository.Plugin;
|
||||
import cn.citycraft.Yum.repository.PluginInfo;
|
||||
import cn.citycraft.Yum.repository.Repository;
|
||||
|
||||
/**
|
||||
* 仓库管理类
|
||||
*
|
||||
@ -44,18 +44,22 @@ public class RepositoryManager {
|
||||
repos = new ArrayList<String>();
|
||||
}
|
||||
|
||||
public void clean() {
|
||||
plugins.clear();
|
||||
public boolean addPackage(String urlstring) {
|
||||
String json = getHtml(urlstring);
|
||||
if (json == "")
|
||||
return false;
|
||||
Package pkg = jsonToPackage(json);
|
||||
if (pkg == null)
|
||||
return false;
|
||||
updatePackage(pkg);
|
||||
return true;
|
||||
}
|
||||
|
||||
public void updatePackage(Package pkg) {
|
||||
for (Plugin plugin : pkg.plugins) {
|
||||
PluginInfo pi = new PluginInfo();
|
||||
pi.plugin = plugin;
|
||||
pi.url = pkg.url;
|
||||
pi.repo = pkg.name;
|
||||
plugins.put(plugin.groupId + "." + plugin.artifactId, pi);
|
||||
}
|
||||
public boolean addRepositories(String urlstring) {
|
||||
if (urlstring == null || urlstring.isEmpty())
|
||||
return false;
|
||||
repos.add(urlstring);
|
||||
return updateRepositories(urlstring);
|
||||
}
|
||||
|
||||
public void cacheToJson(FileConfiguration config) {
|
||||
@ -63,6 +67,66 @@ public class RepositoryManager {
|
||||
config.set("plugincache", gson.toJson(plugins));
|
||||
}
|
||||
|
||||
public void clean() {
|
||||
plugins.clear();
|
||||
}
|
||||
|
||||
public List<PluginInfo> getAllPlugin() {
|
||||
List<PluginInfo> li = new ArrayList<PluginInfo>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet())
|
||||
li.add(plugin.getValue());
|
||||
return li;
|
||||
}
|
||||
|
||||
public List<String> getAllPluginName() {
|
||||
List<String> li = new ArrayList<String>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet())
|
||||
li.add(plugin.getValue().plugin.artifactId);
|
||||
return li;
|
||||
}
|
||||
|
||||
public List<String> getAllPluginsInfo() {
|
||||
List<String> li = new ArrayList<String>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet()) {
|
||||
Plugin pl = plugin.getValue().plugin;
|
||||
li.add(String.format("§d%s §a%s(%s) §6- §e%s", plugin.getValue().repo, pl.artifactId, pl.version, pl.description));
|
||||
}
|
||||
return li;
|
||||
}
|
||||
|
||||
public String getHtml(String urlstring) {
|
||||
String html = "";
|
||||
try {
|
||||
URL url = new URL(urlstring);
|
||||
BufferedReader br = new BufferedReader(new InputStreamReader(url.openStream(), Charsets.UTF_8));
|
||||
String line;
|
||||
while ((line = br.readLine()) != null)
|
||||
html += line;
|
||||
return html;
|
||||
} catch (IOException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public PluginInfo getPlugin(String name) {
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet())
|
||||
if (plugin.getValue().plugin.artifactId.equalsIgnoreCase(name))
|
||||
return plugin.getValue();
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<PluginInfo> getPluginInfo(String name) {
|
||||
List<PluginInfo> li = new ArrayList<PluginInfo>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet())
|
||||
if (plugin.getValue().plugin.artifactId.equalsIgnoreCase(name))
|
||||
li.add(plugin.getValue());
|
||||
return li;
|
||||
}
|
||||
|
||||
public PluginInfo getPluginInfo(String groupId, String artifactId) {
|
||||
return plugins.get(groupId + "." + artifactId);
|
||||
}
|
||||
|
||||
public boolean jsonToCache(FileConfiguration config) {
|
||||
String repocache = config.getString("repocache");
|
||||
String plugincache = config.getString("plugincache");
|
||||
@ -79,112 +143,14 @@ public class RepositoryManager {
|
||||
}
|
||||
}
|
||||
|
||||
public boolean updateRepositories(CommandSender sender) {
|
||||
plugins.clear();
|
||||
for (String string : repos) {
|
||||
if (updateRepositories(string)) {
|
||||
sender.sendMessage("§6源: §e" + string + " §a更新成功!");
|
||||
} else {
|
||||
sender.sendMessage("§6源: §e" + string + " §c更新失败!");
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public boolean addRepositories(String urlstring) {
|
||||
repos.add(urlstring);
|
||||
return updateRepositories(urlstring);
|
||||
}
|
||||
|
||||
public boolean updateRepositories(String urlstring) {
|
||||
String json = getHtml(urlstring);
|
||||
if (json == "") {
|
||||
return false;
|
||||
}
|
||||
List<Repository> lrepo = jsonToRepositories(json);
|
||||
if (lrepo == null) {
|
||||
return false;
|
||||
}
|
||||
for (Repository repository : lrepo) {
|
||||
addPackage(repository.url);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
public boolean addPackage(String urlstring) {
|
||||
String json = getHtml(urlstring);
|
||||
if (json == "") {
|
||||
return false;
|
||||
}
|
||||
Package pkg = jsonToPackage(json);
|
||||
if (pkg == null) {
|
||||
return false;
|
||||
}
|
||||
updatePackage(pkg);
|
||||
return true;
|
||||
}
|
||||
|
||||
public String getHtml(String urlstring) {
|
||||
String html = "";
|
||||
public Package jsonToPackage(String json) {
|
||||
try {
|
||||
URL url = new URL(urlstring);
|
||||
BufferedReader br = new BufferedReader(new InputStreamReader(url.openStream(), Charsets.UTF_8));
|
||||
String line;
|
||||
while ((line = br.readLine()) != null) {
|
||||
html += line;
|
||||
}
|
||||
return html;
|
||||
} catch (IOException e) {
|
||||
return gson.fromJson(json, Package.class);
|
||||
} catch (JsonSyntaxException e) {
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
public PluginInfo getPluginInfo(String groupId, String artifactId) {
|
||||
return plugins.get(groupId + "." + artifactId);
|
||||
}
|
||||
|
||||
public PluginInfo getPlugin(String name) {
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet()) {
|
||||
if (plugin.getValue().plugin.artifactId.equalsIgnoreCase(name))
|
||||
return plugin.getValue();
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public List<PluginInfo> getAllPlugin() {
|
||||
List<PluginInfo> li = new ArrayList<PluginInfo>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet()) {
|
||||
li.add(plugin.getValue());
|
||||
}
|
||||
return li;
|
||||
}
|
||||
|
||||
public List<String> getAllPluginName() {
|
||||
List<String> li = new ArrayList<String>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet()) {
|
||||
li.add(plugin.getValue().plugin.artifactId);
|
||||
}
|
||||
return li;
|
||||
}
|
||||
|
||||
public List<String> getAllPluginsInfo() {
|
||||
List<String> li = new ArrayList<String>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet()) {
|
||||
Plugin pl = plugin.getValue().plugin;
|
||||
li.add(String.format("§d%s §a%s(%s) §6- §e%s", plugin.getValue().repo, pl.artifactId, pl.version, pl.description));
|
||||
}
|
||||
return li;
|
||||
}
|
||||
|
||||
public List<PluginInfo> getPluginInfo(String name) {
|
||||
List<PluginInfo> li = new ArrayList<PluginInfo>();
|
||||
for (Entry<String, PluginInfo> plugin : plugins.entrySet()) {
|
||||
if (plugin.getValue().plugin.artifactId.equalsIgnoreCase(name))
|
||||
li.add(plugin.getValue());
|
||||
}
|
||||
return li;
|
||||
}
|
||||
|
||||
public List<Repository> jsonToRepositories(String json) {
|
||||
try {
|
||||
return gson.fromJson(json, new TypeToken<List<Repository>>() {
|
||||
@ -194,11 +160,37 @@ public class RepositoryManager {
|
||||
}
|
||||
}
|
||||
|
||||
public Package jsonToPackage(String json) {
|
||||
try {
|
||||
return gson.fromJson(json, Package.class);
|
||||
} catch (JsonSyntaxException e) {
|
||||
return null;
|
||||
public void updatePackage(Package pkg) {
|
||||
for (Plugin plugin : pkg.plugins) {
|
||||
PluginInfo pi = new PluginInfo();
|
||||
pi.plugin = plugin;
|
||||
pi.url = pkg.url;
|
||||
pi.repo = pkg.name;
|
||||
plugins.put(plugin.groupId + "." + plugin.artifactId, pi);
|
||||
}
|
||||
}
|
||||
|
||||
public boolean updateRepositories(CommandSender sender) {
|
||||
plugins.clear();
|
||||
for (String string : repos)
|
||||
if (updateRepositories(string))
|
||||
sender.sendMessage("§6源: §e" + string + " §a更新成功!");
|
||||
else
|
||||
sender.sendMessage("§6源: §e" + string + " §c更新失败!");
|
||||
return true;
|
||||
}
|
||||
|
||||
public boolean updateRepositories(String urlstring) {
|
||||
if (!urlstring.endsWith("repo.info"))
|
||||
urlstring = urlstring + "/repo.info";
|
||||
String json = getHtml(urlstring);
|
||||
if (json == "")
|
||||
return false;
|
||||
List<Repository> lrepo = jsonToRepositories(json);
|
||||
if (lrepo == null)
|
||||
return false;
|
||||
for (Repository repository : lrepo)
|
||||
addPackage(repository.url);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user