001/*
002 *  Copyright 2016 Anyware Services
003 *
004 *  Licensed under the Apache License, Version 2.0 (the "License");
005 *  you may not use this file except in compliance with the License.
006 *  You may obtain a copy of the License at
007 *
008 *      http://www.apache.org/licenses/LICENSE-2.0
009 *
010 *  Unless required by applicable law or agreed to in writing, software
011 *  distributed under the License is distributed on an "AS IS" BASIS,
012 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
013 *  See the License for the specific language governing permissions and
014 *  limitations under the License.
015 */
016package org.ametys.plugins.core.right.profile;
017
018import org.apache.avalon.framework.service.ServiceException;
019import org.apache.avalon.framework.service.ServiceManager;
020
021import org.ametys.core.right.Profile;
022import org.ametys.core.right.RightManager;
023import org.ametys.core.right.RightProfilesDAO;
024import org.ametys.core.script.SqlTablesInit;
025
026/**
027 * Creates the READER profile at initialization.
028 */
029public class CreateReaderProfileInit extends SqlTablesInit
030{
031    private RightProfilesDAO _profilesDAO;
032    
033    @Override
034    public void service(ServiceManager manager) throws ServiceException
035    {
036        super.service(manager);
037        _profilesDAO = (RightProfilesDAO) manager.lookup(RightProfilesDAO.ROLE);
038    }
039    
040    @Override
041    public void init() throws Exception
042    {
043        // First create the needed tables for rights, in case the Init extension "org.ametys.core.script.profile.SqlTablesInit" is not called before this one
044        super.init();
045        
046        // Then do the job: create the reader profile
047        if (_profilesDAO.getProfile(RightManager.READER_PROFILE_ID) != null)
048        {
049            // already exist
050            getLogger().info("READER profile already exists, it will not be created");
051            return;
052        }
053        
054        getLogger().info("Creating READER profile");
055        String profileName = RightManager.READER_PROFILE_ID; // We give the same name as its id
056        
057        Profile profile = new Profile(RightManager.READER_PROFILE_ID, profileName);
058        _profilesDAO.addProfile(profile, true);
059    }
060}