Merge with c436f1be02c998a2a0d1fcfe5c2a254be6c10693
This commit is contained in:
commit
b825eab40d
|
@ -0,0 +1,8 @@
|
||||||
|
-- Mar 5, 2013 5:32:43 PM COT
|
||||||
|
-- IDEMPIERE-347 passwords hash
|
||||||
|
UPDATE AD_User SET EMailVerifyDate=NULL, EMail='webservice @ gardenworld.com',Updated=TO_DATE('2013-03-05 17:32:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_User_ID=50001
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201303051733_IDEMPIERE-347.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
-- Mar 5, 2013 5:32:43 PM COT
|
||||||
|
-- IDEMPIERE-347 passwords hash
|
||||||
|
UPDATE AD_User SET EMailVerifyDate=NULL, EMail='webservice @ gardenworld.com',Updated=TO_TIMESTAMP('2013-03-05 17:32:43','YYYY-MM-DD HH24:MI:SS'),UpdatedBy=100 WHERE AD_User_ID=50001
|
||||||
|
;
|
||||||
|
|
||||||
|
SELECT register_migration_script('201303051733_IDEMPIERE-347.sql') FROM dual
|
||||||
|
;
|
||||||
|
|
|
@ -902,7 +902,7 @@ public class MUser extends X_AD_User
|
||||||
if (email_login && getPassword() != null && getPassword().length() > 0) {
|
if (email_login && getPassword() != null && getPassword().length() > 0) {
|
||||||
// email is mandatory for users with password
|
// email is mandatory for users with password
|
||||||
if (getEMail() == null || getEMail().length() == 0) {
|
if (getEMail() == null || getEMail().length() == 0) {
|
||||||
log.saveError("SaveError", Msg.getMsg(getCtx(), "FillMandatory") + Msg.getElement(getCtx(), COLUMNNAME_EMail));
|
log.saveError("SaveError", Msg.getMsg(getCtx(), "FillMandatory") + Msg.getElement(getCtx(), COLUMNNAME_EMail) + " - " + toString());
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
// email with password must be unique on the same tenant
|
// email with password must be unique on the same tenant
|
||||||
|
|
|
@ -287,12 +287,12 @@ public class M_Element extends X_AD_Element
|
||||||
|| is_ValueChanged(M_Element.COLUMNNAME_Name)
|
|| is_ValueChanged(M_Element.COLUMNNAME_Name)
|
||||||
) {
|
) {
|
||||||
// Print Info
|
// Print Info
|
||||||
sql = new StringBuilder("UPDATE AD_PrintFormatItem pi SET PrintName=")
|
sql = new StringBuilder("UPDATE AD_PrintFormatItem SET PrintName=")
|
||||||
.append(DB.TO_STRING(getPrintName()))
|
.append(DB.TO_STRING(getPrintName()))
|
||||||
.append(", Name=").append(DB.TO_STRING(getName()))
|
.append(", Name=").append(DB.TO_STRING(getName()))
|
||||||
.append(" WHERE IsCentrallyMaintained='Y'")
|
.append(" WHERE IsCentrallyMaintained='Y'")
|
||||||
.append(" AND EXISTS (SELECT * FROM AD_Column c ")
|
.append(" AND EXISTS (SELECT * FROM AD_Column c ")
|
||||||
.append("WHERE c.AD_Column_ID=pi.AD_Column_ID AND c.AD_Element_ID=")
|
.append("WHERE c.AD_Column_ID=AD_PrintFormatItem.AD_Column_ID AND c.AD_Element_ID=")
|
||||||
.append(get_ID()).append(")");
|
.append(get_ID()).append(")");
|
||||||
no = DB.executeUpdate(sql.toString(), get_TrxName());
|
no = DB.executeUpdate(sql.toString(), get_TrxName());
|
||||||
if (log.isLoggable(Level.FINE)) log.fine("PrintFormatItem updated #" + no);
|
if (log.isLoggable(Level.FINE)) log.fine("PrintFormatItem updated #" + no);
|
||||||
|
|
|
@ -19,8 +19,10 @@ package org.compiere.print;
|
||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
import java.text.SimpleDateFormat;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Calendar;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -503,8 +505,7 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
|
|
||||||
// Get Info
|
// Get Info
|
||||||
String sql = "SELECT TableName," // 1
|
String sql = "SELECT TableName," // 1
|
||||||
+ " (SELECT COUNT(*) FROM AD_PrintFormat x WHERE x.AD_Table_ID=t.AD_Table_ID AND x.AD_Client_ID=c.AD_Client_ID) AS Count,"
|
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID," // 2
|
||||||
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID," // 3
|
|
||||||
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
|
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
|
||||||
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID "
|
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID "
|
||||||
+ "FROM AD_Table t, AD_Client c"
|
+ "FROM AD_Table t, AD_Client c"
|
||||||
|
@ -528,21 +529,18 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
// Name
|
// Name
|
||||||
String TableName = rs.getString(1);
|
String TableName = rs.getString(1);
|
||||||
String ColumnName = TableName + "_ID";
|
String ColumnName = TableName + "_ID";
|
||||||
String s = ColumnName;
|
String basename = ColumnName;
|
||||||
if (!ColumnName.equals("T_Report_ID"))
|
if (!ColumnName.equals("T_Report_ID"))
|
||||||
{
|
{
|
||||||
s = Msg.translate (ctx, ColumnName);
|
basename = Msg.translate (ctx, ColumnName);
|
||||||
if (ColumnName.equals (s)) // not found
|
if (ColumnName.equals (basename)) // not found
|
||||||
s = Msg.translate (ctx, TableName);
|
basename = Msg.translate (ctx, TableName);
|
||||||
}
|
}
|
||||||
int count = rs.getInt(2);
|
setUniqueName(AD_Client_ID, pf, basename);
|
||||||
if (count > 0)
|
|
||||||
s += "_" + (count+1);
|
|
||||||
pf.setName(s);
|
|
||||||
//
|
//
|
||||||
pf.setAD_PrintColor_ID(rs.getInt(3));
|
pf.setAD_PrintColor_ID(rs.getInt(2));
|
||||||
pf.setAD_PrintFont_ID(rs.getInt(4));
|
pf.setAD_PrintFont_ID(rs.getInt(3));
|
||||||
pf.setAD_PrintPaper_ID(rs.getInt(5));
|
pf.setAD_PrintPaper_ID(rs.getInt(4));
|
||||||
//
|
//
|
||||||
error = false;
|
error = false;
|
||||||
}
|
}
|
||||||
|
@ -561,8 +559,7 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
// Save & complete
|
// Save & complete
|
||||||
if (!pf.save())
|
pf.saveEx();
|
||||||
return null;
|
|
||||||
|
|
||||||
GridField[] gridFields = null;
|
GridField[] gridFields = null;
|
||||||
|
|
||||||
|
@ -634,6 +631,12 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
return pf;
|
return pf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static boolean exists(int clientID, String name) {
|
||||||
|
final String sql = "SELECT COUNT(*) FROM AD_PrintFormat WHERE AD_Client_ID=? AND Name=?";
|
||||||
|
int cnt = DB.getSQLValue(null, sql, clientID, name);
|
||||||
|
return cnt > 0;
|
||||||
|
}
|
||||||
|
|
||||||
/**************************************************************************
|
/**************************************************************************
|
||||||
* Create MPrintFormat for Table
|
* Create MPrintFormat for Table
|
||||||
* @param ctx context
|
* @param ctx context
|
||||||
|
@ -663,8 +666,7 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
|
|
||||||
// Get Info
|
// Get Info
|
||||||
String sql = "SELECT TableName," // 1
|
String sql = "SELECT TableName," // 1
|
||||||
+ " (SELECT COUNT(*) FROM AD_PrintFormat x WHERE x.AD_Table_ID=t.AD_Table_ID AND x.AD_Client_ID=c.AD_Client_ID) AS Count,"
|
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID," // 2
|
||||||
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID," // 3
|
|
||||||
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
|
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
|
||||||
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID "
|
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID "
|
||||||
+ "FROM AD_Table t, AD_Client c"
|
+ "FROM AD_Table t, AD_Client c"
|
||||||
|
@ -688,21 +690,18 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
// Name
|
// Name
|
||||||
String TableName = rs.getString(1);
|
String TableName = rs.getString(1);
|
||||||
String ColumnName = TableName + "_ID";
|
String ColumnName = TableName + "_ID";
|
||||||
String s = ColumnName;
|
String basename = ColumnName;
|
||||||
if (!ColumnName.equals("T_Report_ID"))
|
if (!ColumnName.equals("T_Report_ID"))
|
||||||
{
|
{
|
||||||
s = Msg.translate (ctx, ColumnName);
|
basename = Msg.translate (ctx, ColumnName);
|
||||||
if (ColumnName.equals (s)) // not found
|
if (ColumnName.equals (basename)) // not found
|
||||||
s = Msg.translate (ctx, TableName);
|
basename = Msg.translate (ctx, TableName);
|
||||||
}
|
}
|
||||||
int count = rs.getInt(2);
|
setUniqueName(AD_Client_ID, pf, basename);
|
||||||
if (count > 0)
|
|
||||||
s += "_" + (count+1);
|
|
||||||
pf.setName(s);
|
|
||||||
//
|
//
|
||||||
pf.setAD_PrintColor_ID(rs.getInt(3));
|
pf.setAD_PrintColor_ID(rs.getInt(2));
|
||||||
pf.setAD_PrintFont_ID(rs.getInt(4));
|
pf.setAD_PrintFont_ID(rs.getInt(3));
|
||||||
pf.setAD_PrintPaper_ID(rs.getInt(5));
|
pf.setAD_PrintPaper_ID(rs.getInt(4));
|
||||||
//
|
//
|
||||||
error = false;
|
error = false;
|
||||||
}
|
}
|
||||||
|
@ -721,8 +720,7 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
// Save & complete
|
// Save & complete
|
||||||
if (!pf.save())
|
pf.saveEx();
|
||||||
return null;
|
|
||||||
// pf.dump();
|
// pf.dump();
|
||||||
pf.setItems (createItems(ctx, pf));
|
pf.setItems (createItems(ctx, pf));
|
||||||
//
|
//
|
||||||
|
@ -746,7 +744,6 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
|
|
||||||
// Get Info
|
// Get Info
|
||||||
String sql = "SELECT t.TableName,"
|
String sql = "SELECT t.TableName,"
|
||||||
+ " (SELECT COUNT(*) FROM AD_PrintFormat x WHERE x.AD_ReportView_ID=rv.AD_ReportView_ID AND x.AD_Client_ID=c.AD_Client_ID) AS Count,"
|
|
||||||
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID,"
|
+ " COALESCE (cpc.AD_PrintColor_ID, pc.AD_PrintColor_ID) AS AD_PrintColor_ID,"
|
||||||
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
|
+ " COALESCE (cpf.AD_PrintFont_ID, pf.AD_PrintFont_ID) AS AD_PrintFont_ID,"
|
||||||
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID,"
|
+ " COALESCE (cpp.AD_PrintPaper_ID, pp.AD_PrintPaper_ID) AS AD_PrintPaper_ID,"
|
||||||
|
@ -772,19 +769,16 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
if (rs.next())
|
if (rs.next())
|
||||||
{
|
{
|
||||||
// Name
|
// Name
|
||||||
String name = ReportName;
|
String basename = ReportName;
|
||||||
if (name == null || name.length() == 0)
|
if (basename == null || basename.length() == 0)
|
||||||
name = rs.getString(1); // TableName
|
basename = rs.getString(1); // TableName
|
||||||
int count = rs.getInt(2);
|
setUniqueName(AD_Client_ID, pf, basename);
|
||||||
if (count > 0)
|
|
||||||
name += "_" + count;
|
|
||||||
pf.setName(name);
|
|
||||||
//
|
//
|
||||||
pf.setAD_PrintColor_ID(rs.getInt(3));
|
pf.setAD_PrintColor_ID(rs.getInt(2));
|
||||||
pf.setAD_PrintFont_ID(rs.getInt(4));
|
pf.setAD_PrintFont_ID(rs.getInt(3));
|
||||||
pf.setAD_PrintPaper_ID(rs.getInt(5));
|
pf.setAD_PrintPaper_ID(rs.getInt(4));
|
||||||
//
|
//
|
||||||
pf.setAD_Table_ID (rs.getInt(6));
|
pf.setAD_Table_ID (rs.getInt(5));
|
||||||
error = false;
|
error = false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -802,14 +796,27 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
return null;
|
return null;
|
||||||
|
|
||||||
// Save & complete
|
// Save & complete
|
||||||
if (!pf.save())
|
pf.saveEx();
|
||||||
return null;
|
|
||||||
// pf.dump();
|
// pf.dump();
|
||||||
pf.setItems (createItems(ctx, pf));
|
pf.setItems (createItems(ctx, pf));
|
||||||
//
|
//
|
||||||
return pf;
|
return pf;
|
||||||
} // createFromReportView
|
} // createFromReportView
|
||||||
|
|
||||||
|
private static void setUniqueName(int AD_Client_ID, MPrintFormat pf, String basename) {
|
||||||
|
String name = basename;
|
||||||
|
pf.setName(name);
|
||||||
|
boolean sleep = false;
|
||||||
|
while (exists(AD_Client_ID, name)) {
|
||||||
|
if (sleep)
|
||||||
|
Env.sleep(1); // wait 1 sec to get next second in datetime
|
||||||
|
else
|
||||||
|
sleep = true;
|
||||||
|
name = basename + "_" + getDateTime();
|
||||||
|
pf.setName(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create Items.
|
* Create Items.
|
||||||
|
@ -1022,8 +1029,8 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
// Set Name - Remove TEMPLATE - add copy
|
// Set Name - Remove TEMPLATE - add copy
|
||||||
to.setName(Util.replace(to.getName(), "TEMPLATE", String.valueOf(to_Client_ID)));
|
to.setName(Util.replace(to.getName(), "TEMPLATE", String.valueOf(to_Client_ID)));
|
||||||
to.setName(to.getName()
|
to.setName(to.getName()
|
||||||
+ " " + Msg.getMsg(ctx, "Copy")
|
+ " - " + Util.cleanAmp(Msg.getMsg(ctx, "Copy"))
|
||||||
+ " " + to.hashCode()); // unique name
|
+ " " + getDateTime()); // unique name
|
||||||
//
|
//
|
||||||
to.saveEx();
|
to.saveEx();
|
||||||
|
|
||||||
|
@ -1034,6 +1041,13 @@ public class MPrintFormat extends X_AD_PrintFormat
|
||||||
|
|
||||||
/*************************************************************************/
|
/*************************************************************************/
|
||||||
|
|
||||||
|
private static String getDateTime() {
|
||||||
|
Calendar cal = Calendar.getInstance();
|
||||||
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
|
||||||
|
String dt = sdf.format(cal.getTime());
|
||||||
|
return dt;
|
||||||
|
}
|
||||||
|
|
||||||
/** Cached Formats */
|
/** Cached Formats */
|
||||||
static private CCache<Integer,MPrintFormat> s_formats = new CCache<Integer,MPrintFormat>(Table_Name, 30);
|
static private CCache<Integer,MPrintFormat> s_formats = new CCache<Integer,MPrintFormat>(Table_Name, 30);
|
||||||
|
|
||||||
|
|
|
@ -665,21 +665,21 @@ public class MPrintFormatItem extends X_AD_PrintFormatItem
|
||||||
// && MClient.get(getCtx()).isMultiLingualDocument()
|
// && MClient.get(getCtx()).isMultiLingualDocument()
|
||||||
&& getPrintName() != null && getPrintName().length() > 0)
|
&& getPrintName() != null && getPrintName().length() > 0)
|
||||||
{
|
{
|
||||||
String sql = "UPDATE AD_PrintFormatItem_Trl trl "
|
String sql = "UPDATE AD_PrintFormatItem_Trl "
|
||||||
+ "SET PrintName = (SELECT e.PrintName "
|
+ "SET PrintName = (SELECT e.PrintName "
|
||||||
+ "FROM AD_Element_Trl e, AD_Column c "
|
+ "FROM AD_Element_Trl e, AD_Column c "
|
||||||
+ "WHERE e.AD_Language=trl.AD_Language"
|
+ "WHERE e.AD_Language=AD_PrintFormatItem_Trl.AD_Language"
|
||||||
+ " AND e.AD_Element_ID=c.AD_Element_ID"
|
+ " AND e.AD_Element_ID=c.AD_Element_ID"
|
||||||
+ " AND c.AD_Column_ID=" + getAD_Column_ID() + ") "
|
+ " AND c.AD_Column_ID=" + getAD_Column_ID() + ") "
|
||||||
+ "WHERE AD_PrintFormatItem_ID = " + get_ID()
|
+ "WHERE AD_PrintFormatItem_ID = " + get_ID()
|
||||||
+ " AND EXISTS (SELECT * "
|
+ " AND EXISTS (SELECT * "
|
||||||
+ "FROM AD_Element_Trl e, AD_Column c "
|
+ "FROM AD_Element_Trl e, AD_Column c "
|
||||||
+ "WHERE e.AD_Language=trl.AD_Language"
|
+ "WHERE e.AD_Language=AD_PrintFormatItem_Trl.AD_Language"
|
||||||
+ " AND e.AD_Element_ID=c.AD_Element_ID"
|
+ " AND e.AD_Element_ID=c.AD_Element_ID"
|
||||||
+ " AND c.AD_Column_ID=" + getAD_Column_ID()
|
+ " AND c.AD_Column_ID=" + getAD_Column_ID()
|
||||||
+ " AND trl.AD_PrintFormatItem_ID = " + get_ID() + ")"
|
+ " AND AD_PrintFormatItem_Trl.AD_PrintFormatItem_ID = " + get_ID() + ")"
|
||||||
+ " AND EXISTS (SELECT * FROM AD_Client "
|
+ " AND EXISTS (SELECT * FROM AD_Client "
|
||||||
+ "WHERE AD_Client_ID=trl.AD_Client_ID AND IsMultiLingualDocument='Y')";
|
+ "WHERE AD_Client_ID=AD_PrintFormatItem_Trl.AD_Client_ID AND IsMultiLingualDocument='Y')";
|
||||||
int no = DB.executeUpdate(sql, get_TrxName());
|
int no = DB.executeUpdate(sql, get_TrxName());
|
||||||
if (log.isLoggable(Level.FINE)) log.fine("translations updated #" + no);
|
if (log.isLoggable(Level.FINE)) log.fine("translations updated #" + no);
|
||||||
}
|
}
|
||||||
|
|
|
@ -171,6 +171,7 @@ public class Login
|
||||||
* @param force ignore pwd
|
* @param force ignore pwd
|
||||||
* @return Array of Role KeyNamePair or null if error
|
* @return Array of Role KeyNamePair or null if error
|
||||||
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
||||||
|
* @deprecated
|
||||||
*/
|
*/
|
||||||
protected KeyNamePair[] getRoles (CConnection cc,
|
protected KeyNamePair[] getRoles (CConnection cc,
|
||||||
String app_user, String app_pwd, boolean force)
|
String app_user, String app_pwd, boolean force)
|
||||||
|
@ -206,6 +207,7 @@ public class Login
|
||||||
* @param app_user Principal
|
* @param app_user Principal
|
||||||
* @return role array or null if in error.
|
* @return role array or null if in error.
|
||||||
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
||||||
|
* @deprecated use public KeyNamePair[] getRoles(String app_user, KeyNamePair client)
|
||||||
*/
|
*/
|
||||||
public KeyNamePair[] getRoles (Principal app_user)
|
public KeyNamePair[] getRoles (Principal app_user)
|
||||||
{
|
{
|
||||||
|
@ -225,6 +227,7 @@ public class Login
|
||||||
* @param app_pwd password
|
* @param app_pwd password
|
||||||
* @return role array or null if in error.
|
* @return role array or null if in error.
|
||||||
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
||||||
|
* @deprecated use public KeyNamePair[] getRoles(String app_user, KeyNamePair client)
|
||||||
*/
|
*/
|
||||||
public KeyNamePair[] getRoles (String app_user, String app_pwd)
|
public KeyNamePair[] getRoles (String app_user, String app_pwd)
|
||||||
{
|
{
|
||||||
|
@ -238,6 +241,7 @@ public class Login
|
||||||
* @param force ignore pwd
|
* @param force ignore pwd
|
||||||
* @return role array or null if in error.
|
* @return role array or null if in error.
|
||||||
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
* The error (NoDatabase, UserPwdError, DBLogin) is saved in the log
|
||||||
|
* @deprecated use public KeyNamePair[] getRoles(String app_user, KeyNamePair client)
|
||||||
*/
|
*/
|
||||||
private KeyNamePair[] getRoles (String app_user, String app_pwd, boolean force)
|
private KeyNamePair[] getRoles (String app_user, String app_pwd, boolean force)
|
||||||
{
|
{
|
||||||
|
@ -296,6 +300,8 @@ public class Login
|
||||||
" AND c.IsActive='Y') AND " +
|
" AND c.IsActive='Y') AND " +
|
||||||
" AD_User.IsActive='Y'";
|
" AD_User.IsActive='Y'";
|
||||||
|
|
||||||
|
// deprecate this method - it cannot cope with same user found on multiple clients
|
||||||
|
// use public KeyNamePair[] getRoles(String app_user, KeyNamePair client) approach instead
|
||||||
MUser user = MTable.get(m_ctx, MUser.Table_ID).createQuery( where, null).setParameters(app_user).firstOnly(); // throws error if username collision occurs
|
MUser user = MTable.get(m_ctx, MUser.Table_ID).createQuery( where, null).setParameters(app_user).firstOnly(); // throws error if username collision occurs
|
||||||
|
|
||||||
// always do calculation to confuse timing based attacks
|
// always do calculation to confuse timing based attacks
|
||||||
|
@ -397,7 +403,13 @@ public class Login
|
||||||
do // read all roles
|
do // read all roles
|
||||||
{
|
{
|
||||||
MUser user = new MUser(m_ctx, rs.getInt(1), null);
|
MUser user = new MUser(m_ctx, rs.getInt(1), null);
|
||||||
if (user.getPassword() != null && user.getPassword().equals(app_pwd)) {
|
boolean valid = false;
|
||||||
|
if (hash_password) {
|
||||||
|
valid = user.authenticateHash(app_pwd);
|
||||||
|
} else {
|
||||||
|
valid = user.getPassword() != null && user.getPassword().equals(app_pwd);
|
||||||
|
}
|
||||||
|
if (valid) {
|
||||||
int AD_Role_ID = rs.getInt(2);
|
int AD_Role_ID = rs.getInt(2);
|
||||||
if (AD_Role_ID == 0)
|
if (AD_Role_ID == 0)
|
||||||
Env.setContext(m_ctx, "#SysAdmin", "Y");
|
Env.setContext(m_ctx, "#SysAdmin", "Y");
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -45,6 +45,8 @@ import org.zkoss.zk.ui.event.EventListener;
|
||||||
import org.zkoss.zk.ui.event.Events;
|
import org.zkoss.zk.ui.event.Events;
|
||||||
import org.zkoss.zk.ui.util.Clients;
|
import org.zkoss.zk.ui.util.Clients;
|
||||||
import org.zkoss.zul.Menuitem;
|
import org.zkoss.zul.Menuitem;
|
||||||
|
import org.zkoss.zul.Row;
|
||||||
|
import org.zkoss.zul.RowRenderer;
|
||||||
import org.zkoss.zul.Vlayout;
|
import org.zkoss.zul.Vlayout;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -210,7 +212,7 @@ public class CompositeADTabbox extends AbstractADTabbox
|
||||||
layout.addEventListener(ON_POST_TAB_SELECTION_CHANGED_EVENT, new EventListener<Event>() {
|
layout.addEventListener(ON_POST_TAB_SELECTION_CHANGED_EVENT, new EventListener<Event>() {
|
||||||
@Override
|
@Override
|
||||||
public void onEvent(Event event) throws Exception {
|
public void onEvent(Event event) throws Exception {
|
||||||
onPostTabSelectionChanged();
|
onPostTabSelectionChanged((Boolean)event.getData());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -435,10 +437,10 @@ public class CompositeADTabbox extends AbstractADTabbox
|
||||||
headerTab.setDetailPaneMode(false);
|
headerTab.setDetailPaneMode(false);
|
||||||
getBreadCrumb().getFirstChild().setVisible(false);
|
getBreadCrumb().getFirstChild().setVisible(false);
|
||||||
|
|
||||||
Events.echoEvent(new Event(ON_POST_TAB_SELECTION_CHANGED_EVENT, layout));
|
Events.echoEvent(new Event(ON_POST_TAB_SELECTION_CHANGED_EVENT, layout, oldIndex > newIndex));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onPostTabSelectionChanged() {
|
private void onPostTabSelectionChanged(Boolean back) {
|
||||||
if (headerTab instanceof ADTabpanel) {
|
if (headerTab instanceof ADTabpanel) {
|
||||||
DetailPane detailPane = headerTab.getDetailPane();
|
DetailPane detailPane = headerTab.getDetailPane();
|
||||||
if (detailPane == null) {
|
if (detailPane == null) {
|
||||||
|
@ -488,6 +490,17 @@ public class CompositeADTabbox extends AbstractADTabbox
|
||||||
adwindow.getADWindowContent().getToolbar().enableTabNavigation(getBreadCrumb().hasParentLink(),
|
adwindow.getADWindowContent().getToolbar().enableTabNavigation(getBreadCrumb().hasParentLink(),
|
||||||
headerTab.getDetailPane() != null && headerTab.getDetailPane().getTabcount() > 0);
|
headerTab.getDetailPane() != null && headerTab.getDetailPane().getTabcount() > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//indicator and row highlight lost after navigate back from child to parent
|
||||||
|
if (back != null && back.booleanValue()) {
|
||||||
|
if (headerTab.isGridView()) {
|
||||||
|
RowRenderer<Object[]> renderer = headerTab.getGridView().getListbox().getRowRenderer();
|
||||||
|
GridTabRowRenderer gtr = (GridTabRowRenderer)renderer;
|
||||||
|
Row row = gtr.getCurrentRow();
|
||||||
|
if (row != null)
|
||||||
|
gtr.setCurrentRow(row);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateBreadCrumb() {
|
private void updateBreadCrumb() {
|
||||||
|
|
|
@ -30,6 +30,7 @@ import org.adempiere.webui.apps.AEnv;
|
||||||
import org.adempiere.webui.apps.BusyDialog;
|
import org.adempiere.webui.apps.BusyDialog;
|
||||||
import org.adempiere.webui.apps.ProcessDialog;
|
import org.adempiere.webui.apps.ProcessDialog;
|
||||||
import org.adempiere.webui.apps.WReport;
|
import org.adempiere.webui.apps.WReport;
|
||||||
|
import org.adempiere.webui.component.Tab;
|
||||||
import org.adempiere.webui.component.Tabpanel;
|
import org.adempiere.webui.component.Tabpanel;
|
||||||
import org.adempiere.webui.component.ToolBarButton;
|
import org.adempiere.webui.component.ToolBarButton;
|
||||||
import org.adempiere.webui.event.DrillEvent;
|
import org.adempiere.webui.event.DrillEvent;
|
||||||
|
@ -438,14 +439,22 @@ public class DefaultDesktop extends TabbedDesktop implements MenuListener, Seria
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//use _docClick undocumented api. need verification after major zk release update
|
||||||
|
private final static String autoHideMenuScript = "try{var w=zk.Widget.$('#{0}');var t=zk.Widget.$('#{1}');" +
|
||||||
|
"var e=new Object;e.target=t;w._docClick(e);}catch(error){}";
|
||||||
|
|
||||||
private void autoHideMenu() {
|
private void autoHideMenu() {
|
||||||
if (layout.getWest().isCollapsible() && !layout.getWest().isOpen())
|
if (layout.getWest().isCollapsible() && !layout.getWest().isOpen())
|
||||||
{
|
{
|
||||||
String id = layout.getWest().getUuid();
|
String id = layout.getWest().getUuid();
|
||||||
//$n('colled') is not documented api so this might break in release after 6.0.0
|
Tab tab = windowContainer.getSelectedTab();
|
||||||
String script = "jq(zk.Widget.$('"+id+"').$n('colled')).click();";
|
if (tab != null) {
|
||||||
AuScript aus = new AuScript(layout.getWest(), script);
|
String tabId = tab.getUuid();
|
||||||
Clients.response("autoHideWest", aus);
|
String script = autoHideMenuScript.replace("{0}", id);
|
||||||
|
script = script.replace("{1}", tabId);
|
||||||
|
AuScript aus = new AuScript(layout.getWest(), script);
|
||||||
|
Clients.response("autoHideWest", aus);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -169,6 +169,7 @@ public abstract class TabbedDesktop extends AbstractDesktop {
|
||||||
runnable.run();
|
runnable.run();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
preOpenNewTab();
|
||||||
Events.echoEvent(new Event("onOpenWindow", tabPanel));
|
Events.echoEvent(new Event("onOpenWindow", tabPanel));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -259,6 +260,7 @@ public abstract class TabbedDesktop extends AbstractDesktop {
|
||||||
runnable.run();
|
runnable.run();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
preOpenNewTab();
|
||||||
Events.echoEvent(new Event("onOpenWindow", tabPanel));
|
Events.echoEvent(new Event("onOpenWindow", tabPanel));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -384,7 +386,6 @@ public abstract class TabbedDesktop extends AbstractDesktop {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
preOpenNewTab();
|
|
||||||
if (adWindow.createPart(tabPanel) != null ) {
|
if (adWindow.createPart(tabPanel) != null ) {
|
||||||
tab.setImage(null);
|
tab.setImage(null);
|
||||||
tab.setClosable(true);
|
tab.setClosable(true);
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
package org.idempiere.fitnesse.fixture;
|
package org.idempiere.fitnesse.fixture;
|
||||||
|
|
||||||
import org.compiere.model.MSession;
|
import org.compiere.model.MSession;
|
||||||
|
import org.compiere.model.MUser;
|
||||||
import org.compiere.util.Env;
|
import org.compiere.util.Env;
|
||||||
import org.compiere.util.KeyNamePair;
|
import org.compiere.util.KeyNamePair;
|
||||||
|
|
||||||
|
@ -140,7 +141,29 @@ public class Login extends TableFixture {
|
||||||
return null; // already logged with same data
|
return null; // already logged with same data
|
||||||
|
|
||||||
org.compiere.util.Login login = new org.compiere.util.Login(m_ads!=null ? m_ads.getCtx() : null);
|
org.compiere.util.Login login = new org.compiere.util.Login(m_ads!=null ? m_ads.getCtx() : null);
|
||||||
KeyNamePair[] roles = login.getRoles(m_user, m_password);
|
|
||||||
|
KeyNamePair[] clients = login.getClients(m_user, m_password);
|
||||||
|
boolean okclient = false;
|
||||||
|
KeyNamePair selectedClient = null;
|
||||||
|
for (KeyNamePair client : clients) {
|
||||||
|
if (client.getKey() == m_client_id) {
|
||||||
|
okclient = true;
|
||||||
|
selectedClient = client;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!okclient)
|
||||||
|
return "Error logging in - client not allowed for this user";
|
||||||
|
|
||||||
|
Env.setContext(m_ads.getCtx(), "#AD_Client_ID", (String) selectedClient.getID());
|
||||||
|
MUser user = MUser.get (m_ads.getCtx(), m_user);
|
||||||
|
if (user != null) {
|
||||||
|
Env.setContext(m_ads.getCtx(), "#AD_User_ID", user.getAD_User_ID() );
|
||||||
|
Env.setContext(m_ads.getCtx(), "#AD_User_Name", user.getName() );
|
||||||
|
Env.setContext(m_ads.getCtx(), "#SalesRep_ID", user.getAD_User_ID() );
|
||||||
|
}
|
||||||
|
|
||||||
|
KeyNamePair[] roles = login.getRoles(m_user, selectedClient);
|
||||||
if (roles != null)
|
if (roles != null)
|
||||||
{
|
{
|
||||||
boolean okrole = false;
|
boolean okrole = false;
|
||||||
|
@ -153,19 +176,6 @@ public class Login extends TableFixture {
|
||||||
if (!okrole)
|
if (!okrole)
|
||||||
return "Error logging in - role not allowed for this user";
|
return "Error logging in - role not allowed for this user";
|
||||||
|
|
||||||
KeyNamePair[] clients = login.getClients( new KeyNamePair(m_role_id, "" ) );
|
|
||||||
boolean okclient = false;
|
|
||||||
for (KeyNamePair client : clients) {
|
|
||||||
if (client.getKey() == m_client_id) {
|
|
||||||
okclient = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!okclient)
|
|
||||||
return "Error logging in - client not allowed for this role";
|
|
||||||
|
|
||||||
m_ads.getCtx().setProperty("#AD_Client_ID", Integer.toString(m_client_id));
|
|
||||||
|
|
||||||
KeyNamePair[] orgs = login.getOrgs( new KeyNamePair(m_role_id, "" ));
|
KeyNamePair[] orgs = login.getOrgs( new KeyNamePair(m_role_id, "" ));
|
||||||
|
|
||||||
if (orgs == null)
|
if (orgs == null)
|
||||||
|
|
|
@ -33,6 +33,7 @@ import org.adempiere.base.ServiceQuery;
|
||||||
import org.adempiere.base.equinox.EquinoxExtensionLocator;
|
import org.adempiere.base.equinox.EquinoxExtensionLocator;
|
||||||
import org.adempiere.exceptions.AdempiereException;
|
import org.adempiere.exceptions.AdempiereException;
|
||||||
import org.compiere.model.Lookup;
|
import org.compiere.model.Lookup;
|
||||||
|
import org.compiere.model.MUser;
|
||||||
import org.compiere.model.MWebService;
|
import org.compiere.model.MWebService;
|
||||||
import org.compiere.model.MWebServiceType;
|
import org.compiere.model.MWebServiceType;
|
||||||
import org.compiere.model.PO;
|
import org.compiere.model.PO;
|
||||||
|
@ -89,7 +90,29 @@ public class AbstractService {
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
Login login = new Login(m_cs.getCtx());
|
Login login = new Login(m_cs.getCtx());
|
||||||
KeyNamePair[] roles = login.getRoles(loginRequest.getUser(), loginRequest.getPass());
|
KeyNamePair[] clients = login.getClients(loginRequest.getUser(), loginRequest.getPass());
|
||||||
|
boolean okclient = false;
|
||||||
|
KeyNamePair selectedClient = null;
|
||||||
|
for (KeyNamePair client : clients) {
|
||||||
|
if (client.getKey() == loginRequest.getClientID()) {
|
||||||
|
okclient = true;
|
||||||
|
selectedClient = client;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!okclient)
|
||||||
|
return "Error logging in - client not allowed for this user";
|
||||||
|
|
||||||
|
m_cs.getCtx().setProperty("#AD_Client_ID", "" + loginRequest.getClientID());
|
||||||
|
Env.setContext(m_cs.getCtx(), "#AD_Client_ID", (String) selectedClient.getID());
|
||||||
|
MUser user = MUser.get (m_cs.getCtx(), loginRequest.getUser());
|
||||||
|
if (user != null) {
|
||||||
|
Env.setContext(m_cs.getCtx(), "#AD_User_ID", user.getAD_User_ID() );
|
||||||
|
Env.setContext(m_cs.getCtx(), "#AD_User_Name", user.getName() );
|
||||||
|
Env.setContext(m_cs.getCtx(), "#SalesRep_ID", user.getAD_User_ID() );
|
||||||
|
}
|
||||||
|
|
||||||
|
KeyNamePair[] roles = login.getRoles(loginRequest.getUser(), selectedClient);
|
||||||
if (roles != null) {
|
if (roles != null) {
|
||||||
boolean okrole = false;
|
boolean okrole = false;
|
||||||
for (KeyNamePair role : roles) {
|
for (KeyNamePair role : roles) {
|
||||||
|
@ -101,19 +124,6 @@ public class AbstractService {
|
||||||
if (!okrole)
|
if (!okrole)
|
||||||
return "Error logging in - role not allowed for this user";
|
return "Error logging in - role not allowed for this user";
|
||||||
|
|
||||||
KeyNamePair[] clients = login.getClients(new KeyNamePair(loginRequest.getRoleID(), ""));
|
|
||||||
boolean okclient = false;
|
|
||||||
for (KeyNamePair client : clients) {
|
|
||||||
if (client.getKey() == loginRequest.getClientID()) {
|
|
||||||
okclient = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!okclient)
|
|
||||||
return "Error logging in - client not allowed for this role";
|
|
||||||
|
|
||||||
m_cs.getCtx().setProperty("#AD_Client_ID", "" + loginRequest.getClientID());
|
|
||||||
|
|
||||||
KeyNamePair[] orgs = login.getOrgs(new KeyNamePair(loginRequest.getRoleID(), ""));
|
KeyNamePair[] orgs = login.getOrgs(new KeyNamePair(loginRequest.getRoleID(), ""));
|
||||||
|
|
||||||
if (orgs == null)
|
if (orgs == null)
|
||||||
|
@ -152,8 +162,6 @@ public class AbstractService {
|
||||||
if (!m_cs.login(AD_User_ID, loginRequest.getRoleID(), loginRequest.getClientID(), loginRequest.getOrgID(), loginRequest.getWarehouseID(), loginRequest.getLang()))
|
if (!m_cs.login(AD_User_ID, loginRequest.getRoleID(), loginRequest.getClientID(), loginRequest.getOrgID(), loginRequest.getWarehouseID(), loginRequest.getLang()))
|
||||||
return "Error logging in";
|
return "Error logging in";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
return "Error logging in - no roles or user/pwd invalid for user " + loginRequest.getUser();
|
return "Error logging in - no roles or user/pwd invalid for user " + loginRequest.getUser();
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,6 @@
|
||||||
<classpath>
|
<classpath>
|
||||||
<classpathentry kind="src" path="src"/>
|
<classpathentry kind="src" path="src"/>
|
||||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
|
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
|
||||||
<classpathentry kind="lib" path="/org.idempiere.fitnesse.server/lib/selenium-server-standalone-2.27.0.jar"/>
|
<classpathentry kind="lib" path="/org.idempiere.fitnesse.server/lib/selenium-server-standalone-2.31.0.jar" sourcepath="/org.idempiere.fitnesse.server/lib/selenium-server-2.31.0-sources.jar"/>
|
||||||
<classpathentry kind="output" path="bin"/>
|
<classpathentry kind="output" path="bin"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
|
|
|
@ -3,6 +3,6 @@
|
||||||
<classpathentry kind="src" path="src"/>
|
<classpathentry kind="src" path="src"/>
|
||||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
|
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.6"/>
|
||||||
<classpathentry kind="lib" path="lib/ztl-2.0.0-SNAPSHOT.jar" sourcepath="lib/ztl-2.0.0-sources.jar"/>
|
<classpathentry kind="lib" path="lib/ztl-2.0.0-SNAPSHOT.jar" sourcepath="lib/ztl-2.0.0-sources.jar"/>
|
||||||
<classpathentry kind="lib" path="/org.idempiere.fitnesse.server/lib/selenium-server-standalone-2.27.0.jar"/>
|
<classpathentry kind="lib" path="/org.idempiere.fitnesse.server/lib/selenium-server-standalone-2.31.0.jar" sourcepath="/org.idempiere.fitnesse.server/lib/selenium-server-2.31.0-sources.jar"/>
|
||||||
<classpathentry kind="output" path="bin"/>
|
<classpathentry kind="output" path="bin"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
|
|
Loading…
Reference in New Issue