该系统为使用PHP开发的基于web的Subversion(SVN)服务器端管理工具。支持功能:SVN仓库管理、SVN用户管理、SVN分组管理、目录授权、目录浏览、Hooks管理、在线dump备份、在线备份恢复、SVN用户禁用、服务器状态管理、日志管理、消息通知、更新检测...
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

566 lines
20 KiB

<?php
/*
* @Author: witersen
* @Date: 2022-04-27 15:57:48
* @LastEditors: witersen
* @LastEditTime: 2022-05-09 16:37:46
* @Description: QQ:1801168257
* @copyright: https://github.com/witersen/
*/
namespace SVNAdmin\SVN;
class User extends Core
{
function __construct($authzFileContent, $passwdFileContent, $config_svn, $config_bin)
{
parent::__construct($authzFileContent, $passwdFileContent, $config_svn, $config_bin);
}
/**
* 不提供修改SVN用户名称的方法
* 一个不变的用户对应SVN仓库所有的历史记录是非常有必要的
*/
/**
* 添加SVN用户
*
* 0 文件格式错误(不存在[users]标识)
* 1 用户已存在
* string 正常
*/
function AddSvnUser($passwdContent, $userName, $userPass)
{
$userName = trim($userName);
$userPass = trim($userPass);
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
$userStr = "\n$userName=$userPass\n";
return $passwdContent . $userStr;
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
$enabledAllUser = $resultPreg[1];
array_walk($enabledAllUser, 'FunArrayValueEnabled');
if (in_array($userName, $resultPreg[1]) || in_array($userName, $enabledAllUser)) {
return '1';
}
$resultStr = "[users]\n";
foreach (array_combine($resultPreg[1], $resultPreg[3]) as $key => $value) {
$resultStr .= "$key=$value\n";
}
$resultStr .= "$userName=$userPass\n";
return $resultStr;
}
} else {
return '0';
}
}
/**
* 修改SVN用户(passwd文件中)
*/
function UpdSvnUserPasswd($passwdContent, $oldUserName, $newUserName)
{
//不提供此方法
}
/**
* 删除SVN用户
*
* 0 文件格式错误(不存在[users]标识)
* 1 用户不存在
* string 正常
*/
function DelSvnUserPasswd($passwdContent, $userName, $isDisabledUser = false)
{
$userName = trim($userName);
$userName = $isDisabledUser ? ($this->REG_SVN_USER_DISABLED . $userName) : $userName;
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
return '1';
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
if (in_array($userName, $resultPreg[1])) {
$resultStr = "[users]\n";
foreach (array_combine($resultPreg[1], $resultPreg[3]) as $key => $value) {
if ($key == $userName) {
continue;
}
$resultStr .= "$key=$value\n";
}
return $resultStr;
}
return '1';
}
} else {
return '0';
}
}
/**
* 获取SVN用户列表
*
* 文件格式错误(不存在[users]标识)
* 0
*
* 空列表
* []
*
* 正常数据
* Array
* (
* [0] => Array
* (
* [userName] => u1
* [disabled] => 1
* )
*
* [1] => Array
* (
* [userName] => u2
* [disabled] => 0
* )
*
* )
*/
function GetSvnUserList($passwdContent)
{
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
return [];
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
$result = [];
foreach ($resultPreg[1] as $value) {
$item = [];
if (substr($value, 0, strlen($this->REG_SVN_USER_DISABLED)) == $this->REG_SVN_USER_DISABLED) {
$item['userName'] = substr($value, strlen($this->REG_SVN_USER_DISABLED));
$item['disabled'] = '1';
} else {
$item['userName'] = $value;
$item['disabled'] = '0';
}
array_push($result, $item);
}
return $result;
}
} else {
return '0';
}
}
/**
* 获取SVN用户以及密码列表
*
* 文件格式错误(不存在[users]标识)
* 0
*
* 空数据
* []
*
* 正常数据
* Array
* (
* [0] => Array
* (
* [userName] => u1
* [userPass] => p1
* [disabled] => 1
* )
*
* [1] => Array
* (
* [userName] => u2
* [userPass] => p2
* [disabled] => 0
* )
*
* )
*/
function GetSvnUserPassList($passwdContent)
{
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$tem1 = trim($passwdContentPreg[1][0]);
if (empty($tem1)) {
return [];
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
$result = [];
foreach (array_combine($resultPreg[1], $resultPreg[3]) as $userName => $userPass) {
$item = [];
if (substr($userName, 0, strlen($this->REG_SVN_USER_DISABLED)) == $this->REG_SVN_USER_DISABLED) {
$item['userName'] = substr($userName, strlen($this->REG_SVN_USER_DISABLED));
$item['userPass'] = $userPass;
$item['disabled'] = '1';
} else {
$item['userName'] = $userName;
$item['userPass'] = $userPass;
$item['disabled'] = '0';
}
array_push($result, $item);
}
return $result;
}
} else {
return '0';
}
}
/**
* 获取SVN指定用户的密码
*
* 0 文件格式错误(不存在[users]标识)
* 1 用户不存在
* string 正常
*/
function GetPassByUser($passwdContent, $userName, $isDisabledUser = false)
{
$userName = trim($userName);
$userName = $isDisabledUser ? ($this->REG_SVN_USER_DISABLED . $userName) : $userName;
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
return [];
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
if (array_search($userName, $resultPreg[1]) !== false) {
return $resultPreg[3][array_search($userName, $resultPreg[1])];
} else {
return '1';
}
}
} else {
return '0';
}
}
/**
* 修改SVN指定用户的密码
*
* 0 文件格式错误(不存在[users]标识)
* 1 用户不存在
* string 正常
*/
function UpdSvnUserPass($passwdContent, $userName, $userPass, $isDisabledUser = false)
{
$userName = trim($userName);
$userPass = trim($userPass);
$userName = $isDisabledUser ? ($this->REG_SVN_USER_DISABLED . $userName) : $userName;
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
return '1';
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
if (in_array($userName, $resultPreg[1])) {
$resultStr = "[users]\n";
foreach (array_combine($resultPreg[1], $resultPreg[3]) as $key => $value) {
if ($key == $userName) {
$value = $userPass;
}
$resultStr .= "$key=$value\n";
}
return $resultStr;
}
return '1';
}
} else {
return '0';
}
}
/**
* 获取某个用户所在的分组列表
* $recursively = false 只获取用户与分组处于直接包含关系的分组列表
* $recursively = true 获取用户与分组处于直接包含关系的分组列表、获取处于分组嵌套分组导致用户与分组处于间接包含关系的分组列表
*
* 空列表
* []
*
* 正常数据
* Array
* (
* [0] => goup1
* [1] => group
* )
*/
function GetSvnUserGroupList($authzContent, $userName)
{
$userName = trim($userName);
preg_match_all($this->REG_AUTHZ_GROUP_WITH_CON, $authzContent, $authzContentPreg);
if (array_key_exists(0, $authzContentPreg[0])) {
$temp1 = trim($authzContentPreg[1][0]);
if (empty($temp1)) {
return [];
} else {
preg_match_all($this->REG_AUTHZ_USER_PRI, $authzContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[2], 'FunArrayValueTrim');
$userArray = [];
foreach (array_combine($resultPreg[1], $resultPreg[2]) as $groupStr => $userGroupStr) {
$userGroupArray = $userGroupStr == '' ? [] : explode(',', $userGroupStr);
array_walk($userGroupArray, 'FunArrayValueTrim');
if (in_array($userName, $userGroupArray)) {
array_push($userArray, $groupStr);
}
}
return $userArray;
}
} else {
return '0';
}
}
/**
* 获取某个用户有权限的所有仓库列表
*
*
* 空列表
* []
*
* 正常数据
* Array
* (
* [0] => rep1
* [1] => rep2
* )
*/
function GetUserPriRepListWithoutPri($authzContent, $userName)
{
$userName = trim($userName);
preg_match_all(sprintf($this->REG_AUTHZ_USER_PRI_REPS, $userName), $authzContent, $authzContentPreg);
if (array_key_exists(0, $authzContentPreg[1])) {
array_walk($authzContentPreg[1], 'FunArrayValueTrim');
return $authzContentPreg[1];
} else {
return [];
}
}
/**
* 获取某个用户有权限的所有仓库列表以及对应的权限
*
* 空列表
* []
*
* 正常数据
* Array
* (
* [0] => Array
* (
* [repName] => rep1
* [repPri] => rw
* )
* [1] => Array
* (
* [repName] => rep2
* [repPri] => rw
* )
* )
*/
function GetUserPriRepListWithPri($authzContent, $userName)
{
$userName = trim($userName);
preg_match_all(sprintf($this->REG_AUTHZ_USER_PRI_REPS, $userName), $authzContent, $authzContentPreg);
if (array_key_exists(0, $authzContentPreg[1])) {
array_walk($authzContentPreg[1], 'FunArrayValueTrim');
array_walk($authzContentPreg[3], 'FunArrayValueTrim');
$result = [];
foreach (array_combine($authzContentPreg[1], $authzContentPreg[3]) as $key => $value) {
$item = [];
$item['repName'] = $key;
$item['repPri'] = $value;
array_push($result, $item);
}
return $result;
} else {
return [];
}
}
/**
* 获取某个用户有权限的所有仓库列表(带有路径和权限)
*
* 空列表
* []
*
* 正常数据
* Array
* (
* [0] => Array
* (
* [repName] => rep1
* [priPath] => /
* [repPri] => rw
* )
* [1] => Array
* (
* [repName] => rep2
* [priPath] => /branches/taoweitao/计划.md
* [repPri] => rw
* )
* )
*/
function GetUserPriRepListWithPriAndPath($authzContent, $userName)
{
$userName = trim($userName);
preg_match_all(sprintf($this->REG_AUTHZ_USER_PRI_REPS, $userName), $authzContent, $authzContentPreg);
if (array_key_exists(0, $authzContentPreg[1])) {
array_walk($authzContentPreg[1], 'FunArrayValueTrim');
array_walk($authzContentPreg[2], 'FunArrayValueTrim');
array_walk($authzContentPreg[3], 'FunArrayValueTrim');
$result = [];
foreach ($authzContentPreg[1] as $key => $value) {
array_push($result, [
'repName' => $value,
'priPath' => $authzContentPreg[2][$key],
'repPri' => $authzContentPreg[3][$key],
'unique' => $value . ':' . $authzContentPreg[2][$key] . $authzContentPreg[3][$key]
]);
}
return $result;
} else {
return [];
}
}
/**
* 从所有仓库路径和分组下修改用户名
*
* string 正常
*/
function UpdUserAuthz($authzContent, $oldUserName, $newUserName)
{
}
/**
* 从所有仓库路径和分组下删除SVN用户
* 从所有分组中删除用户
* 从所有仓库下删除用户
*
* 0 文件格式错误(不存在[users]标识)
* string 正常
*/
function DelUserAuthz($authzContent, $userName)
{
$userName = trim($userName);
$content1 = "[groups]\n";
$content2 = "";
preg_match_all($this->REG_AUTHZ_GROUP_WITH_CON, $authzContent, $authzContentPreg1);
if (array_key_exists(0, $authzContentPreg1[0])) {
$temp1 = trim($authzContentPreg1[1][0]);
if (!empty($temp1)) {
preg_match_all($this->REG_AUTHZ_USER_PRI, $authzContentPreg1[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[2], 'FunArrayValueTrim');
$groupContent = "";
foreach (array_combine($resultPreg[1], $resultPreg[2]) as $groupStr => $userGroupStr) {
$groupContent .= "$groupStr=";
$userGroupArray = $userGroupStr == '' ? [] : explode(',', $userGroupStr);
array_walk($userGroupArray, 'FunArrayValueTrim');
if (in_array($userName, $userGroupArray)) {
unset($userGroupArray[array_search($userName, $userGroupArray)]);
}
$groupContent .= implode(',', $userGroupArray) . "\n";
}
$content1 .= $groupContent;
}
} else {
return '0';
}
$content2 = preg_replace("/([^@]^$userName" . "[\s]*=.*?)\n/m", "\n", str_replace($authzContentPreg1[0][0], '', $authzContent));
return $content1 . $content2;
}
/**
* 禁用某个SVN用户
* 0 文件格式错误(不存在[users]标识)
* 1 要禁用的用户不存在
* string 正常
*/
function DisabledUser($passwdContent, $userName)
{
$userName = trim($userName);
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
return '1';
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
if (in_array($userName, $resultPreg[1])) {
$resultStr = "[users]\n";
foreach (array_combine($resultPreg[1], $resultPreg[3]) as $key => $value) {
if ($key == $userName) {
$key = $this->REG_SVN_USER_DISABLED . $key;
}
$resultStr .= "$key=$value\n";
}
return $resultStr;
}
return '1';
}
} else {
return '0';
}
}
/**
* 启用某个SVN用户
* 0 文件格式错误(不存在[users]标识)
* 1 要启用的用户不存在
* string 正常
*/
function EnabledUser($passwdContent, $userName)
{
$userName = trim($userName);
preg_match_all($this->REG_PASSWD_USER_WITH_CON, $passwdContent, $passwdContentPreg);
if (array_key_exists(0, $passwdContentPreg[1])) {
$temp1 = trim($passwdContentPreg[1][0]);
if (empty($temp1)) {
return '1';
} else {
preg_match_all(sprintf($this->REG_PASSWD_USER_PASSWD, $this->REG_SVN_USER_DISABLED), $passwdContentPreg[1][0], $resultPreg);
array_walk($resultPreg[1], 'FunArrayValueTrim');
array_walk($resultPreg[3], 'FunArrayValueTrim');
if (in_array($this->REG_SVN_USER_DISABLED . $userName, $resultPreg[1])) {
$resultStr = "[users]\n";
foreach (array_combine($resultPreg[1], $resultPreg[3]) as $key => $value) {
if ($key == $this->REG_SVN_USER_DISABLED . $userName) {
$key = $userName;
}
$resultStr .= "$key=$value\n";
}
return $resultStr;
}
return '1';
}
} else {
return '0';
}
}
}