View Javadoc
1   /*
2    * Copyright (c) 2022-2023. Roland T. Lichti, Kaiserpfalz EDV-Service.
3    *
4    * This program is free software: you can redistribute it and/or modify
5    * it under the terms of the GNU General Public License as published by
6    * the Free Software Foundation, either version 3 of the License, or
7    * (at your option) any later version.
8    *
9    * This program is distributed in the hope that it will be useful,
10   * but WITHOUT ANY WARRANTY; without even the implied warranty of
11   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12   * GNU General Public License for more details.
13   *
14   * You should have received a copy of the GNU General Public License
15   * along with this program.  If not, see <https://www.gnu.org/licenses/>.
16   */
17  
18  package de.kaiserpfalzedv.commons.api.resources;
19  
20  import org.eclipse.microprofile.openapi.annotations.media.Schema;
21  
22  import jakarta.validation.constraints.NotBlank;
23  import jakarta.validation.constraints.Pattern;
24  import jakarta.validation.constraints.Size;
25  
26  /**
27   * HasApiVersion -- The object has an api version.
28   *
29   * @author klenkes74 {@literal <rlichti@kaiserpfalz-edv.de>}
30   * @version 2.0.2  2022-01-16
31   * @since 2.0.2  2022-01-16
32   */
33  public interface HasApiVersion {
34      String VALID_VERSION_PATTERN = "^[a-zA-Z]([a-zA-Z\\d]{1,9})?$";
35      String VALID_VERSION_PATTERN_MSG = "The version must match the pattern '" + VALID_VERSION_PATTERN + "'.";
36      String VALID_VERSION_EXAMPLE = "v1";
37  
38      int VALID_VERSION_MIN_LENGTH = 1;
39      int VALID_VERSION_MAX_LENGTH = 10;
40      String VALID_VERSION_LENGTH_MSG = "The length of an api version must be between "
41              + VALID_VERSION_MIN_LENGTH + " and " + VALID_VERSION_MAX_LENGTH + " characters.";
42  
43      @Schema(
44              name = "apiVersion",
45              description = "The version of a resource.",
46              example = "v1",
47              defaultValue = "v1",
48              pattern = VALID_VERSION_PATTERN,
49              minLength = VALID_VERSION_MIN_LENGTH,
50              maxLength = VALID_VERSION_MAX_LENGTH
51      )
52      @NotBlank
53      @Size(min = VALID_VERSION_MIN_LENGTH, max = VALID_VERSION_MAX_LENGTH, message = "The API Version is either too long or too short.")
54      @Pattern(regexp = VALID_VERSION_PATTERN, message = "The api version does not match the validation pattern.")
55      String getApiVersion();
56  }