ORE Studio 0.0.4
Loading...
Searching...
No Matches
role.hpp
1/* -*- mode: c++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
2 *
3 * Copyright (C) 2025 Marco Craveiro <marco.craveiro@gmail.com>
4 *
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU General Public License as published by the Free Software
7 * Foundation; either version 3 of the License, or (at your option) any later
8 * version.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
12 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
13 * details.
14 *
15 * You should have received a copy of the GNU General Public License along with
16 * this program; if not, write to the Free Software Foundation, Inc., 51
17 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
18 *
19 */
20#ifndef ORES_IAM_DOMAIN_ROLE_HPP
21#define ORES_IAM_DOMAIN_ROLE_HPP
22
23#include <chrono>
24#include <optional>
25#include <string>
26#include <vector>
27#include <boost/uuid/uuid.hpp>
28#include "ores.utility/uuid/tenant_id.hpp"
29
30namespace ores::iam::domain {
31
41struct role final {
45 int version = 0;
46
51
55 boost::uuids::uuid id;
56
60 std::string name;
61
65 std::string description;
66
70 std::string modified_by;
71
77 std::string change_reason_code;
78
82 std::string change_commentary;
83
87 std::string performed_by;
88
92 std::chrono::system_clock::time_point recorded_at;
93
100 std::vector<std::string> permission_codes;
101};
102
106namespace roles {
107 constexpr auto super_admin = "SuperAdmin";
108 constexpr auto tenant_admin = "TenantAdmin";
109 constexpr auto trading = "Trading";
110 constexpr auto sales = "Sales";
111 constexpr auto operations = "Operations";
112 constexpr auto support = "Support";
113 constexpr auto viewer = "Viewer";
114}
115
116}
117
118#endif
Domain types for identity and access management.
Definition account.hpp:29
Represents a named collection of permissions that can be assigned to accounts.
Definition role.hpp:41
std::string modified_by
Username of the person who last modified this role.
Definition role.hpp:70
std::string change_commentary
Free-text commentary explaining the change.
Definition role.hpp:82
std::string description
Human-readable description of the role's purpose and scope.
Definition role.hpp:65
std::chrono::system_clock::time_point recorded_at
Timestamp when this version of the record was recorded.
Definition role.hpp:92
std::string name
Unique name for the role (e.g., "Trading", "Sales", "Admin").
Definition role.hpp:60
boost::uuids::uuid id
Unique identifier for the role.
Definition role.hpp:55
int version
Version number for optimistic locking and change tracking.
Definition role.hpp:45
std::string performed_by
Username of the account that performed this operation.
Definition role.hpp:87
std::vector< std::string > permission_codes
Permission codes granted to this role.
Definition role.hpp:100
utility::uuid::tenant_id tenant_id
Tenant identifier for multi-tenancy isolation.
Definition role.hpp:50
std::string change_reason_code
Code identifying the reason for the change.
Definition role.hpp:77
A strongly-typed wrapper around a UUID representing a tenant identifier.
Definition tenant_id.hpp:66
static tenant_id system()
Creates a tenant_id representing the system tenant.
Definition tenant_id.cpp:41