Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(598)

Unified Diff: extensions/browser/content_verify_job.h

Issue 266963003: Beginning of support for extension content verification (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: oops, forgot to upload minor cosmetic changes to test Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: extensions/browser/content_verify_job.h
diff --git a/extensions/browser/content_verify_job.h b/extensions/browser/content_verify_job.h
new file mode 100644
index 0000000000000000000000000000000000000000..68eb1ac92691293f35e6027fab2038eaa7ae3e81
--- /dev/null
+++ b/extensions/browser/content_verify_job.h
@@ -0,0 +1,93 @@
+// Copyright 2014 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 EXTENSIONS_BROWSER_CONTENT_VERIFY_JOB_H_
+#define EXTENSIONS_BROWSER_CONTENT_VERIFY_JOB_H_
+
+#include <string>
+
+#include "base/callback.h"
+#include "base/memory/ref_counted.h"
+#include "base/memory/scoped_ptr.h"
+
+namespace base {
+class FilePath;
+}
+
+namespace extensions {
+
+class ContentHashReader;
+
+// Objects of this class are responsible for verifying that the actual content
+// read from an extension file matches an expected set of hashes. This class
+// can be created on any thread but the rest of the methods should be called
+// from only one thread.
Yoyo Zhou 2014/05/07 02:25:59 consider using a ThreadChecker
asargent_no_longer_on_chrome 2014/05/07 06:56:42 Good idea. Done.
+class ContentVerifyJob : public base::RefCountedThreadSafe<ContentVerifyJob> {
+ public:
+ enum FailureReason {
+ // No failure.
+ NONE,
+
+ // Failed because there were no expected hashes.
+ NO_HASHES,
+
+ // Some of the content read did not match the expected hash.
+ HASH_MISMATCH
+ };
+ typedef base::Callback<void(FailureReason)> FailureCallback;
+
+ // The |failure_callback| will be called at most once if there was a failure.
+ //
+ // IMPORTANT NOTE: this class is still a stub right now - in the future this
+ // constructor will also be passed information to let it lookup expected
+ // block hashes for the file being read.
+ ContentVerifyJob(const std::string& extension_id,
+ const FailureCallback& failure_callback);
+
+ // This begins the process of getting expected hashes, so it should be called
+ // as early as possible.
+ void Start();
+
+ // Call this to add more bytes to verify. If at any point the read bytes
+ // don't match the expected hashes, this will dispatch the failure
+ // callback. The failure callback will only be run once even if more bytes
+ // are read. Make sure to call DoneReading so that any final bytes that were
+ // read that didn't align exactly on a block size boundary get their hash
+ // checked as well.
+ void BytesRead(int count, const char* data);
+
+ // Call once when finished adding bytes via BytesRead.
+ void DoneReading();
+
+ class TestDelegate {
+ public:
+ // These methods will be called inside BytesRead/DoneReading respectively.
+ // If either return something other than NONE, then the failure callback
+ // will be dispatched with that reason.
+ virtual FailureReason BytesRead(const std::string& extension_id,
+ int count,
+ const char* data) = 0;
+ virtual FailureReason DoneReading(const std::string& extension_id) = 0;
+ };
+
+ static void SetDelegateForTests(TestDelegate* delegate);
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(ContentVerifyJob);
+
+ virtual ~ContentVerifyJob();
+ friend class base::RefCountedThreadSafe<ContentVerifyJob>;
+
+ void DispatchFailureCallback(FailureReason reason);
+
+ // The id of the extension for the file being verified.
+ std::string extension_id_;
+
+ // Called once if verification fails.
+ FailureCallback failure_callback_;
+};
+
+} // namespace extensions
+
+#endif // EXTENSIONS_BROWSER_CONTENT_VERIFY_JOB_H_

Powered by Google App Engine
This is Rietveld 408576698