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

io.gravitee.repository.management.model.Plan Maven / Gradle / Ivy

There is a newer version: 4.5.5
Show newest version
/*
 * Copyright © 2015 The Gravitee team (http://gravitee.io)
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.gravitee.repository.management.model;

import io.gravitee.definition.model.DefinitionVersion;
import java.util.Date;
import java.util.HashSet;
import java.util.List;
import java.util.Objects;
import java.util.Set;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;

/**
 * @author David BRASSELY (david.brassely at graviteesource.com)
 * @author GraviteeSource Team
 */
@Builder(toBuilder = true)
@AllArgsConstructor
@NoArgsConstructor
@Getter
@Setter
public class Plan {

    public enum AuditEvent implements Audit.ApiAuditEvent {
        PLAN_CREATED,
        PLAN_UPDATED,
        PLAN_DELETED,
        PLAN_PUBLISHED,
        PLAN_CLOSED,
        PLAN_DEPRECATED,
    }

    private String id;
    private DefinitionVersion definitionVersion;

    /**
     * The plan crossId uniquely identifies a plan across environments.
     * Plans promoted between environments will share the same crossId.
     */
    private String crossId;

    private String name;

    private String description;

    private PlanSecurityType security;

    private String securityDefinition;

    private String selectionRule;

    /**
     * The way to validate subscriptions
     */
    private PlanValidationType validation;

    private PlanType type;
    private PlanMode mode;

    private Status status;

    /**
     * The position of the plan against the other Plans.
     */
    private int order;

    /**
     * The API used by this plan.
     */
    private String api;

    /**
     * The ID of the environment related to this plan
     */
    private String environmentId;

    /**
     * Plan creation date
     */
    private Date createdAt;

    /**
     * Plan last update date
     */
    private Date updatedAt;

    /**
     * Plan publication date
     */
    private Date publishedAt;

    /**
     * Plan closing date
     */
    private Date closedAt;

    /**
     * The JSON payload containing plan definition.
     *
     * 
    *
  • For V1, it contains all policies to apply for this plan
  • *
  • For V2/V4, it null
  • *
  • For FEDERATED, it contains the serialized definition
  • *
*/ private String definition; private List characteristics; /** * List of excluded groups */ private List excludedGroups; /** * last time modification introduced an api redeployment */ private Date needRedeployAt; private boolean commentRequired; private String commentMessage; private String generalConditions; @Builder.Default private Set tags = new HashSet<>(); public Plan(Plan cloned) { this.id = cloned.id; this.definitionVersion = cloned.definitionVersion; this.crossId = cloned.crossId; this.name = cloned.name; this.description = cloned.description; this.security = cloned.security; this.validation = cloned.validation; this.type = cloned.type; this.mode = cloned.mode; this.status = cloned.status; this.order = cloned.order; this.api = cloned.api; this.environmentId = cloned.environmentId; this.createdAt = cloned.createdAt; this.updatedAt = cloned.updatedAt; this.publishedAt = cloned.publishedAt; this.closedAt = cloned.closedAt; this.definition = cloned.definition; this.characteristics = cloned.characteristics; this.excludedGroups = cloned.excludedGroups; this.needRedeployAt = cloned.needRedeployAt; this.selectionRule = cloned.selectionRule; this.tags = cloned.tags; this.generalConditions = cloned.generalConditions; this.commentMessage = cloned.commentMessage; this.commentRequired = cloned.commentRequired; this.securityDefinition = cloned.securityDefinition; } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; Plan plan = (Plan) o; return Objects.equals(id, plan.id); } @Override public int hashCode() { return id != null ? id.hashCode() : 0; } @Override public String toString() { return ( "Plan{" + "id='" + id + '\'' + ", definitionVersion='" + definitionVersion + '\'' + ", crossId='" + crossId + '\'' + ", api='" + api + '\'' + ", environmentId='" + environmentId + '\'' + ", name='" + name + '\'' + ", description='" + description + '\'' + ", validation=" + validation + ", excludedGroups=" + excludedGroups + ", type=" + type + '}' ); } public enum PlanType { /** * A plan for a single API. */ API, /** * A plan for a bunch of APIs. */ CATALOG, } public enum PlanMode { /** * A plan with the policy security required. */ STANDARD, /** * Plan with no security required. * Used to manage Subscription plan (ex: Webhook) */ PUSH, } public enum PlanSecurityType { /** * Plan which is using a key_less (ie. public) security authentication type for incoming HTTP requests. */ KEY_LESS, /** * Plan which is using an api-key security authentication type for incoming HTTP requests. */ API_KEY, /** * Plan which is using an OAuth2 security authentication type for incoming HTTP requests. */ OAUTH2, /** * Plan which is using a JWT security authentication type for incoming HTTP requests. */ JWT, /** * Plan which is using a MTLS security authentication type for incoming HTTP requests. */ MTLS, } public enum PlanValidationType { /** * Subscription is automatically validated without any human action. */ AUTO, /** * Subscription requires a human validation. */ MANUAL, } public enum Status { /** * Plan is configured but not yet published */ STAGING, /** * Plan is published to portal and can be used to make calls */ PUBLISHED, /** * Plan is closed */ CLOSED, /** * Plan is deprecated */ DEPRECATED, } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy