1*789431f2SAndroid Build Coastguard Worker /* 2*789431f2SAndroid Build Coastguard Worker * Copyright 2020, The Android Open Source Project 3*789431f2SAndroid Build Coastguard Worker * 4*789431f2SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*789431f2SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*789431f2SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*789431f2SAndroid Build Coastguard Worker * 8*789431f2SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*789431f2SAndroid Build Coastguard Worker * 10*789431f2SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*789431f2SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*789431f2SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*789431f2SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*789431f2SAndroid Build Coastguard Worker * limitations under the License. 15*789431f2SAndroid Build Coastguard Worker */ 16*789431f2SAndroid Build Coastguard Worker 17*789431f2SAndroid Build Coastguard Worker #pragma once 18*789431f2SAndroid Build Coastguard Worker 19*789431f2SAndroid Build Coastguard Worker #include <aidl/android/hardware/security/keymint/BnKeyMintOperation.h> 20*789431f2SAndroid Build Coastguard Worker #include <aidl/android/hardware/security/secureclock/ISecureClock.h> 21*789431f2SAndroid Build Coastguard Worker 22*789431f2SAndroid Build Coastguard Worker #include <hardware/keymaster_defs.h> 23*789431f2SAndroid Build Coastguard Worker 24*789431f2SAndroid Build Coastguard Worker namespace keymaster { 25*789431f2SAndroid Build Coastguard Worker class AndroidKeymaster; 26*789431f2SAndroid Build Coastguard Worker } 27*789431f2SAndroid Build Coastguard Worker 28*789431f2SAndroid Build Coastguard Worker namespace aidl::android::hardware::security::keymint { 29*789431f2SAndroid Build Coastguard Worker 30*789431f2SAndroid Build Coastguard Worker using ::ndk::ScopedAStatus; 31*789431f2SAndroid Build Coastguard Worker using secureclock::TimeStampToken; 32*789431f2SAndroid Build Coastguard Worker using std::optional; 33*789431f2SAndroid Build Coastguard Worker using std::shared_ptr; 34*789431f2SAndroid Build Coastguard Worker using std::string; 35*789431f2SAndroid Build Coastguard Worker using std::vector; 36*789431f2SAndroid Build Coastguard Worker 37*789431f2SAndroid Build Coastguard Worker class AndroidKeyMintOperation : public BnKeyMintOperation { 38*789431f2SAndroid Build Coastguard Worker public: 39*789431f2SAndroid Build Coastguard Worker explicit AndroidKeyMintOperation(const shared_ptr<::keymaster::AndroidKeymaster> implementation, 40*789431f2SAndroid Build Coastguard Worker keymaster_operation_handle_t opHandle); 41*789431f2SAndroid Build Coastguard Worker virtual ~AndroidKeyMintOperation(); 42*789431f2SAndroid Build Coastguard Worker 43*789431f2SAndroid Build Coastguard Worker ScopedAStatus updateAad(const vector<uint8_t>& input, 44*789431f2SAndroid Build Coastguard Worker const optional<HardwareAuthToken>& authToken, 45*789431f2SAndroid Build Coastguard Worker const optional<TimeStampToken>& timestampToken) override; 46*789431f2SAndroid Build Coastguard Worker 47*789431f2SAndroid Build Coastguard Worker ScopedAStatus update(const vector<uint8_t>& input, const optional<HardwareAuthToken>& authToken, 48*789431f2SAndroid Build Coastguard Worker const optional<TimeStampToken>& timestampToken, 49*789431f2SAndroid Build Coastguard Worker vector<uint8_t>* output) override; 50*789431f2SAndroid Build Coastguard Worker 51*789431f2SAndroid Build Coastguard Worker ScopedAStatus finish(const optional<vector<uint8_t>>& input, // 52*789431f2SAndroid Build Coastguard Worker const optional<vector<uint8_t>>& signature, // 53*789431f2SAndroid Build Coastguard Worker const optional<HardwareAuthToken>& authToken, // 54*789431f2SAndroid Build Coastguard Worker const optional<TimeStampToken>& timestampToken, 55*789431f2SAndroid Build Coastguard Worker const optional<vector<uint8_t>>& confirmationToken, 56*789431f2SAndroid Build Coastguard Worker vector<uint8_t>* output) override; 57*789431f2SAndroid Build Coastguard Worker 58*789431f2SAndroid Build Coastguard Worker ScopedAStatus abort() override; 59*789431f2SAndroid Build Coastguard Worker 60*789431f2SAndroid Build Coastguard Worker protected: 61*789431f2SAndroid Build Coastguard Worker std::shared_ptr<::keymaster::AndroidKeymaster> impl_; 62*789431f2SAndroid Build Coastguard Worker keymaster_operation_handle_t opHandle_; 63*789431f2SAndroid Build Coastguard Worker }; 64*789431f2SAndroid Build Coastguard Worker 65*789431f2SAndroid Build Coastguard Worker } // namespace aidl::android::hardware::security::keymint 66