org.nakedobjects.example.expenses.fixtures.UserFixture Maven / Gradle / Ivy
package org.nakedobjects.example.expenses.fixtures;
import java.sql.DatabaseMetaData;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
import org.hibernate.Hibernate;
import org.hibernate.SQLQuery;
import org.nakedobjects.applib.fixtures.AbstractFixture;
import org.nakedobjects.metamodel.commons.exceptions.NakedObjectException;
import org.nakedobjects.plugins.hibernate.authentication.DatabaseAuthenticator;
import org.nakedobjects.plugins.hibernate.objectstore.util.HibernateUtil;
import org.nakedobjects.runtime.context.NakedObjectsContext;
// special fixture to insert users
public class UserFixture extends AbstractFixture {
private static final int PERMISSIONS = 0;
private static final int USER_ROLE = 1;
private static final int ROLE = 2;
private static final int USER = 3;
private static final int GET_ID = 4;
private static final int INSERT_USER = 5;
private static final int INSERT_ROLE = 6;
private static final int INSERT_USER_ROLE = 7;
private static final int INSERT_PERMISSION = 8;
// works just for mySQL
private static final String[] MYSQL_SQL = {
"CREATE TABLE `permissions` (`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, `role` INTEGER UNSIGNED NOT NULL,`permission` VARCHAR(255) NOT NULL, `flags` INTEGER UNSIGNED, PRIMARY KEY (`id`)) ENGINE = InnoDB;",
"CREATE TABLE `user_role` (`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, `user` INTEGER UNSIGNED NOT NULL,`role` INTEGER UNSIGNED NOT NULL, PRIMARY KEY (`id`)) ENGINE = InnoDB;",
"CREATE TABLE `role` (`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, `rolename` VARCHAR(255) NOT NULL, PRIMARY KEY (`id`)) ENGINE = InnoDB;",
"CREATE TABLE `expenses`.`user` (`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT, `username` VARCHAR(255) NOT NULL,`password` VARCHAR(255) NOT NULL, `emailupdates` TINYINT(1) NOT NULL, PRIMARY KEY (`id`)) ENGINE = InnoDB;",
"SELECT `id` FROM `?` ORDER BY `id` DESC LIMIT 1",
"INSERT INTO `user` VALUES (?, ?, ?, ?)",
"INSERT INTO `role` VALUES (?, ?)",
"INSERT INTO `user_role` VALUES (?, (SELECT `id` FROM `user` WHERE `username` = ?), (SELECT `id` FROM `role` WHERE `rolename` = ?))",
"INSERT INTO `permissions` VALUES (?, (SELECT `id` FROM `role` WHERE `rolename` = ?), ?, ?)" };
// works for both mySQL and hsql-db (but not postgresql)
private static final String[] HSQLDB_SQL = {
"CREATE TABLE permissions (id INTEGER NOT NULL , role INTEGER NOT NULL,permission VARCHAR(255) NOT NULL, flags INTEGER, PRIMARY KEY (id));",
"CREATE TABLE user_role (id INTEGER NOT NULL , user INTEGER NOT NULL,role INTEGER NOT NULL, PRIMARY KEY (id));",
"CREATE TABLE role (id INTEGER NOT NULL , rolename VARCHAR(255) NOT NULL, PRIMARY KEY (id)) ;",
"CREATE TABLE user (id INTEGER NOT NULL , username VARCHAR(255) NOT NULL,password VARCHAR(255) NOT NULL, emailupdates TINYINT, PRIMARY KEY (id));",
"SELECT id FROM ? ORDER BY id DESC LIMIT 1",
"INSERT INTO user VALUES (?, ?, ?, ?)",
"INSERT INTO role VALUES (?, ?)",
"INSERT INTO user_role VALUES (?, (SELECT id FROM user WHERE username = ?), (SELECT id FROM role WHERE rolename = ?))",
"INSERT INTO permissions VALUES (?, (SELECT id FROM role WHERE rolename = ?), ?, ?)" };
// works for postgreSQL
private static final String[] POSTGRESQL_SQL = {
"CREATE TABLE \"permissions\" (\"id\" INTEGER NOT NULL , \"role\" INTEGER NOT NULL,\"permission\" VARCHAR(255) NOT NULL, \"flags\" INTEGER, PRIMARY KEY (\"id\"));",
"CREATE TABLE \"user_role\" (\"id\" INTEGER NOT NULL , \"user\" INTEGER NOT NULL,\"role\" INTEGER NOT NULL, PRIMARY KEY (\"id\"));",
"CREATE TABLE \"role\" (\"id\" INTEGER NOT NULL , \"rolename\" VARCHAR(255) NOT NULL, PRIMARY KEY (\"id\")) ;",
"CREATE TABLE \"user\" (\"id\" INTEGER NOT NULL , \"username\" VARCHAR(255) NOT NULL,\"password\" VARCHAR(255) NOT NULL, \"emailupdates\" BOOLEAN, PRIMARY KEY (\"id\"));",
"SELECT id FROM \"?\" ORDER BY id DESC LIMIT 1",
"INSERT INTO \"user\" VALUES (?, ?, ?, ?)",
"INSERT INTO \"role\" VALUES (?, ?)",
"INSERT INTO \"user_role\" VALUES (?, (SELECT id FROM \"user\" WHERE username = ?), (SELECT id FROM \"role\" WHERE rolename = ?))",
"INSERT INTO \"permissions\" VALUES (?, (SELECT id FROM \"role\" WHERE rolename = ?), ?, ?)" };
private static final String[] SQL;
private DatabaseAuthenticator databaseAuthenticator;
static {
final String databaseType = getDatabaseType();
if ("postgresql".equalsIgnoreCase(databaseType)) {
SQL = POSTGRESQL_SQL;
} else if ("mysql".equalsIgnoreCase(databaseType)) {
SQL = MYSQL_SQL;
} else {
SQL = HSQLDB_SQL;
}
}
private static String getDatabaseType() {
try {
HibernateUtil.startTransaction();
final DatabaseMetaData dbm = HibernateUtil.getCurrentSession().connection().getMetaData();
HibernateUtil.commitTransaction();
final String dbURL = dbm.getURL();
final Pattern pattern = Pattern.compile("(.*jdbc\\:)([^\\:]*)(\\:.*)");
final Matcher matcher = pattern.matcher(dbURL);
if (matcher.matches()) {
return matcher.group(2);
}
} catch (final Exception e) {
throw new NakedObjectException(e);
}
return null;
}
private void createTable(final String createSQL) {
try {
HibernateUtil.startTransaction();
final SQLQuery sq = HibernateUtil.getCurrentSession().createSQLQuery(createSQL);
sq.executeUpdate();
HibernateUtil.commitTransaction();
} catch (final Exception e) {
HibernateUtil.rollbackTransaction();
}
}
private void createPermissionsTable() {
final String createTable = SQL[PERMISSIONS];
createTable(createTable);
}
private void createUserRoleTable() {
final String createTable = SQL[USER_ROLE];
createTable(createTable);
}
private void createRoleTable() {
final String createTable = SQL[ROLE];
createTable(createTable);
}
private void createUserTable() {
final String createTable = SQL[USER];
createTable(createTable);
}
private int getNextId(final String fromTable) {
try {
HibernateUtil.startTransaction();
final String tableSQL = SQL[GET_ID].replace("?", fromTable);
final SQLQuery sq = HibernateUtil.getCurrentSession().createSQLQuery(tableSQL);
final Integer id = (Integer) sq.uniqueResult();
HibernateUtil.commitTransaction();
return id != null ? id.intValue() + 1 : 0;
} catch (final Exception e) {
HibernateUtil.rollbackTransaction();
}
return 0;
}
private void insertUser(final String username, final String password) {
try {
final int nextId = getNextId("user");
HibernateUtil.startTransaction();
final SQLQuery sq = HibernateUtil.getCurrentSession().createSQLQuery(SQL[INSERT_USER]);
sq.setInteger(0, nextId);
sq.setString(1, username);
sq.setString(2, databaseAuthenticator.generateHash(password));
sq.setBoolean(3, false);
sq.executeUpdate();
HibernateUtil.commitTransaction();
} catch (final Exception e) {
HibernateUtil.rollbackTransaction();
}
}
private void insertRole(final String role) {
try {
final int nextId = getNextId("role");
HibernateUtil.startTransaction();
final SQLQuery sq = HibernateUtil.getCurrentSession().createSQLQuery(SQL[INSERT_ROLE]);
sq.setInteger(0, nextId);
sq.setString(1, role);
sq.executeUpdate();
HibernateUtil.commitTransaction();
} catch (final Exception e) {
HibernateUtil.rollbackTransaction();
}
}
private void insertUserRole(final String user, final String role) {
try {
final int nextId = getNextId("user_role");
HibernateUtil.startTransaction();
final SQLQuery sq = HibernateUtil.getCurrentSession().createSQLQuery(SQL[INSERT_USER_ROLE]);
sq.setInteger(0, nextId);
sq.setString(1, user);
sq.setString(2, role);
sq.executeUpdate();
HibernateUtil.commitTransaction();
} catch (final Exception e) {
HibernateUtil.rollbackTransaction();
}
}
private void insertPermission(final String role, final String permission) {
insertPermission(role, permission, null);
}
private void insertPermission(final String role, final String permission, final Integer flag) {
try {
final int nextId = getNextId("permissions");
HibernateUtil.startTransaction();
final SQLQuery sq = HibernateUtil.getCurrentSession().createSQLQuery(SQL[INSERT_PERMISSION]);
sq.setInteger(0, nextId);
sq.setString(1, role);
sq.setString(2, permission);
if (flag == null) {
sq.setParameter(3, null, Hibernate.INTEGER);
} else {
sq.setInteger(3, flag.intValue());
}
sq.executeUpdate();
HibernateUtil.commitTransaction();
} catch (final Exception e) {
HibernateUtil.rollbackTransaction();
}
}
private void insertPermissions() {
// actions
// common
insertPermission("claimant", "org.nakedobjects.example.expenses.employee.EmployeeStartPoints");
insertPermission("claimant", "org.nakedobjects.example.expenses.employee.Employee");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#returnToClaimant(java.lang.String)");
insertPermission("claimant", "org.nakedobjects.example.expenses.recordedAction.impl.RecordedAction");
insertPermission("approver", "org.nakedobjects.example.expenses.employee.EmployeeStartPoints");
insertPermission("approver", "org.nakedobjects.example.expenses.employee.Employee");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#returnToClaimant(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.recordedAction.impl.RecordedAction");
// approver
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ClaimStartPoints#claimsAwaitingMyApproval()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#approveItems(boolean)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#queryItems(java.lang.String,boolean)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#rejectItems(java.lang.String,boolean)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#approve()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#query(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#reject(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#approve()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#query(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#reject(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#approve()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#query(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#reject(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#approve()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#query(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#reject(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#approve()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#query(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#reject(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#approve()");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#query(java.lang.String)");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#reject(java.lang.String)");
// claimant
insertPermission("claimant", "org.nakedobjects.example.expenses.services.hibernate.EmployeeRepositoryHibernate");
insertPermission("claimant", "org.nakedobjects.example.expenses.recordedAction.impl.RecordedActionContributedActions");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ClaimStartPoints#myRecentClaims()");
insertPermission(
"claimant",
"org.nakedobjects.example.expenses.claims.ClaimStartPoints#findMyClaims(org.nakedobjects.example.expenses.claims.ClaimStatus,java.lang.String)");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ClaimStartPoints#createNewClaim(java.lang.String)");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.Claim#createNewExpenseItem(org.nakedobjects.example.expenses.claims.ExpenseType)");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.Claim#copyAnExistingExpenseItem(org.nakedobjects.example.expenses.claims.ExpenseItem)");
insertPermission(
"claimant",
"org.nakedobjects.example.expenses.claims.Claim#copyAllExpenseItemsFromAnotherClaim(org.nakedobjects.example.expenses.claims.Claim,org.nakedobjects.applib.value.Date)");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.Claim#createNewClaimFromThis(java.lang.String,org.nakedobjects.applib.value.Date)");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.Claim#submit(org.nakedobjects.example.expenses.employee.Employee,boolean)");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#findSimilarExpenseItems()");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#copyFrom(org.nakedobjects.example.expenses.claims.ExpenseItem)");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#findSimilarExpenseItems()");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.items.GeneralExpense#copyFrom(org.nakedobjects.example.expenses.claims.ExpenseItem)");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#findSimilarExpenseItems()");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.items.Airfare#copyFrom(org.nakedobjects.example.expenses.claims.ExpenseItem)");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#findSimilarExpenseItems()");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.items.Taxi#copyFrom(org.nakedobjects.example.expenses.claims.ExpenseItem)");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#findSimilarExpenseItems()");
insertPermission("claimant",
"org.nakedobjects.example.expenses.claims.items.Hotel#copyFrom(org.nakedobjects.example.expenses.claims.ExpenseItem)");
// fields
// common
insertPermission("claimant", "org.nakedobjects.example.expenses.currency.Currency");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ProjectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#dateCreated");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#claimant");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#approver");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#total");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.Claim#expenseItems");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ExpenseItem#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ExpenseItem#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ExpenseItem#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ExpenseItem#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.ExpenseItem#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#origin");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#destination");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#returnJourney");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#totalMiles");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#mileageRate");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#comment");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#comment");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#origin");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#destination");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#returnJourney");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#airlineAndFlight");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#comment");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Airfare#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#origin");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#destination");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#returnJourney");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#comment");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Taxi#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#hotelURL");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#numberOfNights");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#accommodation");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#food");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#other");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.Hotel#comment");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#dateIncurred");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#description");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#amount");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#projectCode");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#status");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#comment");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#rentalCompany");
insertPermission("claimant", "org.nakedobjects.example.expenses.claims.items.CarRental#numberOfDays");
insertPermission("approver", "org.nakedobjects.example.expenses.currency.Currency");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ProjectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#dateCreated");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#approver");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#approver");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#total");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.Claim#expenseItems");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ExpenseItem#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ExpenseItem#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ExpenseItem#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ExpenseItem#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.ExpenseItem#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#origin");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#destination");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#returnJourney");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#totalMiles");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#mileageRate");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#comment");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.PrivateCarJourney#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.GeneralExpense#comment");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#origin");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#destination");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#returnJourney");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#airlineAndFlight");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#comment");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Airfare#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#origin");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#destination");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#returnJourney");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#comment");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Taxi#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#hotelURL");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#numberOfNights");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#accommodation");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#food");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#other");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.Hotel#comment");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#dateIncurred");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#description");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#amount");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#projectCode");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#status");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#comment");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#rentalCompany");
insertPermission("approver", "org.nakedobjects.example.expenses.claims.items.CarRental#numberOfDays");
}
public void install() {
// needed to generate hashes of passwords shortly
databaseAuthenticator = new DatabaseAuthenticator(NakedObjectsContext.getConfiguration());
createUserTable();
createRoleTable();
createUserRoleTable();
createPermissionsTable();
insertUser("sven", "pass");
insertUser("dick", "pass");
insertUser("bob", "pass");
insertUser("joe", "pass");
insertRole("claimant");
insertRole("approver");
insertUserRole("sven", "claimant");
insertUserRole("dick", "claimant");
insertUserRole("bob", "claimant");
insertUserRole("joe", "claimant");
insertUserRole("dick", "approver");
insertPermissions();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy