From 829fe6c6bc33d53fda9c31fd45a37e1df87befff Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期五, 30 一月 2026 11:16:24 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/Servo/CUserManager2.h |   48 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 48 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/Servo/CUserManager2.h b/SourceCode/Bond/Servo/CUserManager2.h
new file mode 100644
index 0000000..794f454
--- /dev/null
+++ b/SourceCode/Bond/Servo/CUserManager2.h
@@ -0,0 +1,48 @@
+#pragma once
+
+#include <string>
+#include <vector>
+
+class CUserManager2
+{
+public:
+	static CUserManager2& getInstance();
+	CUserManager2(const CUserManager2&) = delete;
+	CUserManager2& operator=(const CUserManager2&) = delete;
+
+	struct RoleInfo
+	{
+		std::wstring name;
+		int level = 0;
+	};
+
+	struct UserInfo
+	{
+		std::wstring userName;
+		std::wstring displayName;
+		std::wstring roleName;
+		int roleLevel = 0;
+		bool enabled = false;
+	};
+
+public:
+	void init(const char* pszDir);
+	bool login(const char* pszAccount, const char* pszPwd);
+	bool isLoggedIn();
+	std::string getCurrentUserName();
+	bool IsAdminCurrent();
+	std::vector<RoleInfo> getRoles();
+	std::vector<UserInfo> getUsers();
+	int addUser(const std::wstring& userName, const std::wstring& displayName,
+		const std::wstring& password, const std::wstring& roleName, bool enabled);
+	int updateUser(const std::wstring& userName, const std::wstring& displayName,
+		const std::wstring& password, const std::wstring& roleName, bool enabled);
+	int deleteUser(const std::wstring& userName);
+	int setUserEnabled(const std::wstring& userName, bool enabled);
+	int resetPassword(const std::wstring& userName, const std::wstring& password);
+
+private:
+	CUserManager2();
+	~CUserManager2();
+};
+

--
Gitblit v1.9.3