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

io.getlime.security.powerauth.lib.cmd.steps.VerifySignatureStep Maven / Gradle / Ivy

The newest version!
/*
 * PowerAuth Command-line utility
 * Copyright 2018 Wultra s.r.o.
 *
 * 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 io.getlime.security.powerauth.lib.cmd.steps;

import io.getlime.core.rest.model.base.response.ObjectResponse;
import io.getlime.security.powerauth.lib.cmd.consts.BackwardCompatibilityConst;
import io.getlime.security.powerauth.lib.cmd.consts.PowerAuthStep;
import io.getlime.security.powerauth.lib.cmd.consts.PowerAuthVersion;
import io.getlime.security.powerauth.lib.cmd.logging.StepLogger;
import io.getlime.security.powerauth.lib.cmd.logging.StepLoggerFactory;
import io.getlime.security.powerauth.lib.cmd.header.PowerAuthHeaderFactory;
import io.getlime.security.powerauth.lib.cmd.status.ResultStatusService;
import io.getlime.security.powerauth.lib.cmd.steps.context.RequestContext;
import io.getlime.security.powerauth.lib.cmd.steps.context.StepContext;
import io.getlime.security.powerauth.lib.cmd.steps.model.VerifySignatureStepModel;
import io.getlime.security.powerauth.lib.cmd.util.VerifySignatureUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.ParameterizedTypeReference;
import org.springframework.http.HttpMethod;
import org.springframework.stereotype.Component;

import java.util.Map;

/**
 * Helper class with signature verification logic.
 *
 * 

PowerAuth protocol versions: *

    *
  • 3.0
  • *
  • 3.1
  • *
  • 3.2
  • *
  • 3.3
  • *
* * @author Lukas Lukovsky, [email protected] * @author Petr Dvorak */ @Component public class VerifySignatureStep extends AbstractBaseStep>> { private static final ParameterizedTypeReference>> RESPONSE_TYPE_REFERENCE = new ParameterizedTypeReference<>() {}; private final PowerAuthHeaderFactory powerAuthHeaderFactory; /** * Constructor * @param powerAuthHeaderFactory PowerAuth header factory * @param resultStatusService Result status service * @param stepLoggerFactory Step logger factory */ @Autowired public VerifySignatureStep( PowerAuthHeaderFactory powerAuthHeaderFactory, ResultStatusService resultStatusService, StepLoggerFactory stepLoggerFactory) { super(PowerAuthStep.SIGNATURE_VERIFY, PowerAuthVersion.ALL_VERSIONS, resultStatusService, stepLoggerFactory); this.powerAuthHeaderFactory = powerAuthHeaderFactory; } /** * Constructor for backward compatibility */ public VerifySignatureStep() { this( BackwardCompatibilityConst.POWER_AUTH_HEADER_FACTORY, BackwardCompatibilityConst.RESULT_STATUS_SERVICE, BackwardCompatibilityConst.STEP_LOGGER_FACTORY ); } @Override public ParameterizedTypeReference>> getResponseTypeReference() { return RESPONSE_TYPE_REFERENCE; } @Override public StepContext>> prepareStepContext(StepLogger stepLogger, Map context) throws Exception { VerifySignatureStepModel model = new VerifySignatureStepModel(); model.fromMap(context); byte[] dataFileBytes = VerifySignatureUtil.extractRequestDataBytes(model, stepLogger); RequestContext requestContext = RequestContext.builder() .httpMethod(HttpMethod.valueOf(model.getHttpMethod())) .requestObject(dataFileBytes) .signatureHttpMethod(model.getHttpMethod()) .signatureRequestUri(model.getResourceId()) .uri(model.getUriString()) .build(); StepContext>> stepContext = buildStepContext(stepLogger, model, requestContext); powerAuthHeaderFactory.getHeaderProvider(model).addHeader(stepContext); incrementCounter(model); return stepContext; } /** * Log that the signature was successfully completed. */ @Override public void logDryRun(StepLogger stepLogger) { stepLogger.writeItem( getStep().id() + "-signature-computed", "Signature computed", "Activation signature header was computed successfully", "OK", null ); } @Override public void processResponse(StepContext>> stepContext) { stepContext.getStepLogger().writeItem( getStep().id() + "-signature-verified", "Signature verified", "Activation signature was verified successfully", "OK", null ); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy