1 /* 2 * Copyright (C) 2019 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 #ifndef ANDROID_ML_NN_COMMON_TOKEN_HASHER_H 18 #define ANDROID_ML_NN_COMMON_TOKEN_HASHER_H 19 20 #include <cstring> 21 #include <vector> 22 23 #include <android-base/macros.h> 24 #include <openssl/sha.h> 25 26 namespace android { 27 namespace nn { 28 29 class TokenHasher { 30 DISALLOW_COPY_AND_ASSIGN(TokenHasher); 31 32 public: 33 // Initializes the hasher with token. If token is nullptr, the hasher is set to be empty; 34 // otherwise, it must be of length ANEURALNETWORKS_BYTE_SIZE_OF_CACHE_TOKEN. 35 TokenHasher(const uint8_t* token); 36 37 // Updates with a byte array. Returns false and sets to be empty on fail. 38 // The client must check if the hasher is valid before invoking this method. 39 bool update(const void* bytes, size_t length); 40 41 // Updates with a string ended with '\0'. Returns false and sets to be empty on fail. 42 // The client must check if the hasher is valid before invoking this method. updateFromString(const char * s)43 bool updateFromString(const char* s) { return update(s, strlen(s)); } 44 45 // Finishes the hasher, and writes re-hashed token to mToken. 46 // Returns false and sets to be empty on fail. 47 // The client must check if the hasher is valid before invoking this method. 48 bool finish(); 49 50 // Returns a pointer to the transformed token if the hasher is successfully finished. 51 // Returns nullptr if the hasher is initialized with a nullptr, or some call on the 52 // hasher failed. 53 // Aborts if the hasher is valid but finish has not been called. 54 const uint8_t* getCacheToken() const; 55 ok()56 bool ok() const { return !mIsError; } 57 58 private: 59 // Stores the transformed token, non-empty iff the hasher is not initialized 60 // with nullptr and finish is called. 61 std::vector<uint8_t> mToken; 62 SHA256_CTX mHasher; 63 // Indicates that either the hasher is initialized with a nullptr, or some call on 64 // the hasher failed. 65 bool mIsError; 66 }; 67 68 } // namespace nn 69 } // namespace android 70 71 #endif // ANDROID_ML_NN_COMMON_TOKEN_HASHER_H 72