// Copyright 2015 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. #ifndef CHROME_BROWSER_EXTENSIONS_REQUIREMENTS_CHECKER_H_ #define CHROME_BROWSER_EXTENSIONS_REQUIREMENTS_CHECKER_H_ #include #include "base/callback.h" #include "base/memory/ref_counted.h" namespace extensions { class Extension; // Validates the 'requirements' extension manifest field. This is an // asynchronous process that involves several threads, but the public interface // of this class (including constructor and destructor) must only be used on // the UI thread. class RequirementsChecker { public: virtual ~RequirementsChecker() {} using RequirementsCheckedCallback = base::Callback& /* requirements */)>; // The vector passed to the callback are any localized errors describing // requirement violations. If this vector is non-empty, requirements checking // failed. This should only be called once. |callback| will always be invoked // asynchronously on the UI thread. |callback| will only be called once, and // will be reset after called. virtual void Check(const scoped_refptr& extension, const RequirementsCheckedCallback& callback) = 0; }; } // namespace extensions #endif // CHROME_BROWSER_EXTENSIONS_REQUIREMENTS_CHECKER_H_