// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // // Utility functions to check executable signatures for malicious binary // detection. Each platform has its own implementation of this class. #ifndef CHROME_BROWSER_SAFE_BROWSING_SIGNATURE_UTIL_H_ #define CHROME_BROWSER_SAFE_BROWSING_SIGNATURE_UTIL_H_ #include "base/basictypes.h" #include "base/memory/ref_counted.h" namespace base { class FilePath; } namespace safe_browsing { class ClientDownloadRequest_SignatureInfo; class SignatureUtil : public base::RefCountedThreadSafe { public: SignatureUtil(); // Fills in the DownloadRequest_SignatureInfo for the given file path. // This method may be called on any thread. virtual void CheckSignature( const base::FilePath& file_path, ClientDownloadRequest_SignatureInfo* signature_info); protected: friend class base::RefCountedThreadSafe; virtual ~SignatureUtil(); private: DISALLOW_COPY_AND_ASSIGN(SignatureUtil); }; } // namespace safe_browsing #endif // CHROME_BROWSER_SAFE_BROWSING_SIGNATURE_UTIL_H_