All Downloads are FREE. Search and download functionalities are using the official Maven repository.

se.idsec.signservice.integration.SignServiceIntegrationService Maven / Gradle / Ivy

/*
 * Copyright 2019-2024 IDsec Solutions AB
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package se.idsec.signservice.integration;

import jakarta.annotation.Nonnull;
import jakarta.annotation.Nullable;
import se.idsec.signservice.integration.config.IntegrationServiceDefaultConfiguration;
import se.idsec.signservice.integration.config.PolicyNotFoundException;
import se.idsec.signservice.integration.core.SignatureState;
import se.idsec.signservice.integration.core.error.InputValidationException;
import se.idsec.signservice.integration.core.error.SignServiceIntegrationException;

import java.util.List;

/**
 * Interface describing the API for the SignService Integration Service.
 *
 * @author Martin Lindström ([email protected])
 * @author Stefan Santesson ([email protected])
 */
public interface SignServiceIntegrationService {

  /**
   * Creates a SignRequest message that is to be posted to the signature service.
   *
   * @param signRequestInput the requirements and input for how to create the SignRequest
   * @param callerId the identity for the calling entity (only needed if the implementation is a stand-alone service
   *     running in stateful mode)
   * @return a SignRequestData object containing the encoded (and signed) SignRequest along with additional parameters
   * @throws InputValidationException for errors in the supplied input
   * @throws SignServiceIntegrationException for errors creating the SignRequest
   */
  @Nonnull
  SignRequestData createSignRequest(@Nonnull final SignRequestInput signRequestInput, @Nullable final String callerId)
      throws InputValidationException, SignServiceIntegrationException;

  /**
   * See {@link #createSignRequest(SignRequestInput, String)}.
   *
   * @param signRequestInput the requirements and input for how to create the SignRequest
   * @return a SignRequestData object containing the encoded (and signed) SignRequest along with additional parameters
   * @throws InputValidationException for errors in the supplied input
   * @throws SignServiceIntegrationException for errors creating the SignRequest
   */
  @Nonnull
  default SignRequestData createSignRequest(@Nonnull final SignRequestInput signRequestInput)
      throws InputValidationException, SignServiceIntegrationException {
    return this.createSignRequest(signRequestInput, null);
  }

  /**
   * When the service that has ordered the signing operation receives the sign response message it should invoke this
   * method to process this response. The processing will validate the signature of each signed document and return the
   * signed document(s) along with metadata about the signature process.
   *
   * 

* Note: The {@code relayState} must be equal to supplied state ({@link SignatureState#getId()}). This parameter is * redundant, but included for pedagogical reasons since the RelayState POST parameter is received. *

* * @param signResponse the Base64-encoded SignResponse message (from the EidSignResponse POST parameter) * @param relayState the relayState (from the RelayState POST parameter) * @param state the signature state * @param parameters optional processing parameter giving directives about the processing * @param callerId the identity for the calling entity (only needed if the implementation is a stand-alone service * running in stateful mode) * @return a SignatureResult object containing the signed documents and metadata about the signature * @throws SignResponseCancelStatusException the sign service reported that the user cancelled the operation * @throws SignResponseErrorStatusException the sign service reported an error * @throws SignServiceIntegrationException for validation and processing errors */ @Nonnull SignatureResult processSignResponse(@Nonnull final String signResponse, @Nonnull final String relayState, @Nonnull final SignatureState state, @Nullable final SignResponseProcessingParameters parameters, @Nullable final String callerId) throws SignResponseCancelStatusException, SignResponseErrorStatusException, SignServiceIntegrationException; /** * See {@link #processSignResponse(String, String, SignatureState, SignResponseProcessingParameters, String)}. * * @param signResponse the Base64-encoded SignResponse message (from the EidSignResponse POST parameter) * @param relayState the relayState (from the RelayState POST parameter) * @param state the signature state * @param parameters optional processing parameter giving directives about the processing * @return a SignatureResult object containing the signed documents and metadata about the signature * @throws SignResponseCancelStatusException the sign service reported that the user cancelled the operation * @throws SignResponseErrorStatusException the sign service reported an error * @throws SignServiceIntegrationException for validation and processing errors */ @Nonnull default SignatureResult processSignResponse(@Nonnull final String signResponse, @Nonnull final String relayState, @Nonnull final SignatureState state, @Nullable final SignResponseProcessingParameters parameters) throws SignResponseCancelStatusException, SignResponseErrorStatusException, SignServiceIntegrationException { return this.processSignResponse(signResponse, relayState, state, parameters, null); } /** * Given the name of a SignService Integration policy, the method returns the default settings used for this policy. * * @param policy the policy name (null is interpreted as the default policy) * @return the default service configuration for the given policy * @throws PolicyNotFoundException if the given policy does not exist */ @Nonnull IntegrationServiceDefaultConfiguration getConfiguration(@Nullable final String policy) throws PolicyNotFoundException; /** * Returns a list of names of the policies that are defined for this instance of the SignService Integration Service. * * @return a non-empty list of policy names */ @Nonnull List getPolicies(); /** * Returns the version identifier for the current version of the SignService Integration Service. * * @return version string */ @Nonnull default String getVersion() { return ApiVersion.getVersion(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy