Search in sources :

Example 16 with User

use of org.olat.core.id.User in project OpenOLAT by OpenOLAT.

the class QuestionItemDocumentFactory method createDocument.

public Document createDocument(SearchResourceContext searchResourceContext, QuestionItemFull item) {
    OlatDocument oDocument = new OlatDocument();
    oDocument.setId(item.getKey());
    oDocument.setCreatedDate(item.getCreationDate());
    oDocument.setLastChange(item.getLastModified());
    oDocument.setTitle(item.getTitle());
    oDocument.setDescription(item.getDescription());
    oDocument.setResourceUrl(getResourceUrl(item.getKey()));
    oDocument.setDocumentType(QItemDocument.TYPE);
    oDocument.setCssIcon("o_qitem_icon");
    oDocument.setParentContextType(searchResourceContext.getParentContextType());
    oDocument.setParentContextName(searchResourceContext.getParentContextName());
    // author
    StringBuilder authorSb = new StringBuilder();
    List<Identity> owners = qpoolService.getAuthors(item);
    for (Identity owner : owners) {
        User user = owner.getUser();
        authorSb.append(user.getProperty(UserConstants.FIRSTNAME, null)).append(" ").append(user.getProperty(UserConstants.LASTNAME, null)).append(" ");
    }
    oDocument.setAuthor(authorSb.toString());
    // add specific fields
    Document document = oDocument.getLuceneDocument();
    // content
    QPoolSPI provider = qpoolModule.getQuestionPoolProvider(item.getFormat());
    if (provider != null) {
        String content = provider.extractTextContent(item);
        if (content != null) {
            addStringField(document, AbstractOlatDocument.CONTENT_FIELD_NAME, content, 0.8f);
        }
    }
    if (item.getDescription() != null) {
        addStringField(document, AbstractOlatDocument.CONTENT_FIELD_NAME, item.getDescription(), 1.0f);
    }
    // general fields
    addStringField(document, QItemDocument.IDENTIFIER_FIELD, item.getIdentifier(), 1.0f);
    addStringField(document, QItemDocument.MASTER_IDENTIFIER_FIELD, item.getMasterIdentifier(), 1.0f);
    addTextField(document, QItemDocument.KEYWORDS_FIELD, item.getKeywords(), 2.0f);
    addTextField(document, QItemDocument.COVERAGE_FIELD, item.getCoverage(), 2.0f);
    addTextField(document, QItemDocument.ADD_INFOS_FIELD, item.getAdditionalInformations(), 2.0f);
    addStringField(document, QItemDocument.LANGUAGE_FIELD, item.getLanguage(), 1.0f);
    addTextField(document, QItemDocument.TOPIC_FIELD, item.getTopic(), 2.0f);
    // educational
    if (qpoolModule.isEducationalContextEnabled()) {
        if (item.getEducationalContext() != null) {
            String context = item.getEducationalContext().getLevel();
            addStringField(document, QItemDocument.EDU_CONTEXT_FIELD, context, 1.0f);
        }
    }
    // question
    if (item.getType() != null) {
        String itemType = item.getType().getType();
        addStringField(document, QItemDocument.ITEM_TYPE_FIELD, itemType, 1.0f);
    }
    addStringField(document, QItemDocument.ASSESSMENT_TYPE_FIELD, item.getAssessmentType(), 1.0f);
    // lifecycle
    addStringField(document, QItemDocument.ITEM_VERSION_FIELD, item.getItemVersion(), 1.0f);
    if (item.getQuestionStatus() != null) {
        addStringField(document, QItemDocument.ITEM_STATUS_FIELD, item.getQuestionStatus().name(), 1.0f);
    }
    // rights
    ResourceLicense license = licenseService.loadLicense(item);
    if (license != null && license.getLicenseType() != null) {
        String licenseKey = String.valueOf(license.getLicenseType().getKey());
        addTextField(document, QItemDocument.LICENSE_TYPE_FIELD_NAME, licenseKey, 2.0f);
    }
    // technical
    addTextField(document, QItemDocument.EDITOR_FIELD, item.getEditor(), 2.0f);
    addStringField(document, QItemDocument.EDITOR_VERSION_FIELD, item.getEditorVersion(), 1.0f);
    addStringField(document, QItemDocument.FORMAT_FIELD, item.getFormat(), 1.0f);
    // save owners key
    for (Identity owner : owners) {
        document.add(new StringField(QItemDocument.OWNER_FIELD, owner.getKey().toString(), Field.Store.NO));
    }
    // link resources
    List<OLATResource> resources = questionItemDao.getSharedResources(item);
    for (OLATResource resource : resources) {
        document.add(new StringField(QItemDocument.SHARE_FIELD, resource.getKey().toString(), Field.Store.NO));
    }
    // need pools
    List<Pool> pools = poolDao.getPools(item);
    for (Pool pool : pools) {
        document.add(new StringField(QItemDocument.POOL_FIELD, pool.getKey().toString(), Field.Store.NO));
    }
    // need path
    if (qpoolModule.isTaxonomyEnabled()) {
        String path = item.getTaxonomicPath();
        if (StringHelper.containsNonWhitespace(path)) {
            for (StringTokenizer tokenizer = new StringTokenizer(path, "/"); tokenizer.hasMoreTokens(); ) {
                String nextToken = tokenizer.nextToken();
                document.add(new TextField(QItemDocument.TAXONOMIC_PATH_FIELD, nextToken, Field.Store.NO));
            }
            if (item instanceof QuestionItemImpl) {
                Long key = ((QuestionItemImpl) item).getTaxonomyLevel().getKey();
                TextField field = new TextField(QItemDocument.TAXONOMIC_FIELD, key.toString(), Field.Store.YES);
                field.setBoost(3.0f);
                document.add(field);
            }
        }
    }
    return document;
}
Also used : User(org.olat.core.id.User) QuestionItemImpl(org.olat.modules.qpool.model.QuestionItemImpl) OLATResource(org.olat.resource.OLATResource) Document(org.apache.lucene.document.Document) AbstractOlatDocument(org.olat.search.model.AbstractOlatDocument) OlatDocument(org.olat.search.model.OlatDocument) QItemDocument(org.olat.modules.qpool.model.QItemDocument) ResourceLicense(org.olat.core.commons.services.license.ResourceLicense) AbstractOlatDocument(org.olat.search.model.AbstractOlatDocument) OlatDocument(org.olat.search.model.OlatDocument) StringTokenizer(java.util.StringTokenizer) QPoolSPI(org.olat.modules.qpool.QPoolSPI) StringField(org.apache.lucene.document.StringField) TextField(org.apache.lucene.document.TextField) Pool(org.olat.modules.qpool.Pool) Identity(org.olat.core.id.Identity)

Example 17 with User

use of org.olat.core.id.User in project OpenOLAT by OpenOLAT.

the class InvitationDAO method update.

public Invitation update(Invitation invitation, String firstName, String lastName, String email) {
    List<Identity> identities = groupDao.getMembers(invitation.getBaseGroup(), GroupRoles.invitee.name());
    for (Identity identity : identities) {
        User user = identity.getUser();
        if (email.equals(user.getEmail())) {
            user.setProperty(UserConstants.FIRSTNAME, firstName);
            user.setProperty(UserConstants.LASTNAME, lastName);
            user.setProperty(UserConstants.EMAIL, email);
            userManager.updateUserFromIdentity(identity);
        }
    }
    invitation.setFirstName(firstName);
    invitation.setLastName(lastName);
    invitation.setMail(email);
    return dbInstance.getCurrentEntityManager().merge(invitation);
}
Also used : User(org.olat.core.id.User) Identity(org.olat.core.id.Identity)

Example 18 with User

use of org.olat.core.id.User in project OpenOLAT by OpenOLAT.

the class InvitationDAO method loadOrCreateIdentityAndPersistInvitation.

public Identity loadOrCreateIdentityAndPersistInvitation(Invitation invitation, Group group, Locale locale) {
    group = groupDao.loadGroup(group.getKey());
    ((InvitationImpl) invitation).setCreationDate(new Date());
    ((InvitationImpl) invitation).setBaseGroup(group);
    dbInstance.getCurrentEntityManager().persist(invitation);
    // create identity only if such a user does not already exist
    Identity invitee = userManager.findUniqueIdentityByEmail(invitation.getMail());
    if (invitee == null) {
        String tempUsername = UUID.randomUUID().toString();
        User user = userManager.createUser(invitation.getFirstName(), invitation.getLastName(), invitation.getMail());
        user.getPreferences().setLanguage(locale.toString());
        invitee = securityManager.createAndPersistIdentityAndUser(tempUsername, null, user, null, null, null);
    }
    // add invitee to the security group of that portfolio element
    groupDao.addMembershipTwoWay(group, invitee, GroupRoles.invitee.name());
    return invitee;
}
Also used : User(org.olat.core.id.User) InvitationImpl(org.olat.portfolio.model.InvitationImpl) Identity(org.olat.core.id.Identity) Date(java.util.Date)

Example 19 with User

use of org.olat.core.id.User in project OpenOLAT by OpenOLAT.

the class GetIdentitiesByPowerSearchTest method testGetIdentitiesByPowerSearch_multipleUserProperties.

@Test
public void testGetIdentitiesByPowerSearch_multipleUserProperties() {
    String multi = "multi" + UUID.randomUUID().toString().replace("-", "");
    String multiInst = "multiinst" + UUID.randomUUID().toString().replace("-", "");
    String multiUsername = "multiPropUser-" + UUID.randomUUID();
    User user = UserManager.getInstance().createUser("multipropuser", "multipropuser", multi + "@lustig.com");
    user.setProperty(UserConstants.FIRSTNAME, "multi");
    user.setProperty(UserConstants.LASTNAME, "prop");
    user.setProperty(UserConstants.INSTITUTIONALNAME, "multiinst");
    user.setProperty(UserConstants.INSTITUTIONALEMAIL, multiInst + "@lustig.com");
    user.setProperty(UserConstants.INSTITUTIONALUSERIDENTIFIER, multiInst);
    user.setProperty(UserConstants.CITY, "züri");
    Identity identity = baseSecurityManager.createAndPersistIdentityAndUser(multiUsername, null, user, BaseSecurityModule.getDefaultAuthProviderIdentifier(), multiUsername, "ppp");
    Assert.assertNotNull(identity);
    // commit
    dbInstance.commitAndCloseSession();
    HashMap<String, String> userProperties = new HashMap<String, String>();
    userProperties.put(UserConstants.FIRSTNAME, "multi");
    List<Identity> results = baseSecurityManager.getIdentitiesByPowerSearch(null, userProperties, true, null, null, null, null, null, null, null, null);
    sysoutResults(results);
    Assert.assertTrue(results.contains(identity));
    long countResults = baseSecurityManager.countIdentitiesByPowerSearch(null, userProperties, true, null, null, null, null, null, null, null, null);
    Assert.assertEquals(results.size(), countResults);
    userProperties = new HashMap<String, String>();
    userProperties.put(UserConstants.FIRSTNAME, "multi");
    userProperties.put(UserConstants.LASTNAME, "prop");
    results = baseSecurityManager.getIdentitiesByPowerSearch(null, userProperties, true, null, null, null, null, null, null, null, null);
    Assert.assertTrue(results.contains(identity));
    userProperties = new HashMap<String, String>();
    userProperties.put(UserConstants.FIRSTNAME, "multi");
    userProperties.put(UserConstants.LASTNAME, "prop");
    userProperties.put(UserConstants.INSTITUTIONALNAME, "multiinst");
    results = baseSecurityManager.getIdentitiesByPowerSearch(null, userProperties, true, null, null, null, null, null, null, null, null);
    Assert.assertTrue(results.contains(identity));
    userProperties = new HashMap<String, String>();
    userProperties.put(UserConstants.FIRSTNAME, "multi");
    userProperties.put(UserConstants.LASTNAME, "prop");
    userProperties.put(UserConstants.INSTITUTIONALNAME, "multiinst");
    userProperties.put(UserConstants.INSTITUTIONALEMAIL, multiInst + "@lustig.com");
    results = baseSecurityManager.getIdentitiesByPowerSearch(null, userProperties, true, null, null, null, null, null, null, null, null);
    Assert.assertEquals(1, results.size());
    Assert.assertTrue(results.contains(identity));
    userProperties = new HashMap<String, String>();
    userProperties.put(UserConstants.FIRSTNAME, "multi");
    userProperties.put(UserConstants.LASTNAME, "prop");
    userProperties.put(UserConstants.INSTITUTIONALNAME, "multiinst");
    userProperties.put(UserConstants.INSTITUTIONALEMAIL, multiInst + "@lustig.com");
    userProperties.put(UserConstants.INSTITUTIONALUSERIDENTIFIER, multiInst);
    userProperties.put(UserConstants.CITY, "züri");
    results = baseSecurityManager.getIdentitiesByPowerSearch(null, userProperties, true, null, null, null, null, null, null, null, null);
    Assert.assertEquals(1, results.size());
    Assert.assertTrue(results.contains(identity));
}
Also used : User(org.olat.core.id.User) HashMap(java.util.HashMap) Identity(org.olat.core.id.Identity) Test(org.junit.Test)

Example 20 with User

use of org.olat.core.id.User in project OpenOLAT by OpenOLAT.

the class EmailProperty method isAddressAvailable.

private boolean isAddressAvailable(String emailAddress, String currentUsername) {
    User currentUser = null;
    Identity currentIdentity;
    if (currentUsername != null) {
        currentIdentity = BaseSecurityManager.getInstance().findIdentityByName(currentUsername);
        if (currentIdentity != null) {
            currentUser = currentIdentity.getUser();
        }
    }
    return UserManager.getInstance().isEmailAllowed(emailAddress, currentUser);
}
Also used : User(org.olat.core.id.User) Identity(org.olat.core.id.Identity)

Aggregations

User (org.olat.core.id.User)260 Identity (org.olat.core.id.Identity)126 Test (org.junit.Test)82 UserPropertyHandler (org.olat.user.propertyhandlers.UserPropertyHandler)52 HashMap (java.util.HashMap)28 Translator (org.olat.core.gui.translator.Translator)26 SecurityGroup (org.olat.basesecurity.SecurityGroup)20 Date (java.util.Date)18 ArrayList (java.util.ArrayList)16 Locale (java.util.Locale)16 FormItem (org.olat.core.gui.components.form.flexible.FormItem)16 File (java.io.File)14 VelocityContext (org.apache.velocity.VelocityContext)14 MailTemplate (org.olat.core.util.mail.MailTemplate)12 LDAPUser (org.olat.ldap.model.LDAPUser)12 UserManager (org.olat.user.UserManager)12 IOException (java.io.IOException)10 Map (java.util.Map)10 List (java.util.List)8 CloseableModalController (org.olat.core.gui.control.generic.closablewrapper.CloseableModalController)8