hg merge release-2.1 (merge release2.1 into development)
This commit is contained in:
commit
839a5370dc
|
@ -0,0 +1,11 @@
|
||||||
|
SET SQLBLANKLINES ON
|
||||||
|
SET DEFINE OFF
|
||||||
|
|
||||||
|
-- IDEMPIERE-2757 Key for M_Storage wrongly defined on dictionary
|
||||||
|
-- Aug 6, 2015 5:28:43 PM COT
|
||||||
|
UPDATE AD_Column SET IsParent='Y', IsUpdateable='N',Updated=TO_DATE('2015-08-06 17:28:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=210887
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201508061729_IDEMPIERE-2757.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
-- IDEMPIERE-2757 Key for M_Storage wrongly defined on dictionary
|
||||||
|
-- Aug 6, 2015 5:28:43 PM COT
|
||||||
|
UPDATE AD_Column SET IsParent='Y', IsUpdateable='N',Updated=TO_TIMESTAMP('2015-08-06 17:28:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_Column_ID=210887
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201508061729_IDEMPIERE-2757.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -598,17 +598,29 @@ public class MProduct extends X_M_Product
|
||||||
m_precision = null;
|
m_precision = null;
|
||||||
|
|
||||||
// AttributeSetInstance reset
|
// AttributeSetInstance reset
|
||||||
if (is_ValueChanged(COLUMNNAME_M_AttributeSet_ID))
|
if (getM_AttributeSetInstance_ID() > 0 && is_ValueChanged(COLUMNNAME_M_AttributeSet_ID))
|
||||||
{
|
{
|
||||||
MAttributeSetInstance asi = new MAttributeSetInstance(getCtx(), getM_AttributeSetInstance_ID(), get_TrxName());
|
MAttributeSetInstance asi = new MAttributeSetInstance(getCtx(), getM_AttributeSetInstance_ID(), get_TrxName());
|
||||||
setM_AttributeSetInstance_ID(0);
|
if (asi.getM_AttributeSet_ID() != getM_AttributeSet_ID())
|
||||||
// Delete the old m_attributesetinstance
|
setM_AttributeSetInstance_ID(0);
|
||||||
try {
|
}
|
||||||
asi.deleteEx(true, get_TrxName());
|
if (!newRecord && is_ValueChanged(COLUMNNAME_M_AttributeSetInstance_ID))
|
||||||
} catch (AdempiereException ex)
|
{
|
||||||
{
|
// IDEMPIERE-2752 check if the ASI is referenced in other products before trying to delete it
|
||||||
log.saveError("Error", "Error deleting the AttributeSetInstance");
|
int oldasiid = get_ValueOldAsInt(COLUMNNAME_M_AttributeSetInstance_ID);
|
||||||
return false;
|
if (oldasiid > 0) {
|
||||||
|
MAttributeSetInstance oldasi = new MAttributeSetInstance(getCtx(), get_ValueOldAsInt(COLUMNNAME_M_AttributeSetInstance_ID), get_TrxName());
|
||||||
|
int cnt = DB.getSQLValueEx(get_TrxName(), "SELECT COUNT(*) FROM M_Product WHERE M_AttributeSetInstance_ID=?", oldasi.getM_AttributeSetInstance_ID());
|
||||||
|
if (cnt == 1) {
|
||||||
|
// Delete the old m_attributesetinstance
|
||||||
|
try {
|
||||||
|
oldasi.deleteEx(true, get_TrxName());
|
||||||
|
} catch (AdempiereException ex)
|
||||||
|
{
|
||||||
|
log.saveError("Error", "Error deleting the AttributeSetInstance");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1989,6 +1989,7 @@ public abstract class PO
|
||||||
*/
|
*/
|
||||||
public boolean save()
|
public boolean save()
|
||||||
{
|
{
|
||||||
|
checkValidContext();
|
||||||
CLogger.resetLast();
|
CLogger.resetLast();
|
||||||
boolean newRecord = is_new(); // save locally as load resets
|
boolean newRecord = is_new(); // save locally as load resets
|
||||||
if (!newRecord && !is_Changed())
|
if (!newRecord && !is_Changed())
|
||||||
|
@ -3116,6 +3117,7 @@ public abstract class PO
|
||||||
*/
|
*/
|
||||||
public boolean delete (boolean force)
|
public boolean delete (boolean force)
|
||||||
{
|
{
|
||||||
|
checkValidContext();
|
||||||
CLogger.resetLast();
|
CLogger.resetLast();
|
||||||
if (is_new())
|
if (is_new())
|
||||||
return true;
|
return true;
|
||||||
|
@ -4701,4 +4703,10 @@ public abstract class PO
|
||||||
log.saveError(msg, info);
|
log.saveError(msg, info);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void checkValidContext() {
|
||||||
|
if (getCtx().size() == 0)
|
||||||
|
throw new AdempiereException("Context lost");
|
||||||
|
}
|
||||||
|
|
||||||
} // PO
|
} // PO
|
||||||
|
|
|
@ -1616,7 +1616,7 @@ public final class Env
|
||||||
String foreignTable = colToken.getReferenceTableName();
|
String foreignTable = colToken.getReferenceTableName();
|
||||||
if (v != null) {
|
if (v != null) {
|
||||||
if (format != null && format.length() > 0) {
|
if (format != null && format.length() > 0) {
|
||||||
if (v instanceof Integer && (Integer) v > 0 && token.endsWith("_ID")) {
|
if (v instanceof Integer && (Integer) v > 0 && !Util.isEmpty(foreignTable)) {
|
||||||
int tblIndex = format.indexOf(".");
|
int tblIndex = format.indexOf(".");
|
||||||
String tableName = null;
|
String tableName = null;
|
||||||
if (tblIndex > 0)
|
if (tblIndex > 0)
|
||||||
|
|
|
@ -57,8 +57,16 @@ public class PoFiller{
|
||||||
return;
|
return;
|
||||||
else if (oldValue != null && oldValue.toString().equals(value))
|
else if (oldValue != null && oldValue.toString().equals(value))
|
||||||
return;
|
return;
|
||||||
else
|
else {
|
||||||
|
if (po instanceof MColumn && "IsToolbarButton".equals(columnName)) {
|
||||||
|
// IDEMPIERE-2064 - backward compatibility with 2packs generated before IDEMPIERE-2477
|
||||||
|
if ("true".equals(value))
|
||||||
|
value ="Y";
|
||||||
|
else if ("false".equals(value))
|
||||||
|
value ="N";
|
||||||
|
}
|
||||||
po.set_ValueNoCheck(columnName, value);
|
po.set_ValueNoCheck(columnName, value);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
* Product: Adempiere ERP & CRM Smart Business Solution *
|
* Product: Adempiere ERP & CRM Smart Business Solution *
|
||||||
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
|
* Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. *
|
||||||
* This program is free software; you can redistribute it and/or modify it *
|
* This program is free software; you can redistribute it and/or modify it *
|
||||||
* under the terms version 2 of the GNU General Public License as published *
|
* under the terms version 2 of the GNU General Public License as published *
|
||||||
* by the Free Software Foundation. This program is distributed in the hope *
|
* by the Free Software Foundation. This program is distributed in the hope *
|
||||||
* that it will be useful, but WITHOUT ANY WARRANTY; without even the implied *
|
* that it will be useful, but WITHOUT ANY WARRANTY; without even the implied *
|
||||||
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
|
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
|
||||||
|
@ -16,62 +16,62 @@
|
||||||
*****************************************************************************/
|
*****************************************************************************/
|
||||||
package org.compiere.server;
|
package org.compiere.server;
|
||||||
|
|
||||||
import java.sql.Timestamp;
|
import java.sql.Timestamp;
|
||||||
import java.util.Properties;
|
import java.util.Properties;
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
import org.compiere.model.AdempiereProcessor;
|
import org.adempiere.util.ServerContext;
|
||||||
import org.compiere.model.AdempiereProcessor2;
|
import org.compiere.model.AdempiereProcessor;
|
||||||
import org.compiere.model.AdempiereProcessorLog;
|
import org.compiere.model.AdempiereProcessor2;
|
||||||
import org.compiere.model.MClient;
|
import org.compiere.model.AdempiereProcessorLog;
|
||||||
import org.compiere.model.MSchedule;
|
import org.compiere.model.MClient;
|
||||||
import org.compiere.model.MSystem;
|
import org.compiere.model.MSchedule;
|
||||||
import org.compiere.util.CLogger;
|
import org.compiere.model.MSystem;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.model.PO;
|
||||||
import org.compiere.util.TimeUtil;
|
import org.compiere.util.CLogger;
|
||||||
|
import org.compiere.util.Env;
|
||||||
/**
|
import org.compiere.util.TimeUtil;
|
||||||
* Adempiere Server Base
|
|
||||||
*
|
/**
|
||||||
* @author Jorg Janke
|
* Adempiere Server Base
|
||||||
* @version $Id: AdempiereServer.java,v 1.3 2006/10/09 00:23:26 jjanke Exp $
|
*
|
||||||
*/
|
* @author Jorg Janke
|
||||||
public abstract class AdempiereServer implements Runnable
|
* @version $Id: AdempiereServer.java,v 1.3 2006/10/09 00:23:26 jjanke Exp $
|
||||||
{
|
*/
|
||||||
|
public abstract class AdempiereServer implements Runnable
|
||||||
|
{
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* Server Base Class
|
* Server Base Class
|
||||||
* @param model model
|
* @param model model
|
||||||
* @param initialNap delay time running in sec
|
* @param initialNap delay time running in sec
|
||||||
*/
|
*/
|
||||||
protected AdempiereServer (AdempiereProcessor model, int initialNap)
|
protected AdempiereServer (AdempiereProcessor model, int initialNap)
|
||||||
{
|
{
|
||||||
p_model = model;
|
p_model = model;
|
||||||
m_ctx = new Properties(model.getCtx());
|
if (p_system == null)
|
||||||
if (p_system == null)
|
p_system = MSystem.get(model.getCtx());
|
||||||
p_system = MSystem.get(m_ctx);
|
p_client = MClient.get(model.getCtx(), model.getAD_Client_ID());
|
||||||
p_client = MClient.get(m_ctx);
|
m_initialNap = initialNap;
|
||||||
Env.setContext(m_ctx, "#AD_Client_ID", p_client.getAD_Client_ID());
|
|
||||||
m_initialNap = initialNap;
|
Timestamp dateNextRun = getDateNextRun(true);
|
||||||
|
if (dateNextRun != null)
|
||||||
Timestamp dateNextRun = getDateNextRun(true);
|
m_nextWork = dateNextRun.getTime();
|
||||||
if (dateNextRun != null)
|
|
||||||
m_nextWork = dateNextRun.getTime();
|
long now = System.currentTimeMillis();
|
||||||
|
if (m_nextWork > now)
|
||||||
long now = System.currentTimeMillis();
|
{
|
||||||
if (m_nextWork > now)
|
m_sleepMS = m_nextWork - now;
|
||||||
{
|
|
||||||
m_sleepMS = m_nextWork - now;
|
|
||||||
}
|
}
|
||||||
} // ServerBase
|
} // ServerBase
|
||||||
|
|
||||||
/** The Processor Model */
|
/** The Processor Model */
|
||||||
protected volatile AdempiereProcessor p_model;
|
protected volatile AdempiereProcessor p_model;
|
||||||
/** Initial nap is seconds */
|
/** Initial nap is seconds */
|
||||||
private int m_initialNap = 0;
|
private int m_initialNap = 0;
|
||||||
|
|
||||||
/** Milliseconds to sleep - 0 Sec default */
|
/** Milliseconds to sleep - 0 Sec default */
|
||||||
protected long m_sleepMS = 0;
|
protected long m_sleepMS = 0;
|
||||||
/** Sleeping */
|
/** Sleeping */
|
||||||
private volatile boolean m_sleeping = true;
|
private volatile boolean m_sleeping = true;
|
||||||
/** Server start time */
|
/** Server start time */
|
||||||
|
@ -89,8 +89,6 @@ public abstract class AdempiereServer implements Runnable
|
||||||
|
|
||||||
/** Logger */
|
/** Logger */
|
||||||
protected CLogger log = CLogger.getCLogger(getClass());
|
protected CLogger log = CLogger.getCLogger(getClass());
|
||||||
/** Context */
|
|
||||||
private Properties m_ctx = null;
|
|
||||||
/** System */
|
/** System */
|
||||||
protected volatile static MSystem p_system = null;
|
protected volatile static MSystem p_system = null;
|
||||||
/** Client */
|
/** Client */
|
||||||
|
@ -102,7 +100,7 @@ public abstract class AdempiereServer implements Runnable
|
||||||
*/
|
*/
|
||||||
public Properties getCtx()
|
public Properties getCtx()
|
||||||
{
|
{
|
||||||
return m_ctx;
|
return Env.getCtx();
|
||||||
} // getCtx
|
} // getCtx
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -112,18 +110,41 @@ public abstract class AdempiereServer implements Runnable
|
||||||
{
|
{
|
||||||
return m_sleepMS;
|
return m_sleepMS;
|
||||||
} // getSleepMS
|
} // getSleepMS
|
||||||
|
|
||||||
public long getInitialNap()
|
public long getInitialNap()
|
||||||
{
|
{
|
||||||
return m_initialNap;
|
return m_initialNap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void runNow()
|
||||||
|
{
|
||||||
|
Properties context = new Properties();
|
||||||
|
Env.setContext(context, "#AD_Client_ID", p_model.getAD_Client_ID());
|
||||||
|
if (p_model instanceof PO) {
|
||||||
|
PO po = (PO) p_model;
|
||||||
|
if (po.get_ColumnIndex("AD_Org_ID") >= 0)
|
||||||
|
Env.setContext(context, "#AD_Org_ID", po.get_ValueAsInt("AD_Org_ID"));
|
||||||
|
if (po.get_ColumnIndex("AD_User_ID") >= 0)
|
||||||
|
Env.setContext(context, "#AD_User_ID", po.get_ValueAsInt("AD_User_ID"));
|
||||||
|
}
|
||||||
|
|
||||||
|
Properties prevContext = ServerContext.getCurrentInstance();
|
||||||
|
try {
|
||||||
|
ServerContext.setCurrentInstance(context);
|
||||||
|
m_sleeping = false;
|
||||||
|
doRunNow();
|
||||||
|
} finally {
|
||||||
|
ServerContext.dispose();
|
||||||
|
ServerContext.setCurrentInstance(prevContext);
|
||||||
|
m_sleeping = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Run Now
|
* Run Now
|
||||||
*/
|
*/
|
||||||
public void runNow()
|
public void doRunNow()
|
||||||
{
|
{
|
||||||
m_sleeping = false;
|
|
||||||
p_startWork = System.currentTimeMillis();
|
p_startWork = System.currentTimeMillis();
|
||||||
doWork();
|
doWork();
|
||||||
long now = System.currentTimeMillis();
|
long now = System.currentTimeMillis();
|
||||||
|
@ -135,31 +156,55 @@ public abstract class AdempiereServer implements Runnable
|
||||||
//
|
//
|
||||||
p_model.setDateLastRun(new Timestamp(now));
|
p_model.setDateLastRun(new Timestamp(now));
|
||||||
p_model.saveEx();
|
p_model.saveEx();
|
||||||
//
|
//
|
||||||
if (log.isLoggable(Level.FINE))
|
if (log.isLoggable(Level.FINE))
|
||||||
log.fine(getStatistics());
|
log.fine(getStatistics());
|
||||||
m_sleeping = true;
|
|
||||||
} // runNow
|
} // runNow
|
||||||
|
|
||||||
|
public void run()
|
||||||
|
{
|
||||||
|
final Thread currentThread = Thread.currentThread();
|
||||||
|
final String oldThreadName = currentThread.getName();
|
||||||
|
String newThreadName = getName();
|
||||||
|
boolean renamed = false;
|
||||||
|
if (!oldThreadName.equals(newThreadName)) {
|
||||||
|
try {
|
||||||
|
currentThread.setName(newThreadName);
|
||||||
|
renamed = true;
|
||||||
|
} catch (SecurityException e) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
Properties context = new Properties();
|
||||||
|
Env.setContext(context, "#AD_Client_ID", p_model.getAD_Client_ID());
|
||||||
|
if (p_model instanceof PO) {
|
||||||
|
PO po = (PO) p_model;
|
||||||
|
if (po.get_ColumnIndex("AD_Org_ID") >= 0)
|
||||||
|
Env.setContext(context, "#AD_Org_ID", po.get_ValueAsInt("AD_Org_ID"));
|
||||||
|
if (po.get_ColumnIndex("AD_User_ID") >= 0)
|
||||||
|
Env.setContext(context, "#AD_User_ID", po.get_ValueAsInt("AD_User_ID"));
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
ServerContext.setCurrentInstance(context);
|
||||||
|
m_sleeping = false;
|
||||||
|
doRun();
|
||||||
|
} finally {
|
||||||
|
m_sleeping = true;
|
||||||
|
ServerContext.dispose();
|
||||||
|
if (renamed) {
|
||||||
|
// Revert the name back if the current thread was renamed.
|
||||||
|
// We do not check the exception here because we know it works.
|
||||||
|
currentThread.setName(oldThreadName);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* Run async
|
* Run async
|
||||||
*/
|
*/
|
||||||
public void run ()
|
protected void doRun()
|
||||||
{
|
{
|
||||||
final Thread currentThread = Thread.currentThread();
|
if (m_start == 0)
|
||||||
final String oldThreadName = currentThread.getName();
|
m_start = System.currentTimeMillis();
|
||||||
String newThreadName = getName();
|
|
||||||
boolean renamed = false;
|
|
||||||
if (!oldThreadName.equals(newThreadName)) {
|
|
||||||
try {
|
|
||||||
currentThread.setName(newThreadName);
|
|
||||||
renamed = true;
|
|
||||||
} catch (SecurityException e) {}
|
|
||||||
}
|
|
||||||
|
|
||||||
m_sleeping = false;
|
|
||||||
if (m_start == 0)
|
|
||||||
m_start = System.currentTimeMillis();
|
|
||||||
|
|
||||||
// ---------------
|
// ---------------
|
||||||
p_startWork = System.currentTimeMillis();
|
p_startWork = System.currentTimeMillis();
|
||||||
|
@ -169,35 +214,29 @@ public abstract class AdempiereServer implements Runnable
|
||||||
|
|
||||||
p_runCount++;
|
p_runCount++;
|
||||||
m_runLastMS = now - p_startWork;
|
m_runLastMS = now - p_startWork;
|
||||||
m_runTotalMS += m_runLastMS;
|
m_runTotalMS += m_runLastMS;
|
||||||
|
|
||||||
// Finished work - calculate datetime for next run
|
// Finished work - calculate datetime for next run
|
||||||
Timestamp lastRun = new Timestamp(now);
|
Timestamp lastRun = new Timestamp(now);
|
||||||
if (p_model instanceof AdempiereProcessor2)
|
if (p_model instanceof AdempiereProcessor2)
|
||||||
{
|
{
|
||||||
AdempiereProcessor2 ap = (AdempiereProcessor2) p_model;
|
AdempiereProcessor2 ap = (AdempiereProcessor2) p_model;
|
||||||
if (ap.isIgnoreProcessingTime())
|
if (ap.isIgnoreProcessingTime())
|
||||||
{
|
{
|
||||||
lastRun = new Timestamp(p_startWork);
|
lastRun = new Timestamp(p_startWork);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
m_nextWork = MSchedule.getNextRunMS(lastRun.getTime(),
|
m_nextWork = MSchedule.getNextRunMS(lastRun.getTime(),
|
||||||
p_model.getScheduleType(), p_model.getFrequencyType(),
|
p_model.getScheduleType(), p_model.getFrequencyType(),
|
||||||
p_model.getFrequency(), p_model.getCronPattern());
|
p_model.getFrequency(), p_model.getCronPattern());
|
||||||
|
|
||||||
m_sleepMS = m_nextWork - now;
|
m_sleepMS = m_nextWork - now;
|
||||||
if (log.isLoggable(Level.INFO)) log.info(" Next run: " + new Timestamp(m_nextWork) + " sleep " + m_sleepMS);
|
if (log.isLoggable(Level.INFO)) log.info(" Next run: " + new Timestamp(m_nextWork) + " sleep " + m_sleepMS);
|
||||||
//
|
//
|
||||||
p_model.setDateLastRun(lastRun);
|
p_model.setDateLastRun(lastRun);
|
||||||
p_model.setDateNextRun(new Timestamp(m_nextWork));
|
p_model.setDateNextRun(new Timestamp(m_nextWork));
|
||||||
p_model.saveEx();
|
p_model.saveEx();
|
||||||
m_sleeping = true;
|
|
||||||
if (renamed) {
|
|
||||||
// Revert the name back if the current thread was renamed.
|
|
||||||
// We do not check the exception here because we know it works.
|
|
||||||
currentThread.setName(oldThreadName);
|
|
||||||
}
|
|
||||||
} // run
|
} // run
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -261,13 +300,13 @@ public abstract class AdempiereServer implements Runnable
|
||||||
} // getDescription
|
} // getDescription
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get Model
|
* Get Model
|
||||||
* @return Model
|
* @return Model
|
||||||
*/
|
*/
|
||||||
public AdempiereProcessor getModel()
|
public AdempiereProcessor getModel()
|
||||||
{
|
{
|
||||||
return p_model;
|
return p_model;
|
||||||
} // getModel
|
} // getModel
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is Sleeping
|
* Is Sleeping
|
||||||
|
@ -317,35 +356,35 @@ public abstract class AdempiereServer implements Runnable
|
||||||
} // getStartTime
|
} // getStartTime
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get Processor Logs
|
* Get Processor Logs
|
||||||
* @return logs
|
* @return logs
|
||||||
*/
|
*/
|
||||||
public AdempiereProcessorLog[] getLogs()
|
public AdempiereProcessorLog[] getLogs()
|
||||||
{
|
{
|
||||||
return p_model.getLogs();
|
return p_model.getLogs();
|
||||||
} // getLogs
|
} // getLogs
|
||||||
|
|
||||||
|
|
||||||
protected boolean isInterrupted() {
|
protected boolean isInterrupted() {
|
||||||
return Thread.currentThread().isInterrupted();
|
return Thread.currentThread().isInterrupted();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return p_model.getName();
|
return p_model.getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static boolean isOKtoRunOnIP(AdempiereProcessor model) {
|
public static boolean isOKtoRunOnIP(AdempiereProcessor model) {
|
||||||
if (model instanceof AdempiereProcessor2) {
|
if (model instanceof AdempiereProcessor2) {
|
||||||
int AD_Schedule_ID = ((AdempiereProcessor2)model).getAD_Schedule_ID();
|
int AD_Schedule_ID = ((AdempiereProcessor2)model).getAD_Schedule_ID();
|
||||||
MSchedule schedule = MSchedule.get(Env.getCtx(), AD_Schedule_ID);
|
MSchedule schedule = MSchedule.get(Env.getCtx(), AD_Schedule_ID);
|
||||||
if (!schedule.isOKtoRunOnIP())
|
if (!schedule.isOKtoRunOnIP())
|
||||||
{
|
{
|
||||||
return false; // done
|
return false; // done
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // AdempiereServer
|
} // AdempiereServer
|
||||||
|
|
|
@ -27,10 +27,8 @@ import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Calendar;
|
import java.util.Calendar;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Properties;
|
|
||||||
import java.util.logging.Level;
|
import java.util.logging.Level;
|
||||||
|
|
||||||
import org.adempiere.util.ServerContext;
|
|
||||||
import org.compiere.model.MAttachment;
|
import org.compiere.model.MAttachment;
|
||||||
import org.compiere.model.MClient;
|
import org.compiere.model.MClient;
|
||||||
import org.compiere.model.MMailText;
|
import org.compiere.model.MMailText;
|
||||||
|
@ -84,9 +82,6 @@ public class Scheduler extends AdempiereServer
|
||||||
/** Transaction */
|
/** Transaction */
|
||||||
protected Trx m_trx = null;
|
protected Trx m_trx = null;
|
||||||
|
|
||||||
// ctx for the report/process
|
|
||||||
protected Properties m_schedulerctx = new Properties();
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Work
|
* Work
|
||||||
*/
|
*/
|
||||||
|
@ -96,29 +91,27 @@ public class Scheduler extends AdempiereServer
|
||||||
.append(" - ");
|
.append(" - ");
|
||||||
|
|
||||||
// Prepare a ctx for the report/process - BF [1966880]
|
// Prepare a ctx for the report/process - BF [1966880]
|
||||||
m_schedulerctx.clear();
|
|
||||||
MClient schedclient = MClient.get(getCtx(), m_model.getAD_Client_ID());
|
MClient schedclient = MClient.get(getCtx(), m_model.getAD_Client_ID());
|
||||||
Env.setContext(m_schedulerctx, "#AD_Client_ID", schedclient.getAD_Client_ID());
|
Env.setContext(getCtx(), "#AD_Client_ID", schedclient.getAD_Client_ID());
|
||||||
Env.setContext(m_schedulerctx, "#AD_Language", schedclient.getAD_Language());
|
Env.setContext(getCtx(), "#AD_Language", schedclient.getAD_Language());
|
||||||
Env.setContext(m_schedulerctx, "#AD_Org_ID", m_model.getAD_Org_ID());
|
Env.setContext(getCtx(), "#AD_Org_ID", m_model.getAD_Org_ID());
|
||||||
if (m_model.getAD_Org_ID() != 0) {
|
if (m_model.getAD_Org_ID() != 0) {
|
||||||
MOrgInfo schedorg = MOrgInfo.get(getCtx(), m_model.getAD_Org_ID(), null);
|
MOrgInfo schedorg = MOrgInfo.get(getCtx(), m_model.getAD_Org_ID(), null);
|
||||||
if (schedorg.getM_Warehouse_ID() > 0)
|
if (schedorg.getM_Warehouse_ID() > 0)
|
||||||
Env.setContext(m_schedulerctx, "#M_Warehouse_ID", schedorg.getM_Warehouse_ID());
|
Env.setContext(getCtx(), "#M_Warehouse_ID", schedorg.getM_Warehouse_ID());
|
||||||
}
|
}
|
||||||
Env.setContext(m_schedulerctx, "#AD_User_ID", getAD_User_ID());
|
Env.setContext(getCtx(), "#AD_User_ID", getAD_User_ID());
|
||||||
Env.setContext(m_schedulerctx, "#SalesRep_ID", getAD_User_ID());
|
Env.setContext(getCtx(), "#SalesRep_ID", getAD_User_ID());
|
||||||
// TODO: It can be convenient to add AD_Scheduler.AD_Role_ID
|
// TODO: It can be convenient to add AD_Scheduler.AD_Role_ID
|
||||||
MUser scheduser = MUser.get(getCtx(), getAD_User_ID());
|
MUser scheduser = MUser.get(getCtx(), getAD_User_ID());
|
||||||
MRole[] schedroles = scheduser.getRoles(m_model.getAD_Org_ID());
|
MRole[] schedroles = scheduser.getRoles(m_model.getAD_Org_ID());
|
||||||
if (schedroles != null && schedroles.length > 0)
|
if (schedroles != null && schedroles.length > 0)
|
||||||
Env.setContext(m_schedulerctx, "#AD_Role_ID", schedroles[0].getAD_Role_ID()); // first role, ordered by AD_Role_ID
|
Env.setContext(getCtx(), "#AD_Role_ID", schedroles[0].getAD_Role_ID()); // first role, ordered by AD_Role_ID
|
||||||
Timestamp ts = new Timestamp(System.currentTimeMillis());
|
Timestamp ts = new Timestamp(System.currentTimeMillis());
|
||||||
SimpleDateFormat dateFormat4Timestamp = new SimpleDateFormat("yyyy-MM-dd");
|
SimpleDateFormat dateFormat4Timestamp = new SimpleDateFormat("yyyy-MM-dd");
|
||||||
Env.setContext(m_schedulerctx, "#Date", dateFormat4Timestamp.format(ts)+" 00:00:00" ); // JDBC format
|
Env.setContext(getCtx(), "#Date", dateFormat4Timestamp.format(ts)+" 00:00:00" ); // JDBC format
|
||||||
ServerContext.setCurrentInstance(m_schedulerctx);
|
|
||||||
|
|
||||||
MProcess process = new MProcess(m_schedulerctx, m_model.getAD_Process_ID(), null);
|
MProcess process = new MProcess(getCtx(), m_model.getAD_Process_ID(), null);
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
m_trx = Trx.get(Trx.createTrxName("Scheduler"), true);
|
m_trx = Trx.get(Trx.createTrxName("Scheduler"), true);
|
||||||
|
@ -138,9 +131,6 @@ public class Scheduler extends AdempiereServer
|
||||||
m_trx.close();
|
m_trx.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
// clear thread local context
|
|
||||||
ServerContext.dispose();
|
|
||||||
|
|
||||||
//
|
//
|
||||||
int no = m_model.deleteLog();
|
int no = m_model.deleteLog();
|
||||||
m_summary.append(" Logs deleted=").append(no);
|
m_summary.append(" Logs deleted=").append(no);
|
||||||
|
@ -162,7 +152,7 @@ public class Scheduler extends AdempiereServer
|
||||||
if (log.isLoggable(Level.INFO)) log.info(process.toString());
|
if (log.isLoggable(Level.INFO)) log.info(process.toString());
|
||||||
|
|
||||||
boolean isReport = (process.isReport() || process.getAD_ReportView_ID() > 0 || process.getJasperReport() != null || process.getAD_PrintFormat_ID() > 0);
|
boolean isReport = (process.isReport() || process.getAD_ReportView_ID() > 0 || process.getJasperReport() != null || process.getAD_PrintFormat_ID() > 0);
|
||||||
String schedulerName = Env.parseContext(m_schedulerctx, -1, m_model.getName(), false, true);
|
String schedulerName = Env.parseContext(getCtx(), -1, m_model.getName(), false, true);
|
||||||
|
|
||||||
// Process (see also MWFActivity.performWork
|
// Process (see also MWFActivity.performWork
|
||||||
int AD_Table_ID = m_model.getAD_Table_ID();
|
int AD_Table_ID = m_model.getAD_Table_ID();
|
||||||
|
@ -464,7 +454,7 @@ public class Scheduler extends AdempiereServer
|
||||||
String sql = variable.substring(5); // w/o tag
|
String sql = variable.substring(5); // w/o tag
|
||||||
//sql = Env.parseContext(m_vo.ctx, m_vo.WindowNo, sql, false, true); // replace variables
|
//sql = Env.parseContext(m_vo.ctx, m_vo.WindowNo, sql, false, true); // replace variables
|
||||||
//hengsin, capture unparseable error to avoid subsequent sql exception
|
//hengsin, capture unparseable error to avoid subsequent sql exception
|
||||||
sql = Env.parseContext(m_schedulerctx, 0, sql, false, false); // replace variables
|
sql = Env.parseContext(getCtx(), 0, sql, false, false); // replace variables
|
||||||
if (sql.equals(""))
|
if (sql.equals(""))
|
||||||
log.log(Level.WARNING, "(" + sPara.getColumnName() + ") - Default SQL variable parse failed: " + variable);
|
log.log(Level.WARNING, "(" + sPara.getColumnName() + ") - Default SQL variable parse failed: " + variable);
|
||||||
else {
|
else {
|
||||||
|
@ -508,7 +498,7 @@ public class Scheduler extends AdempiereServer
|
||||||
String tail=index < (columnName.length()-1) ? columnName.substring(index+1) : null;
|
String tail=index < (columnName.length()-1) ? columnName.substring(index+1) : null;
|
||||||
columnName = columnName.substring(0, index);
|
columnName = columnName.substring(0, index);
|
||||||
// try Env
|
// try Env
|
||||||
String env = Env.getContext(m_schedulerctx, columnName);
|
String env = Env.getContext(getCtx(), columnName);
|
||||||
if (env == null || env.length() == 0)
|
if (env == null || env.length() == 0)
|
||||||
env = Env.getContext(getCtx(), columnName);
|
env = Env.getContext(getCtx(), columnName);
|
||||||
if (env.length() == 0)
|
if (env.length() == 0)
|
||||||
|
|
|
@ -253,7 +253,8 @@ public class WPAttributeDialog extends Window implements EventListener<Event>
|
||||||
|
|
||||||
MAttributeSet as = null;
|
MAttributeSet as = null;
|
||||||
|
|
||||||
if (m_M_Product_ID != 0)
|
int M_AttributeSet_ID = Env.getContextAsInt(Env.getCtx(), m_WindowNoParent, "M_AttributeSet_ID");
|
||||||
|
if (m_M_Product_ID != 0 && M_AttributeSet_ID == 0)
|
||||||
{
|
{
|
||||||
// Get Model
|
// Get Model
|
||||||
m_masi = MAttributeSetInstance.get(Env.getCtx(), m_M_AttributeSetInstance_ID, m_M_Product_ID);
|
m_masi = MAttributeSetInstance.get(Env.getCtx(), m_M_AttributeSetInstance_ID, m_M_Product_ID);
|
||||||
|
@ -269,7 +270,6 @@ public class WPAttributeDialog extends Window implements EventListener<Event>
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
int M_AttributeSet_ID = Env.getContextAsInt(Env.getCtx(), m_WindowNoParent, "M_AttributeSet_ID");
|
|
||||||
m_masi = new MAttributeSetInstance (Env.getCtx(), m_M_AttributeSetInstance_ID, M_AttributeSet_ID, null);
|
m_masi = new MAttributeSetInstance (Env.getCtx(), m_M_AttributeSetInstance_ID, M_AttributeSet_ID, null);
|
||||||
as = m_masi.getMAttributeSet();
|
as = m_masi.getMAttributeSet();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue