com.anrisoftware.sscontrol.source.service.SourceServiceConfigInfo.java Source code

Java tutorial

Introduction

Here is the source code for com.anrisoftware.sscontrol.source.service.SourceServiceConfigInfo.java

Source

/*
 * Copyright 2015 Erwin Mller <erwin.mueller@deventm.org>
 *
 * This file is part of sscontrol-source-service.
 *
 * sscontrol-source-service is free software: you can redistribute it and/or modify it
 * under the terms of the GNU Affero General Public License as published by the
 * Free Software Foundation, either version 3 of the License, or (at your
 * option) any later version.
 *
 * sscontrol-source-service 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 Affero General Public License
 * for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with sscontrol-source-service. If not, see <http://www.gnu.org/licenses/>.
 */
package com.anrisoftware.sscontrol.source.service;

import java.io.Serializable;

import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.ToStringBuilder;

/**
 * Information that identifies the source code management service configuration.
 *
 * @author Erwin Mueller, erwin.mueller@deventm.org
 * @since 1.0
 */
@SuppressWarnings("serial")
public abstract class SourceServiceConfigInfo implements Serializable {

    private static final String SERVICE_NAME = "source";
    private static final String PROFILE = "profile";
    private static final String SERVICE = "service";
    private static final String SOURCE_NAME = "source";

    /**
     * Returns the source code management service name.
     *
     * @return the service name.
     */
    public final String getServiceName() {
        return SERVICE_NAME;
    }

    /**
     * Returns the service name for the source code management service, for
     * example <i>gitolite</i>.
     *
     * @return the source code management service name.
     */
    public abstract String getSourceName();

    /**
     * Returns the profile name.
     * <p>
     * The profile name is the server type as specified in the profile script.
     * For example {@code "ubuntu_10_04"} for <i>Ubuntu 10.04</i>.
     *
     * @return the profile name.
     */
    public abstract String getProfileName();

    /**
     * Returns the source code management service.
     *
     * @return the {@link SourceSetupService} service.
     */
    public abstract SourceSetupService getSourceService();

    @Override
    public boolean equals(Object obj) {
        if (obj == null) {
            return false;
        }
        if (obj == this) {
            return true;
        }
        if (!(obj instanceof SourceServiceConfigInfo)) {
            return false;
        }
        SourceServiceConfigInfo rhs = (SourceServiceConfigInfo) obj;
        return new EqualsBuilder().append(getServiceName(), rhs.getServiceName())
                .append(getSourceName(), rhs.getSourceName()).append(getProfileName(), rhs.getProfileName())
                .isEquals();
    }

    @Override
    public String toString() {
        ToStringBuilder builder = new ToStringBuilder(this);
        builder.append(SERVICE, getServiceName());
        builder.append(SOURCE_NAME, getSourceName());
        builder.append(PROFILE, getProfileName());
        return builder.toString();
    }

}