2020-06-24 02:04:22 +00:00
|
|
|
package com.thebrokenrail.modupdater.strategy;
|
|
|
|
|
|
|
|
import com.thebrokenrail.modupdater.ModUpdater;
|
|
|
|
import com.thebrokenrail.modupdater.util.ConfigObject;
|
|
|
|
import com.thebrokenrail.modupdater.util.HardcodedData;
|
|
|
|
import com.thebrokenrail.modupdater.util.ModUpdate;
|
|
|
|
import com.thebrokenrail.modupdater.util.ModUpdateStrategy;
|
|
|
|
import net.fabricmc.loader.api.FabricLoader;
|
|
|
|
import net.fabricmc.loader.api.ModContainer;
|
|
|
|
import net.fabricmc.loader.api.metadata.ModMetadata;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.List;
|
|
|
|
import java.util.Map;
|
2020-06-24 18:03:02 +00:00
|
|
|
import java.util.concurrent.atomic.AtomicInteger;
|
2020-06-24 02:04:22 +00:00
|
|
|
|
|
|
|
public class ModUpdateStrategies {
|
|
|
|
private static final Map<String, ModUpdateStrategy> data = new HashMap<>();
|
|
|
|
|
|
|
|
private static ModUpdate checkForUpdate(ModMetadata metadata, ConfigObject obj, String name) {
|
|
|
|
String oldVersion = metadata.getVersion().toString();
|
|
|
|
|
|
|
|
String strategy;
|
|
|
|
try {
|
|
|
|
strategy = obj.getString("strategy");
|
|
|
|
} catch (ConfigObject.MissingValueException e) {
|
|
|
|
ModUpdater.invalidModUpdaterConfig(name);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
ModUpdateStrategy strategyObj = data.get(strategy);
|
|
|
|
if (strategyObj == null) {
|
|
|
|
ModUpdater.invalidModUpdaterConfig(name);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return strategyObj.checkForUpdate(obj, oldVersion, name);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static ModUpdate[] findAvailableUpdates() {
|
|
|
|
List<ModUpdate> updates = new ArrayList<>();
|
|
|
|
|
2020-06-24 18:03:02 +00:00
|
|
|
AtomicInteger remaining = new AtomicInteger(0);
|
|
|
|
|
2020-06-24 02:04:22 +00:00
|
|
|
for (ModContainer mod : FabricLoader.getInstance().getAllMods()) {
|
2020-06-24 18:03:02 +00:00
|
|
|
Thread thread = new Thread(() -> {
|
|
|
|
ModMetadata metadata = mod.getMetadata();
|
|
|
|
String name = metadata.getName() + " (" + metadata.getId() + ')';
|
2020-06-24 02:04:22 +00:00
|
|
|
|
2020-06-24 18:03:02 +00:00
|
|
|
ModUpdate update = null;
|
|
|
|
if (metadata.containsCustomValue(ModUpdater.NAMESPACE)) {
|
|
|
|
try {
|
|
|
|
update = checkForUpdate(metadata, new ConfigObject.ConfigObjectCustom(metadata.getCustomValue(ModUpdater.NAMESPACE).getAsObject()), name);
|
|
|
|
} catch (ClassCastException e) {
|
|
|
|
ModUpdater.invalidModUpdaterConfig(name);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ConfigObject obj = HardcodedData.getData(metadata.getId());
|
|
|
|
if (obj != null) {
|
|
|
|
update = checkForUpdate(metadata, obj, name);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (update != null) {
|
|
|
|
synchronized (updates) {
|
|
|
|
updates.add(update);
|
|
|
|
}
|
2020-06-24 02:04:22 +00:00
|
|
|
}
|
2020-06-24 18:03:02 +00:00
|
|
|
|
|
|
|
synchronized (remaining) {
|
|
|
|
remaining.decrementAndGet();
|
|
|
|
remaining.notifyAll();
|
2020-06-24 02:04:22 +00:00
|
|
|
}
|
2020-06-24 18:03:02 +00:00
|
|
|
});
|
|
|
|
synchronized (remaining) {
|
|
|
|
remaining.incrementAndGet();
|
2020-06-24 02:04:22 +00:00
|
|
|
}
|
2020-06-24 18:03:02 +00:00
|
|
|
thread.start();
|
|
|
|
}
|
2020-06-24 02:04:22 +00:00
|
|
|
|
2020-06-24 18:03:02 +00:00
|
|
|
synchronized (remaining) {
|
|
|
|
while (remaining.get() > 0) {
|
|
|
|
try {
|
|
|
|
remaining.wait();
|
|
|
|
} catch (InterruptedException ignored) {
|
|
|
|
}
|
2020-06-24 02:04:22 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return updates.toArray(new ModUpdate[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
static {
|
|
|
|
data.put("curseforge", new CurseForgeStrategy());
|
|
|
|
data.put("maven", new MavenStrategy());
|
2020-06-24 18:21:26 +00:00
|
|
|
data.put("github", new GitHubReleasesStrategy());
|
2020-06-24 02:04:22 +00:00
|
|
|
}
|
|
|
|
}
|