RateLimitingPolicyFiltro.java

/*
 * GovWay - A customizable API Gateway 
 * https://govway.org
 * 
 * Copyright (c) 2005-2025 Link.it srl (https://link.it).
 * 
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 3, as published by
 * the Free Software Foundation.
 *
 * This program 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 General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 *
 */
package org.openspcoop2.core.config.rs.server.model;

import java.util.List;
import javax.validation.constraints.*;

import io.swagger.v3.oas.annotations.media.Schema;
import com.fasterxml.jackson.annotation.JsonProperty;
import javax.validation.Valid;

public class RateLimitingPolicyFiltro  {
  
  @Schema(description = "")
  private List<String> azione = null;
  
  @Schema(description = "")
  private String ruoloRichiedente = null;
  
  @Schema(description = "")
  private String applicativoFruitore = null;
  
  @Schema(description = "Indicare i claims richiesti (nome=valore); è possibile elencare differenti valori ammissibili separandoli con la virgola")
 /**
   * Indicare i claims richiesti (nome=valore); è possibile elencare differenti valori ammissibili separandoli con la virgola  
  **/
  private List<String> tokenClaims = null;
  
  @Schema(description = "")
  private RateLimitingChiaveEnum chiaveTipo = null;
  
  @Schema(description = "La semantica cambia in funzione del tipo:   * header-based: nome dell'header   * url-based: espressione regolare da applicare alla url di invocazione   * form-based: nome del parametro della url   * soap-action-based: in questa modalità questo parametro non viene utilizzato   * content-based: xpath o json path da applicare sul contenuto   * indirizzo-ip: indirizzo ip del socket   * indirizzo-ip-forwarded: indirizzo ip inoltrato via header http   * plugin-based: tipo del plugin")
 /**
   * La semantica cambia in funzione del tipo:   * header-based: nome dell'header   * url-based: espressione regolare da applicare alla url di invocazione   * form-based: nome del parametro della url   * soap-action-based: in questa modalità questo parametro non viene utilizzato   * content-based: xpath o json path da applicare sul contenuto   * indirizzo-ip: indirizzo ip del socket   * indirizzo-ip-forwarded: indirizzo ip inoltrato via header http   * plugin-based: tipo del plugin  
  **/
  private String chiaveNome = null;
  
  @Schema(description = "indica il valore che deve assumere la chiave")
 /**
   * indica il valore che deve assumere la chiave  
  **/
  private String filtroChiaveValore = null;
 /**
   * Get azione
   * @return azione
  **/
  @JsonProperty("azione")
  @Valid
  public List<String> getAzione() {
    return this.azione;
  }

  public void setAzione(List<String> azione) {
    this.azione = azione;
  }

  public RateLimitingPolicyFiltro azione(List<String> azione) {
    this.azione = azione;
    return this;
  }

  public RateLimitingPolicyFiltro addAzioneItem(String azioneItem) {
    this.azione.add(azioneItem);
    return this;
  }

 /**
   * Get ruoloRichiedente
   * @return ruoloRichiedente
  **/
  @JsonProperty("ruolo_richiedente")
  @Valid
 @Pattern(regexp="^[_A-Za-z][\\-\\._A-Za-z0-9]*$") @Size(max=255)  public String getRuoloRichiedente() {
    return this.ruoloRichiedente;
  }

  public void setRuoloRichiedente(String ruoloRichiedente) {
    this.ruoloRichiedente = ruoloRichiedente;
  }

  public RateLimitingPolicyFiltro ruoloRichiedente(String ruoloRichiedente) {
    this.ruoloRichiedente = ruoloRichiedente;
    return this;
  }

 /**
   * Get applicativoFruitore
   * @return applicativoFruitore
  **/
  @JsonProperty("applicativo_fruitore")
  @Valid
 @Pattern(regexp="^[_A-Za-z][\\-\\._A-Za-z0-9]*$") @Size(max=255)  public String getApplicativoFruitore() {
    return this.applicativoFruitore;
  }

  public void setApplicativoFruitore(String applicativoFruitore) {
    this.applicativoFruitore = applicativoFruitore;
  }

  public RateLimitingPolicyFiltro applicativoFruitore(String applicativoFruitore) {
    this.applicativoFruitore = applicativoFruitore;
    return this;
  }

 /**
   * Indicare i claims richiesti (nome=valore); è possibile elencare differenti valori ammissibili separandoli con la virgola
   * @return tokenClaims
  **/
  @JsonProperty("token_claims")
  @Valid
  public List<String> getTokenClaims() {
    return this.tokenClaims;
  }

  public void setTokenClaims(List<String> tokenClaims) {
    this.tokenClaims = tokenClaims;
  }

  public RateLimitingPolicyFiltro tokenClaims(List<String> tokenClaims) {
    this.tokenClaims = tokenClaims;
    return this;
  }

  public RateLimitingPolicyFiltro addTokenClaimsItem(String tokenClaimsItem) {
    this.tokenClaims.add(tokenClaimsItem);
    return this;
  }

 /**
   * Get chiaveTipo
   * @return chiaveTipo
  **/
  @JsonProperty("chiave_tipo")
  @Valid
  public RateLimitingChiaveEnum getChiaveTipo() {
    return this.chiaveTipo;
  }

  public void setChiaveTipo(RateLimitingChiaveEnum chiaveTipo) {
    this.chiaveTipo = chiaveTipo;
  }

  public RateLimitingPolicyFiltro chiaveTipo(RateLimitingChiaveEnum chiaveTipo) {
    this.chiaveTipo = chiaveTipo;
    return this;
  }

 /**
   * La semantica cambia in funzione del tipo:   * header-based: nome dell'header   * url-based: espressione regolare da applicare alla url di invocazione   * form-based: nome del parametro della url   * soap-action-based: in questa modalità questo parametro non viene utilizzato   * content-based: xpath o json path da applicare sul contenuto   * indirizzo-ip: indirizzo ip del socket   * indirizzo-ip-forwarded: indirizzo ip inoltrato via header http   * plugin-based: tipo del plugin
   * @return chiaveNome
  **/
  @JsonProperty("chiave_nome")
  @Valid
 @Size(max=255)  public String getChiaveNome() {
    return this.chiaveNome;
  }

  public void setChiaveNome(String chiaveNome) {
    this.chiaveNome = chiaveNome;
  }

  public RateLimitingPolicyFiltro chiaveNome(String chiaveNome) {
    this.chiaveNome = chiaveNome;
    return this;
  }

 /**
   * indica il valore che deve assumere la chiave
   * @return filtroChiaveValore
  **/
  @JsonProperty("filtro_chiave_valore")
  @Valid
 @Size(max=255)  public String getFiltroChiaveValore() {
    return this.filtroChiaveValore;
  }

  public void setFiltroChiaveValore(String filtroChiaveValore) {
    this.filtroChiaveValore = filtroChiaveValore;
  }

  public RateLimitingPolicyFiltro filtroChiaveValore(String filtroChiaveValore) {
    this.filtroChiaveValore = filtroChiaveValore;
    return this;
  }


  @Override
  public String toString() {
    StringBuilder sb = new StringBuilder();
    sb.append("class RateLimitingPolicyFiltro {\n");
    
    sb.append("    azione: ").append(RateLimitingPolicyFiltro.toIndentedString(this.azione)).append("\n");
    sb.append("    ruoloRichiedente: ").append(RateLimitingPolicyFiltro.toIndentedString(this.ruoloRichiedente)).append("\n");
    sb.append("    applicativoFruitore: ").append(RateLimitingPolicyFiltro.toIndentedString(this.applicativoFruitore)).append("\n");
    sb.append("    tokenClaims: ").append(RateLimitingPolicyFiltro.toIndentedString(this.tokenClaims)).append("\n");
    sb.append("    chiaveTipo: ").append(RateLimitingPolicyFiltro.toIndentedString(this.chiaveTipo)).append("\n");
    sb.append("    chiaveNome: ").append(RateLimitingPolicyFiltro.toIndentedString(this.chiaveNome)).append("\n");
    sb.append("    filtroChiaveValore: ").append(RateLimitingPolicyFiltro.toIndentedString(this.filtroChiaveValore)).append("\n");
    sb.append("}");
    return sb.toString();
  }

  /**
   * Convert the given object to string with each line indented by 4 spaces
   * (except the first line).
   */
  private static String toIndentedString(java.lang.Object o) {
    if (o == null) {
      return "null";
    }
    return o.toString().replace("\n", "\n    ");
  }
}