AccessTokenController.java

package io.featureprobe.api.controller;

import io.featureprobe.api.base.doc.CreateApiResponse;
import io.featureprobe.api.base.doc.DefaultApiResponses;
import io.featureprobe.api.base.doc.DeleteApiResponse;
import io.featureprobe.api.base.doc.GetApiResponse;
import io.featureprobe.api.base.enums.AccessTokenType;
import io.featureprobe.api.base.enums.ResponseCodeEnum;
import io.featureprobe.api.base.model.BaseResponse;
import io.featureprobe.api.dto.AccessTokenCreateRequest;
import io.featureprobe.api.dto.AccessTokenResponse;
import io.featureprobe.api.dto.AccessTokenSearchRequest;
import io.featureprobe.api.dto.TokenResponse;
import io.featureprobe.api.service.AccessTokenService;
import io.featureprobe.api.validate.ResourceExistsValidate;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.media.Schema;
import io.swagger.v3.oas.annotations.tags.Tag;
import lombok.AllArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.data.domain.Page;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.DeleteMapping;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

@Slf4j
@DefaultApiResponses
@RequestMapping("/api/tokens")
@AllArgsConstructor
@RestController
@ResourceExistsValidate
@Tag(name = "Access tokens", description = "The access tokens API allows you to list," +
        "create and delete access tokens programmatically.")
public class AccessTokenController {

    private AccessTokenService accessTokenService;

    @GetMapping
    @GetApiResponse
    @Operation(summary = "List access tokens", description = "Fetch a list of person or application access tokens.")
    public Page<AccessTokenResponse> list(AccessTokenSearchRequest searchRequest) {
        return accessTokenService.list(searchRequest);
    }

    @PostMapping
    @CreateApiResponse
    @Operation(summary = "Create access tokens", description = "Create a new access token.")
    public TokenResponse create(@RequestBody @Validated AccessTokenCreateRequest request) {
        return accessTokenService.create(request);
    }

    @GetMapping("/exists")
    @GetApiResponse
    @Operation(summary = "Check access token exist", description = "Check toggle exist.")
    public BaseResponse exists(
            @RequestParam("name")
            @Schema(description = "The name for the access token.")
            String name,
            @RequestParam("type")
            @Schema(description = "The type for the access token.")
            AccessTokenType type) {
        accessTokenService.validateExists(name, type);
        return new BaseResponse(ResponseCodeEnum.SUCCESS);
    }

    @GetMapping("/{id}")
    @GetApiResponse
    @Operation(summary = "Get access token", description = "Get a single access token by ID.")
    public AccessTokenResponse query(@PathVariable("id") @Schema(description = "The ID of the access token") Long id) {
        return accessTokenService.queryById(id);
    }

    @DeleteMapping("/{id}")
    @DeleteApiResponse
    @Operation(summary = "Delete access token", description = "Delete an access token by ID")
    public AccessTokenResponse delete(@PathVariable("id") @Schema(description = "The ID of the access token") Long id) {
        return accessTokenService.delete(id);
    }
}