use of org.activityinfo.server.database.hibernate.entity.UserDatabase in project activityinfo by bedatadriven.
the class UserDatabasePolicy method create.
@Override
public Object create(User user, PropertyMap properties) {
UserDatabase database = new UserDatabase();
database.setCountry(findCountry(properties));
database.setOwner(user);
applyProperties(database, properties);
databaseDAO.persist(database);
return database.getId();
}
use of org.activityinfo.server.database.hibernate.entity.UserDatabase in project activityinfo by bedatadriven.
the class ActivityPolicy method create.
@Override
public Object create(User user, PropertyMap properties) {
UserDatabase database = getDatabase(properties);
assertDesignPrivileges(user, database);
// create the entity
Activity activity = new Activity();
activity.setDatabase(database);
activity.setSortOrder(calculateNextSortOrderIndex(database.getId()));
activity.setLocationType(getLocationType(properties));
applyProperties(activity, properties);
activityDAO.persist(activity);
return activity.getId();
}
use of org.activityinfo.server.database.hibernate.entity.UserDatabase in project activityinfo by bedatadriven.
the class SchemaUpdateBuilder method createAndSyncPartnerInDatabase.
private void createAndSyncPartnerInDatabase(JpaUpdateBuilder builder) throws JSONException {
builder.executeStatement("create table if not exists PartnerInDatabase (DatabaseId integer, PartnerId int)");
builder.executeStatement("delete from PartnerInDatabase");
if (anyPartners()) {
builder.beginPreparedStatement("insert into PartnerInDatabase (DatabaseId, PartnerId) values (?, ?) ");
for (UserDatabase db : databases) {
for (Partner partner : db.getPartners()) {
builder.addExecution(db.getId(), partner.getId());
}
}
builder.finishPreparedStatement();
}
}
use of org.activityinfo.server.database.hibernate.entity.UserDatabase in project activityinfo by bedatadriven.
the class SchemaUpdateBuilder method makeEntityLists.
private void makeEntityLists() {
for (UserDatabase database : databases) {
if (!userIds.contains(database.getOwner().getId())) {
User u = database.getOwner();
// don't send hashed password to client
// EEK i think hibernate will persist this to the database
// automatically if we change it here!!
// u.setHashedPassword("");
users.add(u);
userIds.add(u.getId());
}
if (!countryIds.contains(database.getCountry().getId())) {
countries.add(database.getCountry());
adminLevels.addAll(database.getCountry().getAdminLevels());
countryIds.add(database.getCountry().getId());
for (org.activityinfo.server.database.hibernate.entity.LocationType l : database.getCountry().getLocationTypes()) {
locationTypes.add(l);
}
}
for (Partner partner : database.getPartners()) {
if (!partnerIds.contains(partner.getId())) {
partners.add(partner);
partnerIds.add(partner.getId());
}
}
projects.addAll(new ArrayList<Project>(database.getProjects()));
allLockedPeriods.addAll(database.getLockedPeriods());
for (Project project : database.getProjects()) {
allLockedPeriods.addAll(project.getLockedPeriods());
}
for (Activity activity : database.getActivities()) {
allLockedPeriods.addAll(activity.getLockedPeriods());
activities.add(activity);
for (Indicator indicator : activity.getIndicators()) {
indicators.add(indicator);
List<IndicatorLinkEntity> links = findIndicatorLinks(indicator);
if (links != null && !links.isEmpty()) {
indicatorLinks.addAll(links);
}
}
for (AttributeGroup g : activity.getAttributeGroups()) {
if (!attributeGroupIds.contains(g.getId())) {
attributeGroups.add(g);
attributeGroupIds.add(g.getId());
for (Attribute a : g.getAttributes()) {
attributes.add(a);
}
}
}
}
}
}
Aggregations