import gr.ebs.gss.server.domain.Nonce;
import gr.ebs.gss.server.domain.User;
import gr.ebs.gss.server.domain.UserClass;
+import gr.ebs.gss.server.domain.UserLogin;
import java.util.Date;
import java.util.List;
public List<Group> getGroups(Long userId) throws ObjectNotFoundException;
/**
+ * Retrieves the root folder id for the specified user. The caller must ensure
+ * that the userId exists.
+ *
+ * @param userId
+ * @return Long The id
+ * @throws ObjectNotFoundException if no Folder was found
+ */
+ public Long getRootFolderId(final Long userId) throws ObjectNotFoundException;
+
+ /**
* Retrieves the root folder for the specified user. The caller must ensure
* that the userId exists.
*
public Nonce getNonce(String nonce, Long userId) throws ObjectNotFoundException;
/**
- * Loads the file for indexing. That means the file is loaded with the lazy fields needed for inedexing, initialized.
- * For now only the tags need to be initialized
- *
- * @param id
- * @return the {@link FileHeader} with initialized tags
- * @throws ObjectNotFoundException when a file with the specified id does not exist
- */
- public FileHeader getFileForIndexing(Long id) throws ObjectNotFoundException;
-
- /**
* Calculates total file size of user.
*
* @param userId the ID of the user
*/
public List<FileHeader> getFilesPermittedForGroup(Long userId, Long groupId) throws ObjectNotFoundException;
+ /**
+ * Gets a file with tags initialized, cause indexing does not always run within a transaction (e.g. during rebuild)
+ *
+ * @param id
+ * @return
+ * @throws ObjectNotFoundException
+ */
+ public FileHeader getFileForIndexing(Long id) throws ObjectNotFoundException;
+
/**
* @param userId
* @return
* @return
*/
int deletePermissionsNotCorrespondingToFilesAndFolders(Long userId);
+
+ /**
+ * Returns a list of the top two entries related to the date that a user logged in the service.
+ * The first entry is related to the current session user login
+ * and the latter is related to the user's last login
+ *
+ * @param userId
+ * @return a list of last user login and the current session user login
+ */
+ public List<UserLogin> getLoginsForUser (Long userId);
/**
- *
+ * Returns a list of all entries related to the date that a user logged in the service.
+ *
+ * @param userId
+ * @return a list of last user login and the current session user login
+ */
+ public List<UserLogin> getAllLoginsForUser (Long userId);
+
+ /**
+ * Returns the user matching with the specified username
+ *
+ * @param username the email of the User
+ * @return User
*/
- void fixSharedFlagForAllFoldersAndFiles();
+ public User getUserByUserName(String username);
}