001    /*
002     * $Id: UserNameStore.java 1387 2006-09-11 22:37:44Z rbair $
003     *
004     * Copyright 2004 Sun Microsystems, Inc., 4150 Network Circle,
005     * Santa Clara, California 95054, U.S.A. All rights reserved.
006     *
007     * This library is free software; you can redistribute it and/or
008     * modify it under the terms of the GNU Lesser General Public
009     * License as published by the Free Software Foundation; either
010     * version 2.1 of the License, or (at your option) any later version.
011     *
012     * This library is distributed in the hope that it will be useful,
013     * but WITHOUT ANY WARRANTY; without even the implied warranty of
014     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
015     * Lesser General Public License for more details.
016     *
017     * You should have received a copy of the GNU Lesser General Public
018     * License along with this library; if not, write to the Free Software
019     * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
020     */
021    package org.jdesktop.swingx.auth;
022    
023    import org.jdesktop.beans.AbstractBean;
024    
025    /**
026     * <b>UsernameStore</b> is a class that implements persistence of usernames
027     *
028     * @author Bino George
029     * @author rbair
030     */
031    public abstract class UserNameStore extends AbstractBean {
032        /**
033         * Gets the current list of users.
034         */
035        public abstract String[] getUserNames();
036        /**
037         */
038        public abstract void setUserNames(String[] names);
039        /**
040         * lifecycle method for loading names from persistent storage
041         */
042        public abstract void loadUserNames();
043        /**
044         * lifecycle method for saving name to persistent storage
045         */
046        public abstract void saveUserNames();
047        /**
048         */
049        public abstract boolean containsUserName(String name);
050        
051        /**
052         * Add a username to the store.
053         * @param userName
054         */
055        public abstract void addUserName(String userName);
056        
057        /**
058         * Removes a username from the list.
059         * @param userName
060         */
061        public abstract void removeUserName(String userName);
062    }