|
|
@ -2,7 +2,13 @@ package com.fr.design.extra; |
|
|
|
|
|
|
|
|
|
|
|
import com.fr.base.ConfigManager; |
|
|
|
import com.fr.base.ConfigManager; |
|
|
|
import com.fr.base.FRContext; |
|
|
|
import com.fr.base.FRContext; |
|
|
|
import com.fr.design.extra.exe.callback.*; |
|
|
|
import com.fr.design.extra.exe.callback.InstallFromDiskCallback; |
|
|
|
|
|
|
|
import com.fr.design.extra.exe.callback.InstallOnlineCallback; |
|
|
|
|
|
|
|
import com.fr.design.extra.exe.callback.JSCallback; |
|
|
|
|
|
|
|
import com.fr.design.extra.exe.callback.ModifyStatusCallback; |
|
|
|
|
|
|
|
import com.fr.design.extra.exe.callback.UninstallPluginCallback; |
|
|
|
|
|
|
|
import com.fr.design.extra.exe.callback.UpdateFromDiskCallback; |
|
|
|
|
|
|
|
import com.fr.design.extra.exe.callback.UpdateOnlineCallback; |
|
|
|
import com.fr.design.gui.ilable.UILabel; |
|
|
|
import com.fr.design.gui.ilable.UILabel; |
|
|
|
import com.fr.general.FRLogger; |
|
|
|
import com.fr.general.FRLogger; |
|
|
|
import com.fr.general.Inter; |
|
|
|
import com.fr.general.Inter; |
|
|
@ -20,7 +26,8 @@ import com.fr.plugin.manage.control.PluginTaskResult; |
|
|
|
import com.fr.plugin.view.PluginView; |
|
|
|
import com.fr.plugin.view.PluginView; |
|
|
|
import com.fr.stable.StringUtils; |
|
|
|
import com.fr.stable.StringUtils; |
|
|
|
|
|
|
|
|
|
|
|
import javax.swing.*; |
|
|
|
import javax.swing.JOptionPane; |
|
|
|
|
|
|
|
import javax.swing.SwingUtilities; |
|
|
|
import java.io.File; |
|
|
|
import java.io.File; |
|
|
|
import java.util.List; |
|
|
|
import java.util.List; |
|
|
|
|
|
|
|
|
|
|
@ -81,17 +88,17 @@ public class PluginOperateUtils { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public static void uninstallPlugin(final String pluginInfo, final boolean isForce, final JSCallback jsCallback) { |
|
|
|
public static void uninstallPlugin(final String pluginInfo, final boolean isForce, final JSCallback jsCallback) { |
|
|
|
|
|
|
|
|
|
|
|
SwingUtilities.invokeLater(new Runnable() { |
|
|
|
SwingUtilities.invokeLater(new Runnable() { |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
@Override |
|
|
|
public void run() { |
|
|
|
public void run() { |
|
|
|
int rv = JOptionPane.showConfirmDialog( |
|
|
|
int rv = JOptionPane.showConfirmDialog( |
|
|
|
null, |
|
|
|
null, |
|
|
|
Inter.getLocText("FR-Plugin_Delete_Confirmed"), |
|
|
|
Inter.getLocText("FR-Plugin_Delete_Confirmed"), |
|
|
|
Inter.getLocText("FR-Designer-Plugin_Warning"), |
|
|
|
Inter.getLocText("FR-Designer-Plugin_Warning"), |
|
|
|
JOptionPane.OK_CANCEL_OPTION, |
|
|
|
JOptionPane.OK_CANCEL_OPTION, |
|
|
|
JOptionPane.INFORMATION_MESSAGE |
|
|
|
JOptionPane.INFORMATION_MESSAGE |
|
|
|
); |
|
|
|
); |
|
|
|
if (rv == JOptionPane.OK_OPTION) { |
|
|
|
if (rv == JOptionPane.OK_OPTION) { |
|
|
|
PluginMarker pluginMarker = PluginUtils.createPluginMarker(pluginInfo); |
|
|
|
PluginMarker pluginMarker = PluginUtils.createPluginMarker(pluginInfo); |
|
|
@ -101,111 +108,25 @@ public class PluginOperateUtils { |
|
|
|
}); |
|
|
|
}); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public static void readUpdateOnline(final JSCallback jsCallback) { |
|
|
|
public static String getRecommendPlugins() { |
|
|
|
|
|
|
|
|
|
|
|
new Thread(new Runnable() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void run() { |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
List<PluginView> plugins = PluginsReaderFromStore.readPluginsForUpdate(); |
|
|
|
|
|
|
|
JSONArray jsonArray = new JSONArray(); |
|
|
|
|
|
|
|
for (PluginView plugin : plugins) { |
|
|
|
|
|
|
|
JSONObject jsonObject = new JSONObject(); |
|
|
|
|
|
|
|
jsonObject.put("pluginid", plugin.getID()); |
|
|
|
|
|
|
|
jsonArray.put(jsonObject); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
String result = jsonArray.toString(); |
|
|
|
|
|
|
|
jsCallback.execute(result); |
|
|
|
|
|
|
|
} catch (Exception e) { |
|
|
|
|
|
|
|
FRLogger.getLogger().error(e.getMessage()); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}).start(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void searchPlugin(final String keyword, final JSCallback jsCallback) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new Thread(new Runnable() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void run() { |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
if (StringUtils.isBlank(keyword)) { |
|
|
|
|
|
|
|
getRecommendPlugins(jsCallback); |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
HttpClient httpClient = new HttpClient(SiteCenter.getInstance().acquireUrlByKind("shop.plugin.store") + "&keyword=" + keyword); |
|
|
|
|
|
|
|
httpClient.asGet(); |
|
|
|
|
|
|
|
String result = httpClient.getResponseText(); |
|
|
|
|
|
|
|
JSONObject jsonObject = new JSONObject(result); |
|
|
|
|
|
|
|
JSONArray jsonArray = jsonObject.getJSONArray("result"); |
|
|
|
|
|
|
|
JSONArray resultJSONArray = PluginUtils.filterPluginsFromVersion(jsonArray); |
|
|
|
|
|
|
|
jsCallback.execute(resultJSONArray.toString()); |
|
|
|
|
|
|
|
} catch (Exception e) { |
|
|
|
|
|
|
|
FRLogger.getLogger().error(e.getMessage()); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}).start(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void getPluginFromStore(final String category, final String seller, final String fee, final JSCallback jsCallback) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new Thread(new Runnable() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void run() { |
|
|
|
|
|
|
|
String plistUrl = SiteCenter.getInstance().acquireUrlByKind("shop.plugin.plist") + "?"; |
|
|
|
|
|
|
|
boolean getRecommend = StringUtils.isEmpty(category) && StringUtils.isEmpty(seller) && StringUtils.isEmpty(fee); |
|
|
|
|
|
|
|
if (getRecommend) { |
|
|
|
|
|
|
|
getRecommendPlugins(jsCallback); |
|
|
|
|
|
|
|
return; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (StringUtils.isNotBlank(plistUrl)) { |
|
|
|
|
|
|
|
StringBuilder url = new StringBuilder(); |
|
|
|
|
|
|
|
url.append(plistUrl); |
|
|
|
|
|
|
|
dealParams(url, category, seller, fee); |
|
|
|
|
|
|
|
try { |
|
|
|
|
|
|
|
HttpClient httpClient = new HttpClient(url.toString()); |
|
|
|
|
|
|
|
httpClient.asGet(); |
|
|
|
|
|
|
|
String result = httpClient.getResponseText(); |
|
|
|
|
|
|
|
JSONObject resultJSONObject = new JSONObject(result); |
|
|
|
|
|
|
|
JSONArray resultArr = resultJSONObject.getJSONArray("result"); |
|
|
|
|
|
|
|
JSONArray resultJSONArray = PluginUtils.filterPluginsFromVersion(resultArr); |
|
|
|
|
|
|
|
jsCallback.execute(resultJSONArray.toString()); |
|
|
|
|
|
|
|
} catch (Exception e) { |
|
|
|
|
|
|
|
FRLogger.getLogger().error(e.getMessage()); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
String result = PluginConstants.CONNECTION_404; |
|
|
|
|
|
|
|
jsCallback.execute(result); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}).start(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void getRecommendPlugins(JSCallback jsCallback) { |
|
|
|
|
|
|
|
String plistUrl = SiteCenter.getInstance().acquireUrlByKind("shop.plugin.feature"); |
|
|
|
String plistUrl = SiteCenter.getInstance().acquireUrlByKind("shop.plugin.feature"); |
|
|
|
|
|
|
|
JSONArray resultArray = JSONArray.create(); |
|
|
|
try { |
|
|
|
try { |
|
|
|
HttpClient httpClient = new HttpClient(plistUrl.toString()); |
|
|
|
HttpClient httpClient = new HttpClient(plistUrl); |
|
|
|
String result = httpClient.getResponseText(); |
|
|
|
String result = httpClient.getResponseText(); |
|
|
|
JSONArray jsonArray = new JSONArray(result); |
|
|
|
JSONArray jsonArray = new JSONArray(result); |
|
|
|
JSONArray resultJSONArray = PluginUtils.filterPluginsFromVersion(jsonArray); |
|
|
|
resultArray = PluginUtils.filterPluginsFromVersion(jsonArray); |
|
|
|
jsCallback.execute(resultJSONArray.toString()); |
|
|
|
|
|
|
|
} catch (Exception e) { |
|
|
|
} catch (Exception e) { |
|
|
|
FRLogger.getLogger().error(e.getMessage()); |
|
|
|
FRLogger.getLogger().error(e.getMessage()); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
return resultArray.toString(); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public static void dealParams(StringBuilder url, String category, String seller, String fee) { |
|
|
|
public static void dealParams(StringBuilder url, String category, String seller, String fee) { |
|
|
|
if (StringUtils.isNotBlank(category)) { |
|
|
|
if (StringUtils.isNotBlank(category)) { |
|
|
|
url.append("cid=").append(category.split("-")[1]); |
|
|
|
url.append("cid=").append(category.split("-")[1]); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
url.append("cid=").append(""); |
|
|
|
url.append("cid=").append(StringUtils.EMPTY); |
|
|
|
} |
|
|
|
} |
|
|
|
if (StringUtils.isNotBlank(seller)) { |
|
|
|
if (StringUtils.isNotBlank(seller)) { |
|
|
|
switch (seller.split("-")[1]) { |
|
|
|
switch (seller.split("-")[1]) { |
|
|
@ -216,7 +137,7 @@ public class PluginOperateUtils { |
|
|
|
url.append("&seller=").append(2); |
|
|
|
url.append("&seller=").append(2); |
|
|
|
break; |
|
|
|
break; |
|
|
|
default: |
|
|
|
default: |
|
|
|
url.append("&seller=").append(""); |
|
|
|
url.append("&seller=").append(StringUtils.EMPTY); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
if (StringUtils.isNotBlank(fee)) { |
|
|
|
if (StringUtils.isNotBlank(fee)) { |
|
|
@ -228,48 +149,19 @@ public class PluginOperateUtils { |
|
|
|
url.append("&fee=").append(2); |
|
|
|
url.append("&fee=").append(2); |
|
|
|
break; |
|
|
|
break; |
|
|
|
default: |
|
|
|
default: |
|
|
|
url.append("&fee=").append(""); |
|
|
|
url.append("&fee=").append(StringUtils.EMPTY); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
public static void getPluginCategories(final JSCallback jsCallback) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new Thread(new Runnable() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void run() { |
|
|
|
|
|
|
|
String result; |
|
|
|
|
|
|
|
String url = SiteCenter.getInstance().acquireUrlByKind("shop.plugin.category"); |
|
|
|
|
|
|
|
if (url != null) { |
|
|
|
|
|
|
|
HttpClient httpClient = new HttpClient(url); |
|
|
|
|
|
|
|
result = httpClient.getResponseText(); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
result = PluginConstants.CONNECTION_404; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
jsCallback.execute(result); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}).start(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void getPluginPrefix(final JSCallback jsCallback) { |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
new Thread(new Runnable() { |
|
|
|
|
|
|
|
@Override |
|
|
|
|
|
|
|
public void run() { |
|
|
|
|
|
|
|
String result = SiteCenter.getInstance().acquireUrlByKind("plugin.url.prefix"); |
|
|
|
|
|
|
|
jsCallback.execute(result); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}).start(); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
public static void getLoginInfo(JSCallback jsCallback, UILabel uiLabel) { |
|
|
|
public static void getLoginInfo(JSCallback jsCallback, UILabel uiLabel) { |
|
|
|
String username = ConfigManager.getProviderInstance().getBbsUsername(); |
|
|
|
String username = ConfigManager.getProviderInstance().getBbsUsername(); |
|
|
|
if (StringUtils.isEmpty(username)) { |
|
|
|
if (StringUtils.isEmpty(username)) { |
|
|
|
jsCallback.execute(""); |
|
|
|
jsCallback.execute(StringUtils.EMPTY); |
|
|
|
uiLabel.setText(Inter.getLocText("FR-Base_UnSignIn")); |
|
|
|
uiLabel.setText(Inter.getLocText("FR-Base_UnSignIn")); |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
uiLabel.setText(username); |
|
|
|
uiLabel.setText(username); |
|
|
|
String result = username; |
|
|
|
String result = username; |
|
|
|
jsCallback.execute(result); |
|
|
|
jsCallback.execute(result); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -285,11 +177,11 @@ public class PluginOperateUtils { |
|
|
|
StringBuilder pluginInfo = new StringBuilder(); |
|
|
|
StringBuilder pluginInfo = new StringBuilder(); |
|
|
|
List<PluginTaskResult> pluginTaskResults = result.asList(); |
|
|
|
List<PluginTaskResult> pluginTaskResults = result.asList(); |
|
|
|
for (PluginTaskResult pluginTaskResult : pluginTaskResults) { |
|
|
|
for (PluginTaskResult pluginTaskResult : pluginTaskResults) { |
|
|
|
if(pluginInfo.length() != 0){ |
|
|
|
if (pluginInfo.length() != 0) { |
|
|
|
pluginInfo.append("\n"); |
|
|
|
pluginInfo.append("\n"); |
|
|
|
} |
|
|
|
} |
|
|
|
PluginTask pluginTask = pluginTaskResult.getCurrentTask(); |
|
|
|
PluginTask pluginTask = pluginTaskResult.getCurrentTask(); |
|
|
|
if(pluginTask == null){ |
|
|
|
if (pluginTask == null) { |
|
|
|
pluginInfo.append(PluginUtils.getMessageByErrorCode(pluginTaskResult.errorCode())); |
|
|
|
pluginInfo.append(PluginUtils.getMessageByErrorCode(pluginTaskResult.errorCode())); |
|
|
|
continue; |
|
|
|
continue; |
|
|
|
} |
|
|
|
} |
|
|
@ -297,7 +189,7 @@ public class PluginOperateUtils { |
|
|
|
PluginContext pluginContext = PluginManager.getContext(pluginMarker); |
|
|
|
PluginContext pluginContext = PluginManager.getContext(pluginMarker); |
|
|
|
if (pluginContext != null) { |
|
|
|
if (pluginContext != null) { |
|
|
|
pluginInfo.append(pluginContext.getName()).append(PluginUtils.getMessageByErrorCode(pluginTaskResult.errorCode())); |
|
|
|
pluginInfo.append(pluginContext.getName()).append(PluginUtils.getMessageByErrorCode(pluginTaskResult.errorCode())); |
|
|
|
}else{ |
|
|
|
} else { |
|
|
|
pluginInfo.append(pluginMarker.getPluginID()).append(PluginUtils.getMessageByErrorCode(pluginTaskResult.errorCode())); |
|
|
|
pluginInfo.append(pluginMarker.getPluginID()).append(PluginUtils.getMessageByErrorCode(pluginTaskResult.errorCode())); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
@ -305,5 +197,4 @@ public class PluginOperateUtils { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|