3

我们在 SonarQube 7.0 中使用 AD/LDAP 进行身份验证...我们成功实现了 AD/LDAP 身份验证...但是我们想通过程序(php / Python)将项目级别的权限授予不同的用户。

SonarQube 建议使用如下 web api

POST api/permissions/add_user

Params      
 1. login = XXX
 2. permission = user / codereviewer / scan / issueadmin
 3. projectid (optional )
 4. projectkey (optional ) = ABC

SonarQube 文档建议的示例请求

curl -X POST -v -u admin:admin 'http://localhost:9000/api/permissions/add_user?permission=codeviewer&user=XXX&component=ABC'

我们尝试编写 php curl 来处理 post web 请求并获得 json 响应,如下所示:

<?php
$ch = curl_init();

curl_setopt($ch, CURLOPT_URL,"http://localhost:9000/api/permissions/add_user");
curl_setopt($ch, CURLOPT_POST, 1);
curl_setopt($ch, CURLOPT_POSTFIELDS,
            "login=XXX&permission=user&projectkey=ABC");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

$server_output = curl_exec ($ch);

curl_close ($ch);

if ($server_output == "OK") { ... } else { ... }

?>

它没有反映用户 XXX.... 的 ABC 项目权限的任何更改。

谁能指导我这个话题?

我想知道 Sonarqube Web api 发布请求的算法...例如,要访问此发布请求,我们需要在 api/permission 之前为 sonarqube 提供 Web api 管理员登录/注销,或者它需要一些 cookie 或令牌...

谢谢你在这方面帮助我..

4

1 回答 1

1

使用“projectKey”而不是“projectkey”

于 2018-05-31T10:05:37.693 回答