IDEMPIERE-436 AdempiereActivator is not able to run 2Pack
This commit is contained in:
parent
af49e500be
commit
f22faccda1
|
@ -1,12 +1,15 @@
|
||||||
package org.adempiere.pipo.srv;
|
package org.adempiere.pipo.srv;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.sql.Timestamp;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
import org.adempiere.base.IDictionaryService;
|
import org.adempiere.base.IDictionaryService;
|
||||||
import org.adempiere.pipo2.PackIn;
|
import org.adempiere.pipo2.PackIn;
|
||||||
|
import org.adempiere.pipo2.Zipper;
|
||||||
import org.compiere.Adempiere;
|
import org.compiere.Adempiere;
|
||||||
|
import org.compiere.model.X_AD_Package_Imp_Proc;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.util.Env;
|
||||||
import org.compiere.util.Trx;
|
import org.compiere.util.Trx;
|
||||||
import org.osgi.framework.BundleContext;
|
import org.osgi.framework.BundleContext;
|
||||||
|
@ -28,7 +31,28 @@ public class PipoDictionaryService implements IDictionaryService {
|
||||||
packIn.setPackageVersion((String) context.getBundle().getHeaders().get("Bundle-Version"));
|
packIn.setPackageVersion((String) context.getBundle().getHeaders().get("Bundle-Version"));
|
||||||
packIn.setUpdateDictionary(false);
|
packIn.setUpdateDictionary(false);
|
||||||
packIn.setPackageDirectory(getPackageDir());
|
packIn.setPackageDirectory(getPackageDir());
|
||||||
packIn.importXML(packageFile.getAbsolutePath(), Env.getCtx(), trxName);
|
|
||||||
|
X_AD_Package_Imp_Proc adPackageImp = new X_AD_Package_Imp_Proc(Env.getCtx(),
|
||||||
|
0, trxName);
|
||||||
|
File zipFilepath = packageFile;
|
||||||
|
logger.info("zipFilepath->" + zipFilepath);
|
||||||
|
String parentDir = Zipper.getParentDir(zipFilepath);
|
||||||
|
File targetDir = new File(System.getProperty("java.io.tmpdir"));
|
||||||
|
Zipper.unpackFile(zipFilepath, targetDir);
|
||||||
|
|
||||||
|
String dict_file = targetDir + File.separator + parentDir + File.separator
|
||||||
|
+ "dict" + File.separator + "PackOut.xml";
|
||||||
|
|
||||||
|
logger.info("dict file->" + dict_file);
|
||||||
|
|
||||||
|
// call XML Handler
|
||||||
|
String msg = packIn.importXML(dict_file, Env.getCtx(), trxName);
|
||||||
|
adPackageImp.setName(packIn.getPackageName());
|
||||||
|
adPackageImp.setDateProcessed(new Timestamp(System.currentTimeMillis()));
|
||||||
|
adPackageImp.setP_Msg(msg);
|
||||||
|
adPackageImp.setAD_Package_Source_Type("File");
|
||||||
|
adPackageImp.saveEx();
|
||||||
|
|
||||||
Trx.get(trxName, false).commit();
|
Trx.get(trxName, false).commit();
|
||||||
logger.info("commit " + trxName);
|
logger.info("commit " + trxName);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
package org.adempiere.plugin.utils;
|
package org.adempiere.plugin.utils;
|
||||||
|
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
|
import java.io.FileOutputStream;
|
||||||
|
import java.io.InputStream;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
@ -60,12 +62,21 @@ public class AdempiereActivator implements BundleActivator {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void packIn(String trxName) {
|
protected void packIn(String trxName) {
|
||||||
URL packout = this.getClass().getResource(
|
URL packout = this.getClass().getClassLoader().getResource("/META-INF/2Pack.zip");
|
||||||
"/META-INF/2Pack.zip");
|
|
||||||
if (packout != null) {
|
if (packout != null) {
|
||||||
IDictionaryService service = Service.locate(IDictionaryService.class);
|
IDictionaryService service = Service.locate(IDictionaryService.class);
|
||||||
try {
|
try {
|
||||||
service.merge(context, new File(packout.getFile()));
|
// copy the resource to a temporary file to process it with 2pack
|
||||||
|
InputStream stream = this.getClass().getResourceAsStream("/META-INF/2Pack.zip");
|
||||||
|
File zipfile = File.createTempFile(getName(), ".zip");
|
||||||
|
FileOutputStream zipstream = new FileOutputStream(zipfile);
|
||||||
|
byte[] buffer = new byte[1024];
|
||||||
|
int read;
|
||||||
|
while((read = stream.read(buffer)) != -1){
|
||||||
|
zipstream.write(buffer, 0, read);
|
||||||
|
}
|
||||||
|
// call 2pack
|
||||||
|
service.merge(context, zipfile);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.log(Level.WARNING, "Error on Dictionary service", e);
|
logger.log(Level.WARNING, "Error on Dictionary service", e);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue