io.camunda.service.AuthorizationServices Maven / Gradle / Ivy
/*
* Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH under
* one or more contributor license agreements. See the NOTICE file distributed
* with this work for additional information regarding copyright ownership.
* Licensed under the Camunda License 1.0. You may not use this file
* except in compliance with the Camunda License 1.0.
*/
package io.camunda.service;
import io.camunda.search.clients.CamundaSearchClient;
import io.camunda.service.entities.AuthorizationEntity;
import io.camunda.service.search.core.SearchQueryService;
import io.camunda.service.search.query.AuthorizationQuery;
import io.camunda.service.search.query.SearchQueryResult;
import io.camunda.service.security.auth.Authentication;
import io.camunda.service.transformers.ServiceTransformers;
import io.camunda.zeebe.broker.client.api.BrokerClient;
import io.camunda.zeebe.gateway.impl.broker.request.BrokerAuthorizationPatchRequest;
import io.camunda.zeebe.protocol.impl.record.value.authorization.AuthorizationRecord;
import io.camunda.zeebe.protocol.record.value.AuthorizationResourceType;
import io.camunda.zeebe.protocol.record.value.PermissionAction;
import io.camunda.zeebe.protocol.record.value.PermissionType;
import java.util.List;
import java.util.Map;
import java.util.concurrent.CompletableFuture;
public class AuthorizationServices
extends SearchQueryService, AuthorizationQuery, AuthorizationEntity> {
public AuthorizationServices(
final BrokerClient brokerClient, final CamundaSearchClient dataStoreClient) {
this(brokerClient, dataStoreClient, null, null);
}
public AuthorizationServices(
final BrokerClient brokerClient,
final CamundaSearchClient searchClient,
final ServiceTransformers transformers,
final Authentication authentication) {
super(brokerClient, searchClient, transformers, authentication);
}
@Override
public AuthorizationServices withAuthentication(final Authentication authentication) {
return new AuthorizationServices<>(brokerClient, searchClient, transformers, authentication);
}
@Override
public SearchQueryResult search(final AuthorizationQuery query) {
return executor.search(query, AuthorizationEntity.class);
}
public CompletableFuture patchAuthorization(
final PatchAuthorizationRequest request) {
final var brokerRequest =
new BrokerAuthorizationPatchRequest()
.setOwnerKey(request.ownerKey())
.setAction(request.action())
.setResourceType(request.resourceType());
request.permissions().forEach(brokerRequest::addPermissions);
return sendBrokerRequest(brokerRequest);
}
public record PatchAuthorizationRequest(
long ownerKey,
PermissionAction action,
AuthorizationResourceType resourceType,
Map> permissions) {}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy