TagApiClientModule.java
package io.github.evisentin.wordpress.rest.client.adapter.apache.modules;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.github.evisentin.wordpress.rest.client.adapter.apache.query.mappers.TagQueryParamMapper;
import io.github.evisentin.wordpress.rest.client.domain.api.TagAPIs;
import io.github.evisentin.wordpress.rest.client.domain.model.WpPagedResponse;
import io.github.evisentin.wordpress.rest.client.domain.model.WpTag;
import io.github.evisentin.wordpress.rest.client.domain.model.enums.WpContext;
import io.github.evisentin.wordpress.rest.client.domain.model.query.WpPaginationQuery;
import io.github.evisentin.wordpress.rest.client.domain.model.query.WpTagQuery;
import io.github.evisentin.wordpress.rest.client.domain.model.requests.WpTagCreateUpdateRequest;
import io.github.evisentin.wordpress.rest.client.domain.model.responses.WpTagDeletionResponse;
import lombok.NonNull;
import lombok.SneakyThrows;
import org.apache.hc.client5.http.impl.classic.CloseableHttpClient;
import org.apache.hc.core5.net.URIBuilder;
import java.util.Map;
import static io.github.evisentin.wordpress.rest.client.adapter.apache.modules.TypeReferences.WP_TAG_DELETION_RESPONSE_TYPEREFERENCE;
import static io.github.evisentin.wordpress.rest.client.adapter.apache.modules.TypeReferences.WP_TAG_LIST_TYPEREFERENCE;
import static io.github.evisentin.wordpress.rest.client.adapter.apache.modules.TypeReferences.WP_TAG_TYPEREFERENCE;
import static io.github.evisentin.wordpress.rest.client.domain.model.parameters.WpQueryParameters.CONTEXT;
import static io.github.evisentin.wordpress.rest.client.domain.model.parameters.WpQueryParameters.FORCE;
import static io.github.evisentin.wordpress.rest.client.domain.model.parameters.WpQueryParameters.PAGE;
import static io.github.evisentin.wordpress.rest.client.domain.model.parameters.WpQueryParameters.PER_PAGE;
import static java.util.Optional.ofNullable;
import static org.apache.commons.lang3.StringUtils.isBlank;
/**
* Apache HttpClient implementation of {@link TagAPIs}.
*
* <p>Provides access to WordPress tag resources through the {@code /wp/v2/tags} endpoint.</p>
*/
public class TagApiClientModule extends ApiClientModule implements TagAPIs {
public TagApiClientModule(final String apiUrl,
final CloseableHttpClient httpClient,
final ObjectMapper mapper) {
super(apiUrl, httpClient, mapper);
}
@Override
@SneakyThrows
public WpTag create(final @NonNull WpTagCreateUpdateRequest creationRequest) {
if (isBlank(creationRequest.getName()))
throw new IllegalArgumentException("name cannot be blank");
final URIBuilder builder = urlBuilder("${apiUrl}/wp/v2/tags", Map.of(API_URL, apiUrl));
return performPostWithBody(builder, creationRequest, WP_TAG_TYPEREFERENCE);
}
@Override
@SneakyThrows
public WpTagDeletionResponse delete(final long id) {
final URIBuilder builder = urlBuilder("${apiUrl}/wp/v2/tags/${id}", Map.of(API_URL, apiUrl, "id", id));
// For tags/terms, WordPress does not support trashing, and the REST API explicitly
// requires force to be true for delete.
builder.addParameter(FORCE, Boolean.TRUE.toString());
return performDeleteRequest(builder, WP_TAG_DELETION_RESPONSE_TYPEREFERENCE);
}
@Override
@SneakyThrows
public WpTag get(final long id, final WpContext context) {
final URIBuilder builder = urlBuilder("${apiUrl}/wp/v2/tags/${id}", Map.of(API_URL, apiUrl, "id", id));
builder.addParameter(CONTEXT, ofNullable(context).orElse(WpContext.VIEW).getValue());
return performGetRequest(builder, WP_TAG_TYPEREFERENCE);
}
@Override
@SneakyThrows
public WpPagedResponse<WpTag> list(final @NonNull WpPaginationQuery paginationQuery,
final WpTagQuery tagQuery) {
final URIBuilder builder = urlBuilder("${apiUrl}/wp/v2/tags", Map.of(API_URL, apiUrl));
builder.addParameter(PAGE, Integer.toString(paginationQuery.pageNumber()));
builder.addParameter(PER_PAGE, Integer.toString(paginationQuery.pageSize()));
TagQueryParamMapper.map(builder, tagQuery);
return performPagingRequest(builder, paginationQuery, WP_TAG_LIST_TYPEREFERENCE);
}
@Override
@SneakyThrows
public WpTag update(final long id,
final @NonNull WpTagCreateUpdateRequest updateRequest) {
final URIBuilder builder = urlBuilder("${apiUrl}/wp/v2/tags/${id}", Map.of(API_URL, apiUrl, "id", id));
return performPostWithBody(builder, updateRequest, WP_TAG_TYPEREFERENCE);
}
}