Search in sources :

Example 1 with RestApiClient

use of fi.otavanopisto.muikku.openfire.rest.client.RestApiClient in project muikku by otavanopisto.

the class ChatRoomSyncScheduler method updateChatRooms.

@Schedule(second = "*", minute = "*/15", hour = "*", persistent = false)
@TransactionAttribute(TransactionAttributeType.REQUIRED)
public void updateChatRooms() {
    String enabledWorkspacesCsv = pluginSettingsController.getPluginSetting("chat", "enabledWorkspaces");
    if (enabledWorkspacesCsv == null) {
        return;
    }
    List<String> enabledWorkspaces = Arrays.asList(enabledWorkspacesCsv.split(","));
    String openfireToken = pluginSettingsController.getPluginSetting("chat", "openfireToken");
    if (openfireToken == null) {
        logger.log(Level.INFO, "No openfire token set, skipping room sync");
        return;
    }
    String openfireUrl = pluginSettingsController.getPluginSetting("chat", "openfireUrl");
    if (openfireUrl == null) {
        logger.log(Level.INFO, "No openfire url set, skipping room sync");
        return;
    }
    String openfirePort = pluginSettingsController.getPluginSetting("chat", "openfirePort");
    if (openfirePort == null) {
        logger.log(Level.INFO, "No openfire port set, skipping room sync");
        return;
    }
    if (!StringUtils.isNumeric(openfirePort)) {
        logger.log(Level.WARNING, "Invalid openfire port, skipping room sync");
        return;
    }
    AuthenticationToken token = new AuthenticationToken(openfireToken);
    RestApiClient client = new RestApiClient(openfireUrl, Integer.parseInt(openfirePort, 10), token);
    for (String enabledWorkspace : enabledWorkspaces) {
        try {
            // Checking before creating is subject to a race condition, but in the worst case
            // the creation just fails, resulting in a log entry
            MUCRoomEntity chatRoomEntity = client.getChatRoom(enabledWorkspace);
            if (chatRoomEntity == null) {
                logger.log(Level.INFO, "Syncing chat workspace " + enabledWorkspace);
                SchoolDataIdentifier identifier = SchoolDataIdentifier.fromId(enabledWorkspace);
                if (identifier == null) {
                    logger.log(Level.WARNING, "Invalid workspace identifier " + enabledWorkspace + ", skipping...");
                    continue;
                }
                WorkspaceEntity workspaceEntity = workspaceEntityController.findWorkspaceByUrlName(enabledWorkspace);
                if (workspaceEntity == null) {
                    logger.log(Level.WARNING, "No workspace entity found for identifier " + enabledWorkspace + ", skipping...");
                    continue;
                }
                Workspace workspace = workspaceController.findWorkspace(workspaceEntity);
                chatRoomEntity = new MUCRoomEntity(enabledWorkspace, workspace.getName(), workspace.getDescription());
                client.createChatRoom(chatRoomEntity);
            }
        } catch (Exception e) {
            logger.log(Level.INFO, "Exception when syncing chat workspace " + enabledWorkspace, e);
        }
    }
}
Also used : SchoolDataIdentifier(fi.otavanopisto.muikku.schooldata.SchoolDataIdentifier) AuthenticationToken(fi.otavanopisto.muikku.openfire.rest.client.entity.AuthenticationToken) WorkspaceEntity(fi.otavanopisto.muikku.model.workspace.WorkspaceEntity) MUCRoomEntity(fi.otavanopisto.muikku.openfire.rest.client.entity.MUCRoomEntity) RestApiClient(fi.otavanopisto.muikku.openfire.rest.client.RestApiClient) Workspace(fi.otavanopisto.muikku.schooldata.entity.Workspace) TransactionAttribute(javax.ejb.TransactionAttribute) Schedule(javax.ejb.Schedule)

Example 2 with RestApiClient

use of fi.otavanopisto.muikku.openfire.rest.client.RestApiClient in project muikku by otavanopisto.

the class ChatUserSyncScheduler method updateChatUsers.

@Schedule(second = "0", minute = "*/15", hour = "*", persistent = false)
@TransactionAttribute(TransactionAttributeType.REQUIRED)
public void updateChatUsers() {
    String enabledUsersCsv = pluginSettingsController.getPluginSetting("chat", "enabledUsers");
    if (enabledUsersCsv == null) {
        return;
    }
    List<String> enabledUsers = Arrays.asList(enabledUsersCsv.split(","));
    String openfireToken = pluginSettingsController.getPluginSetting("chat", "openfireToken");
    if (openfireToken == null) {
        logger.log(Level.INFO, "No openfire token set, skipping user sync");
        return;
    }
    String openfireUrl = pluginSettingsController.getPluginSetting("chat", "openfireUrl");
    if (openfireUrl == null) {
        logger.log(Level.INFO, "No openfire url set, skipping user sync");
        return;
    }
    String openfirePort = pluginSettingsController.getPluginSetting("chat", "openfirePort");
    if (openfirePort == null) {
        logger.log(Level.INFO, "No openfire port set, skipping user sync");
        return;
    }
    if (!StringUtils.isNumeric(openfirePort)) {
        logger.log(Level.WARNING, "Invalid openfire port, skipping user sync");
        return;
    }
    AuthenticationToken token = new AuthenticationToken(openfireToken);
    RestApiClient client = new RestApiClient(openfireUrl, Integer.parseInt(openfirePort, 10), token);
    SecureRandom random = new SecureRandom();
    for (String enabledUser : enabledUsers) {
        try {
            // Checking before creating is subject to a race condition, but in the worst case
            // the creation just fails, resulting in a log entry
            UserEntity userEntity = client.getUser(enabledUser);
            if (userEntity == null) {
                logger.log(Level.INFO, "Syncing chat user " + enabledUser);
                SchoolDataIdentifier identifier = SchoolDataIdentifier.fromId(enabledUser);
                if (identifier == null) {
                    logger.log(Level.WARNING, "Invalid user identifier " + enabledUser + ", skipping...");
                    continue;
                }
                User user = userController.findUserByIdentifier(identifier);
                if (user == null) {
                    logger.log(Level.WARNING, "No user found for identifier " + enabledUser + ", skipping...");
                    continue;
                }
                // Can't leave the password empty, so next best thing is random passwords
                // The passwords are not actually used
                byte[] passwordBytes = new byte[20];
                random.nextBytes(passwordBytes);
                String password = Base64.encodeBase64String(passwordBytes);
                userEntity = new UserEntity(enabledUser, user.getDisplayName(), "", password);
                client.createUser(userEntity);
            }
        } catch (Exception e) {
            logger.log(Level.INFO, "Exception when syncing user " + enabledUser, e);
        }
    }
}
Also used : SchoolDataIdentifier(fi.otavanopisto.muikku.schooldata.SchoolDataIdentifier) AuthenticationToken(fi.otavanopisto.muikku.openfire.rest.client.entity.AuthenticationToken) User(fi.otavanopisto.muikku.schooldata.entity.User) SecureRandom(java.security.SecureRandom) RestApiClient(fi.otavanopisto.muikku.openfire.rest.client.RestApiClient) UserEntity(fi.otavanopisto.muikku.openfire.rest.client.entity.UserEntity) TransactionAttribute(javax.ejb.TransactionAttribute) Schedule(javax.ejb.Schedule)

Aggregations

RestApiClient (fi.otavanopisto.muikku.openfire.rest.client.RestApiClient)2 AuthenticationToken (fi.otavanopisto.muikku.openfire.rest.client.entity.AuthenticationToken)2 SchoolDataIdentifier (fi.otavanopisto.muikku.schooldata.SchoolDataIdentifier)2 Schedule (javax.ejb.Schedule)2 TransactionAttribute (javax.ejb.TransactionAttribute)2 WorkspaceEntity (fi.otavanopisto.muikku.model.workspace.WorkspaceEntity)1 MUCRoomEntity (fi.otavanopisto.muikku.openfire.rest.client.entity.MUCRoomEntity)1 UserEntity (fi.otavanopisto.muikku.openfire.rest.client.entity.UserEntity)1 User (fi.otavanopisto.muikku.schooldata.entity.User)1 Workspace (fi.otavanopisto.muikku.schooldata.entity.Workspace)1 SecureRandom (java.security.SecureRandom)1