All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.bonitasoft.engine.identity.RoleCreator Maven / Gradle / Ivy

There is a newer version: 10.2.0
Show newest version
/**
 * Copyright (C) 2019 Bonitasoft S.A.
 * Bonitasoft, 32 rue Gustave Eiffel - 38000 Grenoble
 * This library is free software; you can redistribute it and/or modify it under the terms
 * of the GNU Lesser General Public License as published by the Free Software Foundation
 * version 2.1 of the License.
 * This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 * See the GNU Lesser General Public License for more details.
 * You should have received a copy of the GNU Lesser General Public License along with this
 * program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
 * Floor, Boston, MA 02110-1301, USA.
 **/
package org.bonitasoft.engine.identity;

import java.io.Serializable;
import java.util.HashMap;
import java.util.Map;
import java.util.Objects;

/**
 * represents a helper for creating a {@link Role}. Chaining is possible with this creator to ease the {@link Role}
 * creation.
 * 
* For instance, new RoleCreator("member").setDisplayName("Member").setIconName("userIcon"); * * @author Matthieu Chaffotte * @author Celine Souchet * @see Role * @since 6.0.0 */ public class RoleCreator implements Serializable { private static final long serialVersionUID = -1414989152963184543L; /** * represents the available {@link Role} field */ public enum RoleField { NAME, DISPLAY_NAME, DESCRIPTION, @Deprecated ICON_NAME, @Deprecated ICON_PATH, ICON_FILENAME, ICON_CONTENT } private final Map fields; /** * create a new creator instance with a given role name * * @param name * The name of the role to create */ public RoleCreator(final String name) { fields = new HashMap<>(5); fields.put(RoleField.NAME, name); } /** * @param displayName * The role's display name to create * @return The current {@link RoleCreator} */ public RoleCreator setDisplayName(final String displayName) { fields.put(RoleField.DISPLAY_NAME, displayName); return this; } /** * @param description * The role's description to create * @return The current {@link RoleCreator} */ public RoleCreator setDescription(final String description) { fields.put(RoleField.DESCRIPTION, description); return this; } /** * @param iconName * The role's icon name to create * @return The current {@link RoleCreator} * @deprecated since 7.3.0 use #setIcon */ @Deprecated public RoleCreator setIconName(final String iconName) { return this; } /** * @param iconPath * The role's icon path to create * @return The current {@link RoleCreator} * @deprecated since 7.3.0 use #setIcon */ @Deprecated public RoleCreator setIconPath(final String iconPath) { return this; } /** * set the icon on the role to be created * * @param filename the filename of the icon * @param content the content of the icon * @return the role created */ public RoleCreator setIcon(String filename, byte[] content) { fields.put(RoleField.ICON_FILENAME, filename); fields.put(RoleField.ICON_CONTENT, content); return this; } /** * @return The current role's information to create */ public Map getFields() { return fields; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; RoleCreator that = (RoleCreator) o; return Objects.equals(fields, that.fields); } @Override public int hashCode() { return Objects.hash(fields); } @Override public String toString() { return "RoleCreator{" + "fields=" + fields + '}'; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy