/** * Copyright (C) 2012 10gen 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 . * * 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 #include "mongo/base/string_data.h" #include "mongo/db/jsobj.h" namespace mongo { /** * This class represents the layout and contents of documents contained in the * config.lockpings collection. All manipulation of documents coming from that * collection should be done with this class. * * Usage Example: * * // Contact the config. 'conn' has been obtained before. * DBClientBase* conn; * BSONObj query = QUERY(LockpingsType::exampleField("exampleFieldName")); * exampleDoc = conn->findOne(LockpingsType::ConfigNS, query); * * // Process the response. * LockpingsType exampleType; * std::string errMsg; * if (!exampleType.parseBSON(exampleDoc, &errMsg) || !exampleType.isValid(&errMsg)) { * // Can't use 'exampleType'. Take action. * } * // use 'exampleType' * */ class LockpingsType { public: // // schema declarations // // Name of the lockpings collection in the config server. static const std::string ConfigNS; // Field names and types in the lockpings collection type. static const BSONField process; static const BSONField ping; // // lockpings type methods // LockpingsType(); ~LockpingsType(); /** * Returns true if all the mandatory fields are present and have valid * representations. Otherwise returns false and fills in the optional 'errMsg' string. */ bool isValid(std::string* errMsg) const; /** * Returns the BSON representation of the entry. */ BSONObj toBSON() const; /** * Clears and populates the internal state using the 'source' BSON object if the * latter contains valid values. Otherwise sets errMsg and returns false. */ bool parseBSON(const BSONObj& source, std::string* errMsg); /** * Clears the internal state. */ void clear(); /** * Copies all the fields present in 'this' to 'other'. */ void cloneTo(LockpingsType* other) const; /** * Returns a std::string representation of the current internal state. */ std::string toString() const; // // individual field accessors // // Mandatory Fields void setProcess(StringData process) { _process = process.toString(); _isProcessSet = true; } void unsetProcess() { _isProcessSet = false; } bool isProcessSet() const { return _isProcessSet; } // Calling get*() methods when the member is not set results in undefined behavior const std::string& getProcess() const { dassert(_isProcessSet); return _process; } void setPing(const Date_t ping) { _ping = ping; _isPingSet = true; } void unsetPing() { _isPingSet = false; } bool isPingSet() const { return _isPingSet; } // Calling get*() methods when the member is not set results in undefined behavior const Date_t getPing() const { dassert(_isPingSet); return _ping; } // Optional Fields private: // Convention: (M)andatory, (O)ptional, (S)pecial rule. std::string _process; // (M) std::string describing the process holding the lock bool _isProcessSet; Date_t _ping; // (M) last time the holding process updated this document bool _isPingSet; }; } // namespace mongo