summaryrefslogtreecommitdiff
path: root/src/mongo/db/repl/rollback.h
diff options
context:
space:
mode:
authorBenety Goh <benety@mongodb.com>2017-03-08 16:09:25 -0500
committerBenety Goh <benety@mongodb.com>2017-03-23 16:18:26 -0400
commit42d945d2446e0ca0aef570ec090e4d93ede00618 (patch)
tree2849ac57af6e9b9d72a82baf669b6f30503dfbea /src/mongo/db/repl/rollback.h
parentc1964e817459a575a64609229a473d57d08aa4d0 (diff)
downloadmongo-42d945d2446e0ca0aef570ec090e4d93ede00618.tar.gz
SERVER-28204 added Rollback interface and 3.6 implementation
This is a stub implementation of the new 3.6 rollback algorithm.
Diffstat (limited to 'src/mongo/db/repl/rollback.h')
-rw-r--r--src/mongo/db/repl/rollback.h60
1 files changed, 60 insertions, 0 deletions
diff --git a/src/mongo/db/repl/rollback.h b/src/mongo/db/repl/rollback.h
new file mode 100644
index 00000000000..6f65ddb9830
--- /dev/null
+++ b/src/mongo/db/repl/rollback.h
@@ -0,0 +1,60 @@
+/**
+ * Copyright (C) 2017 MongoDB Inc.
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License, version 3,
+ * as published by the Free Software Foundation.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ *
+ * As a special exception, the copyright holders give permission to link the
+ * code of portions of this program with the OpenSSL library under certain
+ * conditions as described in each individual source file and distribute
+ * linked combinations including the program with the OpenSSL library. You
+ * must comply with the GNU Affero General Public License in all respects for
+ * all of the code used other than as permitted herein. If you modify file(s)
+ * with this exception, you may extend this exception to your version of the
+ * file(s), but you are not obligated to do so. If you do not wish to do so,
+ * delete this exception statement from your version. If you delete this
+ * exception statement from all source files in the program, then also delete
+ * it in the license file.
+ */
+
+#pragma once
+
+#include "mongo/base/disallow_copying.h"
+#include "mongo/base/status_with.h"
+#include "mongo/db/repl/optime.h"
+#include "mongo/stdx/functional.h"
+
+namespace mongo {
+namespace repl {
+
+/**
+ * This class represents the interface BackgroundSync and ReplicationCoordinatorExternalState use to
+ * interact with the rollback subsystem.
+ */
+class Rollback {
+ MONGO_DISALLOW_COPYING(Rollback);
+
+public:
+ /**
+ * Callback function to report results of rollback. On success, the last optime applied will be
+ * passed in.
+ */
+ using OnCompletionFn =
+ stdx::function<void(const StatusWith<OpTime>& lastOpTimeApplied) noexcept>;
+
+ Rollback() = default;
+
+ virtual ~Rollback() = default;
+};
+
+} // namespace repl
+} // namespace mongo