DecodingKey

KeyGenerator

ServiceCredentials

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120
#ifndef CondCore_CondDB_DecodingKey_h
#define CondCore_CondDB_DecodingKey_h

#include <iostream>
#include <string>
#include <set>
#include <map>

namespace cond {

  namespace auth {

    struct ServiceCredentials {
      ServiceCredentials();
      std::string connectionString;
      std::string userName;
      std::string password;
    };

    class KeyGenerator {
    public:
      KeyGenerator();

      std::string make(size_t keySize);
      std::string makeWithRandomSize(size_t maxSize);

    private:
      int m_iteration;
    };

    class DecodingKey {
    public:
      static constexpr const char* const KEY_FMT_VERSION = "2.0";
      static constexpr const char* const FILE_NAME = "db.key";
      static constexpr const char* const FILE_PATH = ".cms_cond/db.key";
      static constexpr size_t DEFAULT_KEY_SIZE = 100;

      static std::string templateFile();

    public:
      DecodingKey();

      virtual ~DecodingKey() {}

      size_t init(const std::string& keyFileName, const std::string& password, bool readMode = true);

      size_t createFromInputFile(const std::string& inputFileName, size_t generatedKeySize = 0);

      void list(std::ostream& out);

      void flush();

      const std::string& version() const;

      const std::string& principalName() const;

      const std::string& principalKey() const;

      bool isNominal() const;

      const std::string& ownerName() const;

      const std::map<std::string, ServiceCredentials>& services() const;

      void addDefaultService(const std::string& connectionString);

      void addService(const std::string& serviceName,
                      const std::string& connectionString,
                      const std::string& userName,
                      const std::string& password);

    private:
      std::string m_fileName;

      std::string m_version;

      bool m_mode;

      std::string m_pwd;

      std::string m_principalName;

      std::string m_principalKey;

      std::string m_owner;

      std::map<std::string, ServiceCredentials> m_services;
    };
  }  // namespace auth
}  // namespace cond

inline cond::auth::KeyGenerator::KeyGenerator() : m_iteration(0) {}

inline cond::auth::ServiceCredentials::ServiceCredentials() : connectionString(""), userName(""), password("") {}

inline cond::auth::DecodingKey::DecodingKey()
    : m_fileName(""),
      m_version(""),
      m_mode(true),
      m_pwd(""),
      m_principalName(""),
      m_principalKey(""),
      m_owner(""),
      m_services() {}

inline const std::string& cond::auth::DecodingKey::version() const { return m_version; }

inline const std::string& cond::auth::DecodingKey::principalName() const { return m_principalName; }

inline const std::string& cond::auth::DecodingKey::principalKey() const { return m_principalKey; }

inline bool cond::auth::DecodingKey::isNominal() const { return !m_owner.empty(); }

inline const std::string& cond::auth::DecodingKey::ownerName() const { return m_owner; }

inline const std::map<std::string, cond::auth::ServiceCredentials>& cond::auth::DecodingKey::services() const {
  return m_services;
}

#endif  //  CondCore_CondDB_DecodingKey_h