13 namespace Fossology\UI\Api\Controllers;
30 use Psr\Http\Message\ServerRequestInterface;
47 public function getUsers($request, $response, $args)
52 if (isset($args[
'pathParam'])) {
53 if ($apiVersion == ApiVersion::V2) {
54 $user = $this->restHelper->getUserDao()->getUserByName($args[
'pathParam']);
58 $id = intval($user[
'user_pk']);
60 $id = intval($args[
'pathParam']);
62 if (! $this->dbHelper->doesIdExist(
"users",
"user_pk", $id)) {
66 $users = $this->dbHelper->getUsers($id);
69 foreach ($users as $user) {
70 $allUsers[] = $user->getArray($apiVersion);
73 $allUsers = $allUsers[0];
75 return $response->withJson($allUsers, 200);
87 public function addUser($request, $response, $args)
92 if ($userDetails ===
null || !is_array($userDetails)) {
95 if (empty($userDetails[
'name'])) {
100 $symfonyRequest = new \Symfony\Component\HttpFoundation\Request();
101 $symfonyRequest->request->set(
'username', $userDetails[
'name']);
102 $symfonyRequest->request->set(
'pass1', $userDetails[$apiVersion == ApiVersion::V2 ?
'userPass' :
'user_pass']);
103 $symfonyRequest->request->set(
'pass2', $userDetails[$apiVersion == ApiVersion::V2 ?
'userPass' :
'user_pass']);
104 $symfonyRequest->request->set(
'description', $userDetails[
'description']);
105 $symfonyRequest->request->set(
'permission', $userHelper->getEquivalentValueForPermission($userDetails[
'accessLevel']));
106 $symfonyRequest->request->set(
'folder', $userDetails[
'rootFolderId']);
107 $symfonyRequest->request->set(
'enote', $userDetails[
'emailNotification'] ?
'y' :
'n');
108 $symfonyRequest->request->set(
'email', $userDetails[
'email']);
109 $symfonyRequest->request->set(
'public', $userDetails[
'defaultVisibility']);
110 $symfonyRequest->request->set(
'default_bucketpool_fk', $userDetails[
'defaultBucketpool'] ?? 2);
113 if (isset($userDetails[
'agents'])) {
114 if (is_string($userDetails[
'agents'])) {
115 $userDetails[
'agents'] = json_decode($userDetails[
'agents'],
true);
117 $agents[
'Check_agent_mimetype'] = isset($userDetails[
'agents'][
'mime']) && $userDetails[
'agents'][
'mime'] ? 1 : 0;
118 $agents[
'Check_agent_monk'] = isset($userDetails[
'agents'][
'monk']) && $userDetails[
'agents'][
'monk'] ? 1 : 0;
119 $agents[
'Check_agent_ojo'] = isset($userDetails[
'agents'][
'ojo']) && $userDetails[
'agents'][
'ojo'] ? 1 : 0;
120 $agents[
'Check_agent_bucket'] = isset($userDetails[
'agents'][
'bucket']) && $userDetails[
'agents'][
'bucket'] ? 1 : 0 ;
121 $agents[
'Check_agent_copyright'] = isset($userDetails[
'agents'][$apiVersion == ApiVersion::V2 ?
'copyrightEmailAuthor' :
'copyright_email_author']) && $userDetails[
'agents'][$apiVersion == ApiVersion::V2 ?
'copyrightEmailAuthor' :
'copyright_email_author'] ? 1 : 0;
122 $agents[
'Check_agent_ecc'] = isset($userDetails[
'agents'][
'ecc']) && $userDetails[
'agents'][
'ecc'] ? 1 : 0;
123 $agents[
'Check_agent_keyword'] = isset($userDetails[
'agents'][
'keyword']) && $userDetails[
'agents'][
'keyword'] ? 1 : 0;
124 $agents[
'Check_agent_nomos'] = isset($userDetails[
'agents'][
'nomos']) && $userDetails[
'agents'][
'nomos'] ? 1 : 0;
125 $agents[
'Check_agent_pkgagent'] = isset($userDetails[
'agents'][
'package']) && $userDetails[
'agents'][
'package'] ? 1 : 0;
126 $agents[
'Check_agent_reso'] = isset($userDetails[
'agents'][
'reso']) && $userDetails[
'agents'][
'reso'] ? 1 : 0;
127 $agents[
'Check_agent_shagent'] = isset($userDetails[
'agents'][
'heritage']) && $userDetails[
'agents'][
'heritage'] ? 1 : 0 ;
130 $symfonyRequest->request->set(
'user_agent_list',
userAgents($agents));
138 $ErrMsg = $userAddObj->add($symfonyRequest);
144 $returnVal =
new Info(201,
"User created successfully", InfoType::INFO);
145 return $response->withJson($returnVal->getArray(), $returnVal->getCode());
161 if ($apiVersion == ApiVersion::V2) {
162 $user = $this->restHelper->getUserDao()->getUserByName($args[
'pathParam']);
163 if ($user ===
null) {
166 $id = intval($user[
'user_pk']);
168 $id = intval($args[
'pathParam']);
170 if (!$this->dbHelper->doesIdExist(
"users",
"user_pk", $id)) {
174 $this->dbHelper->deleteUser($id);
175 $returnVal =
new Info(202,
"User will be deleted", InfoType::INFO);
176 return $response->withJson($returnVal->getArray(), $returnVal->getCode());
190 $user = $this->dbHelper->getUsers($this->restHelper->getUserId())[0]->getArray($apiVersion);
191 if ($apiVersion == ApiVersion::V2) {
192 return $response->withJson($user, 200);
194 $userDao = $this->restHelper->getUserDao();
195 $defaultGroup = $userDao->getUserAndDefaultGroupByUserName($user[
"name"])[
"group_name"];
196 $user[
'default_group'] = $defaultGroup;
197 return $response->withJson($user, 200);
212 if ($apiVersion == ApiVersion::V2) {
213 $user = $this->restHelper->getUserDao()->getUserByName($args[
'pathParam']);
214 if ($user ===
null) {
217 $id = intval($user[
'user_pk']);
219 $id = intval($args[
'pathParam']);
221 if ($id !== intval($this->restHelper->getUserId())) {
224 if (!$this->dbHelper->doesIdExist(
"users",
"user_pk", $id)) {
229 $returnVal = $userHelper->modifyUserDetails($reqBody, $apiVersion);
230 return $response->withJson($returnVal->getArray(), $returnVal->getCode());
242 public function createRestApiToken($request, $response, $args)
247 $symfonyRequest = new \Symfony\Component\HttpFoundation\Request();
250 $symfonyRequest->request->set(
'pat_name', $tokenRequest->getTokenName());
251 $symfonyRequest->request->set(
'pat_expiry', $tokenRequest->getTokenExpire());
252 $symfonyRequest->request->set(
'pat_scope', $tokenRequest->getTokenScope());
259 $userEditObj =
$restHelper->getPlugin(
'user_edit');
263 $token = $userEditObj->generateNewToken($symfonyRequest);
264 }
catch (DuplicateTokenKeyException $e) {
265 throw new HttpTooManyRequestException(
"Please try again later.", $e);
266 }
catch (DuplicateTokenNameException $e) {
267 throw new HttpConflictException($e->getMessage(), $e);
268 }
catch (\UnexpectedValueException $e) {
269 throw new HttpBadRequestException($e->getMessage(), $e);
272 $returnVal =
new Info(201,
"Token created successfully", InfoType::INFO);
273 $res = $returnVal->getArray();
274 $res[
'token'] = $token;
275 return $response->withJson($res, $returnVal->getCode());
290 $tokenType = $args[
'type'];
291 if ($tokenType !=
"active" && $tokenType !=
"expired") {
297 $userEditObj =
$restHelper->getPlugin(
'user_edit');
300 $tokens = $tokenType ==
"active" ? $userEditObj->getListOfActiveTokens() : $userEditObj->getListOfExpiredTokens();
301 $manageTokenObj =
$restHelper->getPlugin(
'manage-token');
303 $finalTokens = array();
304 foreach ($tokens as $token) {
305 list($tokenPk) = explode(
".", $token[
'id']);
306 $tokenVal = $manageTokenObj->revealToken($tokenPk);
307 $finalTokens[] = array_merge($token, [
'token' => $tokenVal[
'token']]);
310 $returnVal =
new Info(200,
"Success", InfoType::INFO);
311 $res = $returnVal->getArray();
312 $res[$tokenType . ($apiVersion == ApiVersion::V2 ?
'Tokens' :
'_tokens')] = $finalTokens;
313 return $response->withJson($res, $returnVal->getCode());
Exception when a token has duplicate key for same user.
Exception when a token has duplicate name for same user.
Base controller for REST calls.
getParsedBody(ServerRequestInterface $request)
Parse request body as JSON and return associative PHP array.
Controller for User model.
deleteUser($request, $response, $args)
addUser($request, $response, $args)
getUsers($request, $response, $args)
updateUser($request, $response, $args)
getCurrentUser($request, $response, $args)
getTokens($request, $response, $args)
Override Slim response for withJson function.
Provides various DAO helper functions for REST api.
Handle user related queries.
static getVersion(ServerRequestInterface $request)
Different type of infos provided by REST.
Info model to contain general error and return values.
static fromArray(array $input, int $version)
userAgents($agents=null)
Read the UI form and format the user selected agents into a comma separated list.