--- /dev/null
+/*****************************************************************************
+ * Copyright Igor Barma, Eric Brun, Alexandre Desoubeaux, Christian Martel,
+ * (2 décembre 2008)
+ *
+ * Ce logiciel est un programme informatique servant à l'évaluation des
+ * compétences.
+ *
+ * Ce logiciel est régi par la licence CeCILL soumise au droit français et
+ * respectant les principes de diffusion des logiciels libres. Vous pouvez
+ * utiliser, modifier et/ou redistribuer ce programme sous les conditions
+ * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
+ * sur le site "http://www.cecill.info".
+ *
+ * En contrepartie de l'accessibilité au code source et des droits de copie,
+ * de modification et de redistribution accordés par cette licence, il n'est
+ * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
+ * seule une responsabilité restreinte pèse sur l'auteur du programme, le
+ * titulaire des droits patrimoniaux et les concédants successifs.
+ *
+ * A cet égard l'attention de l'utilisateur est attirée sur les risques
+ * associés au chargement, à l'utilisation, à la modification et/ou au
+ * développement et à la reproduction du logiciel par l'utilisateur étant
+ * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
+ * manipuler et qui le réserve donc à des développeurs et des professionnels
+ * avertis possédant des connaissances informatiques approfondies. Les
+ * utilisateurs sont donc invités à charger et tester l'adéquation du
+ * logiciel à leurs besoins dans des conditions permettant d'assurer la
+ * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
+ * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
+ *
+ * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
+ * pris connaissance de la licence CeCILL, et que vous en avez accepté les
+ * termes.
+ *******************************************************************************/
+package com.pentila.evalcomp.ldap.impl;
+
+import javax.naming.directory.BasicAttribute;
+
+import org.springframework.ldap.core.ContextMapper;
+import org.springframework.ldap.core.DirContextAdapter;
+
+import com.pentila.evalcomp.domain.User;
+import com.pentila.evalcomp.ldap.LdapMapper;
+
+// TODO: Auto-generated Javadoc
+/**
+ * The Class UserContextMapper.
+ */
+public class UserContextMapper implements ContextMapper {
+
+ /**
+ * Map user to context. It defines and it maps the attributes with their
+ * values.
+ *
+ * @param user
+ * the user object to be mapped
+ * @param context
+ * the context object where the mapping will be saved
+ * @param isNew
+ * specifies if this user is a new user that wasn't found in ldap
+ * in which case it must be specified the attribute : objectClass
+ * in order to save this context object.
+ */
+ public static void mapToContext(User user, DirContextAdapter context,
+ boolean isNew) {
+ if (isNew) {
+ context.setAttributeValues("objectclass",
+ LdapMapper.getUserObjectClass());
+ }
+ context.setAttributeValue(LdapMapper.getLoginAttr(), user.getUid());
+ context.setAttributeValue(LdapMapper.getCnSymbol(), user.getLastname()
+ + " " + user.getFirstname());
+ context.setAttributeValue(LdapMapper.getEmailAttribute(),
+ user.getEmail());
+ context.setAttributeValue(LdapMapper.getFirstNameAttribute(),
+ user.getFirstname());
+ context.setAttributeValue(LdapMapper.getLastNameAttribute(),
+ user.getLastname());
+
+ if (user.getPassword() != null && !user.getPassword().equals("")) {
+ BasicAttribute ba = new BasicAttribute("userPassword",
+ user.getPassword());
+ context.setAttribute(ba);
+ }
+ // how to set roles ???
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * org.springframework.ldap.core.ContextMapper#mapFromContext(java.lang.
+ * Object)
+ */
+ public Object mapFromContext(Object ctx) {
+ DirContextAdapter context = (DirContextAdapter) ctx;
+ User usr = new User();
+ usr.setEmail(context.getStringAttribute(LdapMapper.getEmailAttribute()));
+ usr.setFirstname(context.getStringAttribute(LdapMapper
+ .getFirstNameAttribute()));
+ usr.setLastname(context.getStringAttribute(LdapMapper
+ .getLastNameAttribute()));
+ usr.setUid(context.getStringAttribute(LdapMapper.getInternalUserId()));
+ return usr;
+ }
+}