mirror of
https://github.com/owncloud/ocis.git
synced 2025-04-18 23:44:07 +03:00
2908 lines
87 KiB
PHP
2908 lines
87 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
/**
|
|
* ownCloud
|
|
*
|
|
* @author Kiran Parajuli <kiran@jankaritech.com>
|
|
* @copyright Copyright (c) 2021 Kiran Parajuli kiran@jankaritech.com
|
|
*/
|
|
|
|
use Behat\Behat\Context\Context;
|
|
use Behat\Behat\Hook\Scope\BeforeScenarioScope;
|
|
use Behat\Gherkin\Node\PyStringNode;
|
|
use Behat\Gherkin\Node\TableNode;
|
|
use GuzzleHttp\Exception\GuzzleException;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
use TestHelpers\GraphHelper;
|
|
use TestHelpers\WebDavHelper;
|
|
use PHPUnit\Framework\Assert;
|
|
use TestHelpers\HttpRequestHelper;
|
|
|
|
require_once 'bootstrap.php';
|
|
|
|
/**
|
|
* Context for the provisioning specific steps using the Graph API
|
|
*/
|
|
class GraphContext implements Context {
|
|
private FeatureContext $featureContext;
|
|
|
|
/**
|
|
* application Entity
|
|
*/
|
|
private array $appEntity = [];
|
|
|
|
/**
|
|
* This will run before EVERY scenario.
|
|
* It will set the properties for this object.
|
|
*
|
|
* @BeforeScenario
|
|
*
|
|
* @param BeforeScenarioScope $scope
|
|
*
|
|
* @return void
|
|
*/
|
|
public function before(BeforeScenarioScope $scope): void {
|
|
// Get the environment
|
|
$environment = $scope->getEnvironment();
|
|
// Get all the contexts you need in this context from here
|
|
$this->featureContext = $environment->getContext('FeatureContext');
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
* @param string|null $userName
|
|
* @param string|null $password
|
|
* @param string|null $email
|
|
* @param string|null $displayName
|
|
* @param string|null $requester
|
|
* @param string|null $requesterPassword
|
|
*
|
|
* @return void
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userHasBeenEditedUsingTheGraphApi(
|
|
string $user,
|
|
?string $userName = null,
|
|
?string $password = null,
|
|
?string $email = null,
|
|
?string $displayName = null,
|
|
?string $requester = null,
|
|
?string $requesterPassword = null
|
|
): void {
|
|
if (!$requester) {
|
|
$requester = $this->featureContext->getAdminUsername();
|
|
$requesterPassword = $this->featureContext->getAdminPassword();
|
|
}
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id');
|
|
$response = GraphHelper::editUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$requester,
|
|
$requesterPassword,
|
|
$userId,
|
|
$userName,
|
|
$password,
|
|
$email,
|
|
$displayName
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
$this->featureContext->theHttpStatusCodeShouldBe(200); // TODO 204 when prefer=minimal header was sent
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" changes the email of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
* @When /^the user "([^"]*)" tries to change the email of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
* @param string $email
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserChangesTheEmailOfUserToUsingTheGraphApi(string $byUser, string $user, string $email): void {
|
|
$response = $this->editUserUsingTheGraphApi($byUser, $user, null, null, $email);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" changes the display name of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
* @When /^the user "([^"]*)" tries to change the display name of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
* @param string $displayName
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserChangesTheDisplayNameOfUserToUsingTheGraphApi(string $byUser, string $user, string $displayName): void {
|
|
$response = $this->editUserUsingTheGraphApi($byUser, $user, null, null, null, $displayName);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" changes the user name of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
* @When /^the user "([^"]*)" tries to change the user name of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
* @param string $userName
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserChangesTheUserNameOfUserToUsingTheGraphApi(string $byUser, string $user, string $userName): void {
|
|
$response = $this->editUserUsingTheGraphApi($byUser, $user, $userName);
|
|
$this->featureContext->setResponse($response);
|
|
// need to add user to list to delete him after test
|
|
if (!empty($userName) && $this->featureContext->getAttributeOfCreatedUser($userName, 'id')) {
|
|
$this->featureContext->addUserToCreatedUsersList($userName, $this->featureContext->getUserPassword($user));
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" disables user "([^"]*)" using the Graph API$/
|
|
* @When /^the user "([^"]*)" tries to disable user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserDisablesUserToUsingTheGraphApi(string $byUser, string $user): void {
|
|
$response = $this->editUserUsingTheGraphApi($byUser, $user, null, null, null, null, false);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @Given /^the user "([^"]*)" has disabled user "([^"]*)"$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserHasDisabledUser(string $byUser, string $user): void {
|
|
$response = $this->editUserUsingTheGraphApi($byUser, $user, null, null, null, null, false);
|
|
$this->featureContext->theHTTPStatusCodeShouldBe(200, '', $response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" enables user "([^"]*)" using the Graph API$/
|
|
* @When /^the user "([^"]*)" tries to enable user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserEnablesUserToUsingTheGraphApi(string $byUser, string $user): void {
|
|
$response = $this->editUserUsingTheGraphApi($byUser, $user);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @Then /^the user information of "([^"]*)" should match this JSON schema$/
|
|
*
|
|
* @param string $user
|
|
* @param PyStringNode $schemaString
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
* @throws JsonException
|
|
*/
|
|
public function theUserInformationShouldMatchTheJSON(string $user, PyStringNode $schemaString): void {
|
|
$response = $this->adminHasRetrievedUserUsingTheGraphApi($user);
|
|
$responseBody = $this->featureContext->getJsonDecodedResponseBodyContent($response);
|
|
$this->featureContext->assertJsonDocumentMatchesSchema(
|
|
$responseBody,
|
|
$this->featureContext->getJSONSchema($schemaString)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Edits the user information
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
* @param string|null $userName
|
|
* @param string|null $password
|
|
* @param string|null $email
|
|
* @param string|null $displayName
|
|
* @param bool|true $accountEnabled
|
|
* @param string $method
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function editUserUsingTheGraphApi(string $byUser, string $user, string $userName = null, string $password = null, string $email = null, string $displayName = null, bool $accountEnabled = true, string $method="PATCH"): ResponseInterface {
|
|
$user = $this->featureContext->getActualUsername($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id') ?: $user;
|
|
return GraphHelper::editUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$byUser,
|
|
$this->featureContext->getPasswordForUser($byUser),
|
|
$userId,
|
|
$method,
|
|
$userName,
|
|
$password,
|
|
$email,
|
|
$displayName,
|
|
$accountEnabled
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function adminHasRetrievedUserUsingTheGraphApi(string $user): ResponseInterface {
|
|
$user = $this->featureContext->getActualUsername($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, "id");
|
|
$userId = $userId ?: $user;
|
|
return GraphHelper::getUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$this->featureContext->getAdminUsername(),
|
|
$this->featureContext->getAdminPassword(),
|
|
$userId
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param string $groupId
|
|
* @param string|null $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function deleteGroupWithId(
|
|
string $groupId,
|
|
?string $user = null
|
|
): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::deleteGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$groupId
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param string $group
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function deleteGroupWithName(
|
|
string $group
|
|
): ResponseInterface {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
return $this->deleteGroupWithId($groupId);
|
|
}
|
|
|
|
/**
|
|
* sends a request to delete a user using the Graph API
|
|
*
|
|
* @param string $user username is used as the id
|
|
* @param string|null $byUser
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function adminDeletesUserUsingTheGraphApi(string $user, ?string $byUser = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
return GraphHelper::deleteUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$user
|
|
);
|
|
}
|
|
|
|
/**
|
|
* remove user from a group
|
|
*
|
|
* @param string $group
|
|
* @param string $user
|
|
* @param string|null $byUser
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function removeUserFromGroup(string $group, string $user, ?string $byUser = null): ResponseInterface {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id") ?: WebDavHelper::generateUUIDv4();
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
return GraphHelper::removeUserFromGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$userId,
|
|
$groupId,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* sends a request to delete a user with the help of userID using the Graph API
|
|
*
|
|
* @param string $userId
|
|
* @param string $byUser
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function deleteUserByUserIdUsingTheGraphApi(string $userId, string $byUser): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
return GraphHelper::deleteUserByUserId(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$userId
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" deletes a user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theUserDeletesAUserUsingTheGraphAPI(string $byUser, string $user): void {
|
|
$userId = $this->featureContext->getUserIdByUserName($user);
|
|
$this->featureContext->setResponse($this->deleteUserByUserIdUsingTheGraphApi($userId, $byUser));
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" tries to delete a nonexistent user using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserTriesToDeleteNonExistingUser(string $byUser): void {
|
|
$userId = WebDavHelper::generateUUIDv4();
|
|
$this->featureContext->setResponse($this->deleteUserByUserIdUsingTheGraphApi($userId, $byUser));
|
|
}
|
|
|
|
/**
|
|
* @Given /^the user "([^"]*)" has deleted a user "([^"]*)"$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theUserHasDeletedAUser(string $byUser, string $user): void {
|
|
$response = $this->adminDeletesUserUsingTheGraphApi($user, $byUser);
|
|
$this->featureContext->theHttpStatusCodeShouldBe(204, "", $response);
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function adminHasRemovedUserFromGroupUsingTheGraphApi(string $user, string $group): void {
|
|
$user = $this->featureContext->getActualUsername($user);
|
|
$response = $this->removeUserFromGroup($group, $user);
|
|
$this->featureContext->TheHTTPStatusCodeShouldBe(204, '', $response);
|
|
}
|
|
|
|
/**
|
|
* check if the provided user is present as a member in the provided group
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return bool
|
|
* @throws JsonException
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function getUserPresenceInGroupUsingTheGraphApi(string $user, string $group): bool {
|
|
$user = $this->featureContext->getActualUsername($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, "id");
|
|
$members = $this->theAdminHasRetrievedMembersListOfGroupUsingTheGraphApi($group);
|
|
$found = false;
|
|
foreach ($members as $member) {
|
|
if ($member["id"] === $userId) {
|
|
$found = true;
|
|
break;
|
|
}
|
|
}
|
|
return $found;
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userShouldNotBeMemberInGroupUsingTheGraphApi(string $user, string $group): void {
|
|
$found = $this->getUserPresenceInGroupUsingTheGraphApi($user, $group);
|
|
Assert::assertFalse($found, __METHOD__ . " User $user is member of group $group");
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userShouldBeMemberInGroupUsingTheGraphApi(string $user, string $group): void {
|
|
$found = $this->getUserPresenceInGroupUsingTheGraphApi($user, $group);
|
|
Assert::assertTrue($found, __METHOD__ . "User $user is not member of group $group");
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
* @param string $password
|
|
* @param string|null $byUser
|
|
*
|
|
* @return void
|
|
* @throws JsonException
|
|
*/
|
|
public function adminChangesPasswordOfUserToUsingTheGraphApi(
|
|
string $user,
|
|
string $password,
|
|
?string $byUser = null
|
|
): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
$user = $this->featureContext->getActualUsername($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, "id") ?: $user;
|
|
return GraphHelper::editUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$userId,
|
|
"PATCH",
|
|
$user,
|
|
$password
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" resets the password of user "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
* @param string $password
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theUserResetsThePasswordOfUserToUsingTheGraphApi(string $byUser, string $user, string $password) {
|
|
$response = $this->adminChangesPasswordOfUserToUsingTheGraphApi($user, $password, $byUser);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $groups
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theseGroupsShouldBeInTheResponse(array $groups): void {
|
|
$respondedGroups = $this->getArrayOfGroupsResponded($this->featureContext->getResponse());
|
|
foreach ($groups as $group) {
|
|
$found = false;
|
|
foreach ($respondedGroups as $respondedGroup) {
|
|
if ($respondedGroup["displayName"] === $group) {
|
|
$found = true;
|
|
break;
|
|
}
|
|
}
|
|
Assert::assertTrue($found, "Group '$group' not found in the list");
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param array $users
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theseUsersShouldBeInTheResponse(array $users): void {
|
|
$respondedUsers = $this->getArrayOfUsersResponded($this->featureContext->getResponse());
|
|
foreach ($users as $user) {
|
|
$found = false;
|
|
foreach ($respondedUsers as $respondedUser) {
|
|
if ($respondedUser["onPremisesSamAccountName"] === $user) {
|
|
$found = true;
|
|
break;
|
|
}
|
|
}
|
|
Assert::assertTrue($found, "User '$user' not found in the list");
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string|null $user
|
|
*
|
|
* @return array
|
|
*/
|
|
public function getAdminOrUserCredentials(?string $user): array {
|
|
$credentials["username"] = $user ? $this->featureContext->getActualUsername($user) : $this->featureContext->getAdminUsername();
|
|
$credentials["password"] = $user ? $this->featureContext->getPasswordForUser($user) : $this->featureContext->getAdminPassword();
|
|
return $credentials;
|
|
}
|
|
/**
|
|
*
|
|
* @param string|null $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function listGroups(?string $user = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::getGroups(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* returns list of groups
|
|
*
|
|
* @param ResponseInterface $response
|
|
*
|
|
* @return array
|
|
* @throws Exception
|
|
*/
|
|
public function getArrayOfGroupsResponded(ResponseInterface $response): array {
|
|
if ($response->getStatusCode() === 200) {
|
|
$jsonResponseBody = $this->featureContext->getJsonDecodedResponse($response);
|
|
return $jsonResponseBody["value"];
|
|
} else {
|
|
$this->throwHttpException($response, "Could not retrieve groups list.");
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @return array
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function adminHasRetrievedGroupListUsingTheGraphApi(): array {
|
|
return $this->getArrayOfGroupsResponded($this->listGroups());
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $group
|
|
* @param string|null $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function listGroupMembers(string $group, ?string $user = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::getMembersList(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$this->featureContext->getAttributeOfCreatedGroup($group, 'id')
|
|
);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $user
|
|
* @param string|null $group
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function listSingleOrAllGroupsAlongWithAllMemberInformation(string $user, ?string $group = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::getSingleOrAllGroupsAlongWithMembers(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
($group) ? $this->featureContext->getAttributeOfCreatedGroup($group, 'id') : null
|
|
);
|
|
}
|
|
|
|
/**
|
|
* returns list of users of a group
|
|
*
|
|
* @param ResponseInterface $response
|
|
*
|
|
* @return array
|
|
* @throws Exception
|
|
*/
|
|
public function getArrayOfUsersResponded(ResponseInterface $response): array {
|
|
if ($response->getStatusCode() === 200) {
|
|
return $this->featureContext->getJsonDecodedResponse($response);
|
|
} else {
|
|
$this->throwHttpException($response, "Could not retrieve group members list.");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* returns a list of members in a group
|
|
*
|
|
* @param string $group
|
|
*
|
|
* @return array
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theAdminHasRetrievedMembersListOfGroupUsingTheGraphApi(string $group): array {
|
|
return $this->getArrayOfUsersResponded($this->listGroupMembers($group));
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" creates a new user with the following attributes using the Graph API:$/
|
|
*
|
|
* @param string $user
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws Exception|GuzzleException
|
|
*/
|
|
public function theUserCreatesNewUser(string $user, TableNode $table): void {
|
|
$rows = $table->getRowsHash();
|
|
$response = GraphHelper::createUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$rows["userName"],
|
|
$rows["password"],
|
|
$rows["email"],
|
|
$rows["displayName"]
|
|
);
|
|
|
|
// add created user to list except for the user with an empty name
|
|
// because request /graph/v1.0/users/emptyUserName exits with 200
|
|
// and we cannot check that the user with empty name doesn't exist
|
|
if (!empty($rows["userName"])) {
|
|
$this->featureContext->addUserToCreatedUsersList(
|
|
$rows["userName"],
|
|
$rows["password"],
|
|
$rows["displayName"],
|
|
$rows["email"]
|
|
);
|
|
}
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* adds a user to a group
|
|
* NOTE: If you want to make a request with non-existing user or group,provide "nonexistent" as their name
|
|
*
|
|
* @param string $group
|
|
* @param string $user
|
|
* @param string|null $byUser
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function addUserToGroup(string $group, string $user, ?string $byUser = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
if ($group === "nonexistent") {
|
|
$groupId = WebDavHelper::generateUUIDv4();
|
|
} else {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
}
|
|
if ($user === "nonexistent") {
|
|
$userId = WebDavHelper::generateUUIDv4();
|
|
} else {
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, "id");
|
|
}
|
|
return GraphHelper::addUserToGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$userId,
|
|
$groupId
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Given /^the administrator has added a user "([^"]*)" to the group "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function adminHasAddedUserToGroupUsingTheGraphApi(
|
|
string $user,
|
|
string $group
|
|
): void {
|
|
$response = $this->addUserToGroup($group, $user);
|
|
$this->featureContext->theHTTPStatusCodeShouldBe(204, '', $response);
|
|
}
|
|
|
|
/**
|
|
* @When the administrator adds the following users to the following groups using the Graph API
|
|
*
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theAdministratorAddsTheFollowingUsersToTheFollowingGroupsUsingTheGraphAPI(TableNode $table): void {
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username', 'groupname']);
|
|
$userGroupList = $table->getColumnsHash();
|
|
|
|
foreach ($userGroupList as $userGroup) {
|
|
$this->featureContext->setResponse($this->addUserToGroup($userGroup['groupname'], $userGroup['username']));
|
|
$this->featureContext->pushToLastHttpStatusCodesArray();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @When the administrator tries to add nonexistent user to group :group using the Graph API
|
|
* @When user :byUser tries to add nonexistent user to group :group using the Graph API
|
|
*
|
|
* @param string $group
|
|
* @param string|null $byUser
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theAdministratorTriesToAddNonExistentUserToGroupUsingTheGraphAPI(string $group, ?string $byUser = null): void {
|
|
$this->featureContext->setResponse($this->addUserToGroup($group, "nonexistent", $byUser));
|
|
}
|
|
|
|
/**
|
|
* @When the administrator tries to add user :user to a nonexistent group using the Graph API
|
|
* @When user :byUser tries to add user :user to a nonexistent group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string|null $byUser
|
|
*
|
|
* @return void
|
|
*
|
|
* @throws GuzzleException | Exception
|
|
*/
|
|
public function theAdministratorTriesToAddUserToNonExistentGroupUsingTheGraphAPI(string $user, ?string $byUser = null): void {
|
|
$this->featureContext->setResponse($this->addUserToGroup("nonexistent", $user, $byUser));
|
|
}
|
|
|
|
/**
|
|
* @When user :user tries to add himself/herself to group :group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theUserTriesToAddHimselfToGroupUsingTheGraphAPI(string $user, string $group): void {
|
|
$this->featureContext->setResponse($this->addUserToGroup($group, $user, $user));
|
|
}
|
|
|
|
/**
|
|
* @When user :byUser tries to add user :user to group :group using the Graph API
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theUserTriesToAddAnotherUserToGroupUsingTheGraphAPI(string $byUser, string $user, string $group): void {
|
|
$this->featureContext->setResponse($this->addUserToGroup($group, $byUser, $user));
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $group
|
|
* @param ?string $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function createGroup(string $group, ?string $user = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::createGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$group,
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator creates a group "([^"]*)" using the Graph API$/
|
|
* @When user :user creates a group :group using the Graph API
|
|
* @When user :user tries to create a group :group using the Graph API
|
|
*
|
|
* @param string $group
|
|
* @param ?string $user
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userCreatesGroupUsingTheGraphApi(string $group, ?string $user = null): void {
|
|
$response = $this->createGroup($group, $user);
|
|
$this->featureContext->setResponse($response);
|
|
$this->featureContext->pushToLastHttpStatusCodesArray((string) $response->getStatusCode());
|
|
|
|
if ($response->getStatusCode() === 201) {
|
|
$groupId = $this->featureContext->getJsonDecodedResponse($response)["id"];
|
|
$this->featureContext->addGroupToCreatedGroupsList($group, true, true, $groupId);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Given /^the administrator has created a group "([^"]*)" using the Graph API$/
|
|
* @Given user :user has created a group :group using the Graph API
|
|
*
|
|
* @param string $group
|
|
* @param ?string $user
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userHasCreatedGroupUsingTheGraphApi(string $group, ?string $user = null): void {
|
|
$response = $this->createGroup($group, $user);
|
|
|
|
if ($response->getStatusCode() === 201) {
|
|
$groupId = $this->featureContext->getJsonDecodedResponse($response)["id"];
|
|
$this->featureContext->addGroupToCreatedGroupsList($group, true, true, $groupId);
|
|
} else {
|
|
$this->throwHttpException($response, "Could not create group '$group'.");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param ResponseInterface $response
|
|
* @param string $errorMsg
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
private function throwHttpException(ResponseInterface $response, string $errorMsg): void {
|
|
try {
|
|
$jsonBody = $this->featureContext->getJsonDecodedResponse($response);
|
|
throw new Exception(
|
|
__METHOD__
|
|
. "\n$errorMsg"
|
|
. "\nHTTP status code: " . $response->getStatusCode()
|
|
. "\nError code: " . $jsonBody["error"]["code"]
|
|
. "\nMessage: " . $jsonBody["error"]["message"]
|
|
);
|
|
} catch (TypeError $e) {
|
|
throw new Exception(
|
|
__METHOD__
|
|
. "\n$errorMsg"
|
|
. "\nHTTP status code: " . $response->getStatusCode()
|
|
. "\nResponse body: " . $response->getBody()
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @param string $shouldOrNot (not|)
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theseGroupsShouldNotExist(string $shouldOrNot, TableNode $table): void {
|
|
$should = ($shouldOrNot !== "not");
|
|
$this->featureContext->verifyTableNodeColumns($table, ['groupname']);
|
|
$actualGroupsList = $this->adminHasRetrievedGroupListUsingTheGraphApi();
|
|
$expectedGroups = $table->getColumnsHash();
|
|
// check if every expected group is(not) in the actual groups list
|
|
foreach ($expectedGroups as $expectedGroup) {
|
|
$groupName = $expectedGroup['groupname'];
|
|
$groupExists = false;
|
|
foreach ($actualGroupsList as $actualGroup) {
|
|
if ($actualGroup['displayName'] === $groupName) {
|
|
$groupExists = true;
|
|
break;
|
|
}
|
|
}
|
|
if ($groupExists !== $should) {
|
|
throw new Exception(
|
|
__METHOD__
|
|
. "\nGroup '$groupName' is expected " . ($should ? "" : "not ")
|
|
. "to exist, but it does" . ($should ? " not" : "") . " exist."
|
|
);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" changes its own password "([^"]*)" to "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $currentPassword
|
|
* @param string $newPassword
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function userChangesOwnPassword(string $user, string $currentPassword, string $newPassword): void {
|
|
$response = GraphHelper::changeOwnPassword(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$currentPassword,
|
|
$newPassword
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :user gets all the groups using the Graph API
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userGetsAllTheGroupsUsingTheGraphApi(string $user): void {
|
|
$this->featureContext->setResponse($this->listGroups($user));
|
|
}
|
|
|
|
/**
|
|
* @When user :user gets all the members of group :group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userGetsAllTheMembersOfGroupUsingTheGraphApi(string $user, string $group): void {
|
|
$this->featureContext->setResponse($this->listGroupMembers($group, $user));
|
|
}
|
|
|
|
/**
|
|
* @When user :user retrieves all groups along with their members using the Graph API
|
|
* @When user :user gets all the members information of group :group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userRetrievesAllMemberInformationOfSingleOrAllGroups(string $user, string $group = ''): void {
|
|
$this->featureContext->setResponse($this->listSingleOrAllGroupsAlongWithAllMemberInformation($user, $group));
|
|
}
|
|
|
|
/**
|
|
* @When user :user deletes group :group using the Graph API
|
|
* @When the administrator deletes group :group using the Graph API
|
|
* @When user :user tries to delete group :group using the Graph API
|
|
*
|
|
* @param string $group
|
|
* @param string|null $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userDeletesGroupUsingTheGraphApi(string $group, ?string $user = null): void {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id") ?: $group;
|
|
$response = $this->deleteGroupWithId($groupId, $user);
|
|
if ($response->getStatusCode() === 204) {
|
|
$this->featureContext->rememberThatGroupIsNotExpectedToExist($group);
|
|
}
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @Then the following users should be listed in the following groups
|
|
*
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theFollowingUsersShouldBeListedInFollowingGroups(TableNode $table): void {
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username', 'groupname']);
|
|
$usersGroups = $table->getColumnsHash();
|
|
foreach ($usersGroups as $userGroup) {
|
|
$members = $this->listGroupMembers($userGroup['groupname']);
|
|
$members = $this->featureContext->getJsonDecodedResponse($members);
|
|
|
|
$exists = false;
|
|
foreach ($members as $member) {
|
|
if ($member['onPremisesSamAccountName'] === $userGroup['username']) {
|
|
$exists = true;
|
|
break;
|
|
}
|
|
}
|
|
Assert::assertTrue(
|
|
$exists,
|
|
__METHOD__
|
|
. "\nExpected user '" . $userGroup['username'] . "' to be in group '" . $userGroup['groupname'] . "'. But not found."
|
|
);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* rename group name
|
|
*
|
|
* @param string $oldGroupId
|
|
* @param string $newGroup
|
|
* @param string|null $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function renameGroup(string $oldGroupId, string $newGroup, ?string $user = null): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::updateGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$oldGroupId,
|
|
$newGroup
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user renames group :oldGroup to :newGroup using the Graph API
|
|
* @When user :user tries to rename group :oldGroup to :newGroup using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $oldGroup
|
|
* @param string $newGroup
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userRenamesGroupUsingTheGraphApi(string $user, string $oldGroup, string $newGroup): void {
|
|
$oldGroupId = $this->featureContext->getAttributeOfCreatedGroup($oldGroup, "id");
|
|
$this->featureContext->setResponse($this->renameGroup($oldGroupId, $newGroup, $user));
|
|
}
|
|
|
|
/**
|
|
* @When user :user tries to rename a nonexistent group to :newGroup using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $newGroup
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function userTriesToRenameNonExistentGroupToNewGroupName(string $user, string $newGroup): void {
|
|
$oldGroupId = WebDavHelper::generateUUIDv4();
|
|
$this->featureContext->setResponse($this->renameGroup($oldGroupId, $newGroup, $user));
|
|
}
|
|
|
|
/**
|
|
* @When the administrator removes the following users from the following groups using the Graph API
|
|
*
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theAdministratorRemovesTheFollowingUsersFromTheFollowingGroupsUsingTheGraphApi(TableNode $table): void {
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username', 'groupname']);
|
|
$usersGroups = $table->getColumnsHash();
|
|
|
|
foreach ($usersGroups as $userGroup) {
|
|
$this->featureContext->setResponse($this->removeUserFromGroup($userGroup['groupname'], $userGroup['username']));
|
|
$this->featureContext->pushToLastHttpStatusCodesArray();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @When user :byUser tries to remove user :user from group :group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param string|null $byUser
|
|
*
|
|
* @return void
|
|
* @throws Exception | GuzzleException
|
|
*/
|
|
public function theUserTriesToRemoveAnotherUserFromGroupUsingTheGraphAPI(string $user, string $group, ?string $byUser = null): void {
|
|
$this->featureContext->setResponse($this->removeUserFromGroup($group, $user, $byUser));
|
|
}
|
|
|
|
/**
|
|
* @When the administrator tries to remove user :user from a nonexistent group using the Graph API
|
|
* @When user :byUser tries to remove user :user from a nonexistent group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string|null $byUser
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theUserTriesToRemoveAnotherUserFromNonExistentGroupUsingTheGraphAPI(string $user, ?string $byUser = null): void {
|
|
$this->featureContext->setResponse($this->removeUserFromGroup('', $user, $byUser));
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function retrieveUserInformationUsingGraphApi(
|
|
string $user
|
|
):ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
return GraphHelper::getOwnInformationAndGroupMemberships(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" retrieves (her|his) information using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws JsonException
|
|
*/
|
|
public function userRetrievesHisOrHerInformationOfUserUsingGraphApi(
|
|
string $user
|
|
):void {
|
|
$response = $this->retrieveUserInformationUsingGraphApi($user);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :byUser tries to get information of user :user using Graph API
|
|
* @When user :byUser gets information of user :user using Graph API
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userTriesToGetInformationOfUser(string $byUser, string $user): void {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
$response = GraphHelper::getUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$user
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :byUser tries to search for user :searchTerm using Graph API
|
|
* @When user :byUser searches for user :searchTerm using Graph API
|
|
*
|
|
* @param string $byUser
|
|
* @param string $searchTerm
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userSearchesForUserUsingGraphApi(string $byUser, string $searchTerm): void {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
$response = GraphHelper::searchUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$searchTerm,
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :byUser searches for federated user :searchTerm using Graph API
|
|
*
|
|
* @param string $byUser
|
|
* @param string $searchTerm
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userSearchesForFederatedUserUsingGraphApi(string $byUser, string $searchTerm): void {
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
$response = GraphHelper::searchFederatedUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$searchTerm,
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :user tries to get all users using the Graph API
|
|
* @When user :user gets all users using the Graph API
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllUserUsingTheGraphApi(string $user) {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$response = GraphHelper::getUsers(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @param string $byUser
|
|
* @param string|null $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function retrieveUserInformationAlongWithDriveUsingGraphApi(
|
|
string $byUser,
|
|
?string $user = null
|
|
):ResponseInterface {
|
|
$user = $user ?? $byUser;
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
return GraphHelper::getUserWithDriveInformation(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$user
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param string $byUser
|
|
* @param string|null $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws JsonException
|
|
* @throws GuzzleException
|
|
*/
|
|
public function retrieveUserInformationAlongWithGroupUsingGraphApi(
|
|
string $byUser,
|
|
?string $user = null
|
|
):ResponseInterface {
|
|
$user = $user ?? $byUser;
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
return GraphHelper::getUserWithGroupInformation(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$user
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" gets user "([^"]*)" along with (his|her) drive information using Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userTriesToGetInformationOfUserAlongWithHisDriveData(string $byUser, string $user) {
|
|
$response = $this->retrieveUserInformationAlongWithDriveUsingGraphApi($byUser, $user);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the user "([^"]*)" gets user "([^"]*)" along with (his|her) group information using Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userTriesToGetInformationOfUserAlongWithHisGroup(string $byUser, string $user) {
|
|
$response = $this->retrieveUserInformationAlongWithGroupUsingGraphApi($byUser, $user);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @When /^the user "([^"]*)" gets (his|her) drive information using Graph API$/
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userTriesToGetOwnDriveInformation(string $user) {
|
|
$response = $this->retrieveUserInformationAlongWithDriveUsingGraphApi($user);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* add multiple users in a group at once
|
|
*
|
|
* @param string $user
|
|
* @param array $userIds
|
|
* @param string $groupId
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function addMultipleUsersToGroup(string $user, array $userIds, string $groupId): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
return GraphHelper::addUsersToGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$groupId,
|
|
$userIds
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" adds the following users to a group "([^"]*)" at once using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theAdministratorAddsTheFollowingUsersToAGroupInASingleRequestUsingTheGraphApi(string $user, string $group, TableNode $table): void {
|
|
$userIds = [];
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
foreach ($table->getHash() as $row) {
|
|
$userIds[] = $this->featureContext->getAttributeOfCreatedUser($row['username'], "id");
|
|
}
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username']);
|
|
$response = $this->addMultipleUsersToGroup($user, $userIds, $groupId);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" tries to add the following users to a group "([^"]*)" at once with an invalid host using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userTriesToAddTheFollowingUsersToAGroupAtOnceWithInvalidHostUsingTheGraphApi(string $user, string $group, TableNode $table): void {
|
|
$userIds = [];
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username']);
|
|
|
|
foreach ($table->getHash() as $row) {
|
|
$userIds[] = $this->featureContext->getAttributeOfCreatedUser($row['username'], "id");
|
|
}
|
|
|
|
$payload = [ "members@odata.bind" => [] ];
|
|
foreach ($userIds as $userId) {
|
|
$payload["members@odata.bind"][] = GraphHelper::getFullUrl('https://invalid/', 'users/' . $userId);
|
|
}
|
|
|
|
$this->featureContext->setResponse(
|
|
HttpRequestHelper::sendRequest(
|
|
GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupId),
|
|
$this->featureContext->getStepLineRef(),
|
|
'PATCH',
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
['Content-Type' => 'application/json'],
|
|
\json_encode($payload)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" tries to add user "([^"]*)" to group "([^"]*)" with an invalid host using the Graph API$/
|
|
*
|
|
* @param string $adminUser
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userTriesToAddUserToGroupWithInvalidHostUsingTheGraphApi(string $adminUser, string $user, string $group): void {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($adminUser);
|
|
|
|
$body = [
|
|
"@odata.id" => GraphHelper::getFullUrl('https://invalid/', 'users/' . $userId)
|
|
];
|
|
|
|
$this->featureContext->setResponse(
|
|
HttpRequestHelper::post(
|
|
GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupId . '/members/$ref'),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
['Content-Type' => 'application/json'],
|
|
\json_encode($body)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add the following users to a nonexistent group at once using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddsTheFollowingUsersToANonExistingGroupAtOnceUsingTheGraphApi(string $user, TableNode $table): void {
|
|
$userIds = [];
|
|
$groupId = WebDavHelper::generateUUIDv4();
|
|
foreach ($table->getHash() as $row) {
|
|
$userIds[] = $this->featureContext->getAttributeOfCreatedUser($row['username'], "id");
|
|
}
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username']);
|
|
$response = $this->addMultipleUsersToGroup($user, $userIds, $groupId);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add the following nonexistent users to a group "([^"]*)" at once using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddTheFollowingNonExistingUsersToAGroupAtOnceUsingTheGraphApi(string $user, string $group, TableNode $table): void {
|
|
$userIds = [];
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
foreach ($table->getHash() as $row) {
|
|
$userIds[] = WebDavHelper::generateUUIDv4();
|
|
}
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username']);
|
|
$response = $this->addMultipleUsersToGroup($user, $userIds, $groupId);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add the following users to a group "([^"]*)" at once using the Graph API$/
|
|
* @When /^the administrator "([^"]*)" tries to add the following existent and nonexistent users to a group "([^"]*)" at once using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddTheFollowingUsersToAGroupAtOnceUsingTheGraphApi(string $user, string $group, TableNode $table): void {
|
|
$userIds = [];
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
foreach ($table->getHash() as $row) {
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($row['username'], "id");
|
|
$userIds[] = $userId ?: WebDavHelper::generateUUIDv4();
|
|
}
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username']);
|
|
$response = $this->addMultipleUsersToGroup($user, $userIds, $groupId);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :user gets all applications using the Graph API
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllApplicationsUsingTheGraphApi(string $user) {
|
|
$response = GraphHelper::getApplications(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @Then the user API response should contain the following application information:
|
|
*
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theResponseShouldContainTheFollowingApplicationInformation(TableNode $table): void {
|
|
Assert::assertIsArray($responseArray = ($this->featureContext->getJsonDecodedResponse($this->featureContext->getResponse()))['value'][0]);
|
|
foreach ($table->getHash() as $row) {
|
|
$key = $row["key"];
|
|
if ($key === 'id') {
|
|
Assert::assertTrue(
|
|
GraphHelper::isUUIDv4($responseArray[$key]),
|
|
__METHOD__ . ' Expected id to have UUIDv4 pattern but found: ' . $row["value"]
|
|
);
|
|
} else {
|
|
Assert::assertEquals($responseArray[$key], $row["value"]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Then the user API response should contain the following app roles:
|
|
*
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theResponseShouldContainTheFollowingAppRolesInformation(TableNode $table): void {
|
|
Assert::assertIsArray($responseArray = ($this->featureContext->getJsonDecodedResponse($this->featureContext->getResponse()))['value'][0]);
|
|
foreach ($table->getRows() as $row) {
|
|
$foundRoleInResponse = false;
|
|
foreach ($responseArray['appRoles'] as $role) {
|
|
if ($role['displayName'] === $row[0]) {
|
|
$foundRoleInResponse = true;
|
|
break;
|
|
}
|
|
}
|
|
Assert::assertTrue($foundRoleInResponse, "the response does not contain the role $row[0]");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @When the user :user gets all users of the group :group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllUsersOfTheGroupUsingTheGraphApi(string $user, string $group) {
|
|
$groupId = $this->featureContext->getGroupIdByGroupName($group);
|
|
$response = GraphHelper::getUsersWithFilterMemberOf(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$groupId
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When the user :user gets all users of two groups :groups using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $groups
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllUsersOfTwoGroupsUsingTheGraphApi(string $user, string $groups) {
|
|
$groupsIdArray = [];
|
|
foreach (explode(',', $groups) as $group) {
|
|
$groupsIdArray[] = $this->featureContext->getGroupIdByGroupName($group);
|
|
}
|
|
$response = GraphHelper::getUsersOfTwoGroups(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$groupsIdArray
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When the user :user gets all users that are members in the group :firstGroup or the group :secondGroup using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $firstGroup
|
|
* @param string $secondGroup
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllUsersOfFirstGroupOderSecondGroupUsingTheGraphApi(string $user, string $firstGroup, string $secondGroup) {
|
|
$response = GraphHelper::getUsersFromOneOrOtherGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$firstGroup,
|
|
$secondGroup
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* Get roleId by role name
|
|
*
|
|
* @param string $role
|
|
*
|
|
* @return string
|
|
* @throws GuzzleException
|
|
*/
|
|
public function getRoleIdByRoleName(string $role): string {
|
|
$response = GraphHelper::getApplications(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$this->featureContext->getAdminUsername(),
|
|
$this->featureContext->getAdminPassword()
|
|
);
|
|
$responseData = \json_decode($response->getBody()->getContents(), true, 512, JSON_THROW_ON_ERROR);
|
|
if (isset($responseData["value"][0]["appRoles"])) {
|
|
foreach ($responseData["value"][0]["appRoles"] as $value) {
|
|
if ($value["displayName"] === $role) {
|
|
return $value["id"];
|
|
}
|
|
}
|
|
throw new Exception(__METHOD__ . " role with name $role not found");
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @When the user :user gets all users with role :role using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $role
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllUsersWithRoleUsingTheGraphApi(string $user, string $role) {
|
|
$response = GraphHelper::getUsersWithFilterRoleAssignment(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$this->getRoleIdByRoleName($role)
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When the user :user gets all users with role :role and member of the group :group using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $role
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGetsAllUsersWithRoleAndMemberOfGroupUsingTheGraphApi(string $user, string $role, string $group) {
|
|
$response = GraphHelper::getUsersWithFilterRolesAssignmentAndMemberOf(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$this->getRoleIdByRoleName($role),
|
|
$this->featureContext->getGroupIdByGroupName($group)
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @Given /^the administrator has assigned the role "([^"]*)" to user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $role
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
*
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorHasGivenTheRoleUsingTheGraphApi(string $role, string $user): void {
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id') ?: $user;
|
|
|
|
if (empty($this->appEntity)) {
|
|
$this->setApplicationEntity();
|
|
}
|
|
|
|
$response = GraphHelper::assignRole(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$this->featureContext->getAdminUsername(),
|
|
$this->featureContext->getAdminPassword(),
|
|
$this->appEntity["appRoles"][$role],
|
|
$this->appEntity["id"],
|
|
$userId
|
|
);
|
|
Assert::assertEquals(
|
|
201,
|
|
$response->getStatusCode(),
|
|
__METHOD__
|
|
. "\nExpected status code '200' but got '" . $response->getStatusCode() . "'"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator retrieves the assigned role of user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userRetrievesAssignedRoleUsingTheGraphApi(string $user): void {
|
|
$admin = $this->featureContext->getAdminUserName();
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id') ?: $user;
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::getAssignedRole(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$admin,
|
|
$this->featureContext->getPasswordForUser($admin),
|
|
$userId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" tries to get the assigned role of user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $ofUser
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userTriesToGetAssignedRoleOfUserUsingTheGraphApi(string $user, string $ofUser): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($ofUser, 'id') ?: $user;
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::getAssignedRole(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$userId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* set application Entity in global variable
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function setApplicationEntity(): void {
|
|
$applicationEntity = (
|
|
$this->featureContext->getJsonDecodedResponse(
|
|
GraphHelper::getApplications(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$this->featureContext->getAdminUsername(),
|
|
$this->featureContext->getAdminPassword(),
|
|
)
|
|
)
|
|
)['value'][0];
|
|
$this->appEntity["id"] = $applicationEntity["id"];
|
|
foreach ($applicationEntity["appRoles"] as $value) {
|
|
$this->appEntity["appRoles"][$value['displayName']] = $value['id'];
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @Then /^the Graph API response should have the role "([^"]*)"$/
|
|
*
|
|
* @param string $role
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theGraphApiResponseShouldHaveTheRole(string $role): void {
|
|
$response = $this->featureContext->getJsonDecodedResponse($this->featureContext->getResponse())['value'][0];
|
|
if (empty($this->appEntity)) {
|
|
$this->setApplicationEntity();
|
|
}
|
|
Assert::assertEquals(
|
|
$this->appEntity["appRoles"][$role],
|
|
$response['appRoleId'],
|
|
__METHOD__
|
|
. "\nExpected rolId for role '$role'' to be '" . $this->appEntity["appRoles"][$role] . "' but got '" . $response['appRoleId'] . "'"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then /^the Graph API response should have no role$/
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theGraphApiResponseShouldHaveNoRole(): void {
|
|
Assert::assertEmpty(
|
|
$this->featureContext->getJsonDecodedResponse($this->featureContext->getResponse())['value'],
|
|
"the user has a role, but should not"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user gets details of the group :groupName using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $groupName
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userGetsDetailsOfTheGroupUsingTheGraphApi(string $user, string $groupName): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::getGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$groupName
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user tries to search for group :searchTerm using Graph API
|
|
* @When user :user searches for group :searchTerm using Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $searchTerm
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userSearchesForGroupUsingGraphApi(string $user, string $searchTerm):void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::searchGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$searchTerm
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then /^the JSON data of the response should (not )?contain the user "([^"]*)" in the item 'value'(?:, the user-details should match)?$/
|
|
* @Then /^the JSON data of the response should (not )?contain the group "([^"]*)" in the item 'value'(?:, the group-details should match)?$/
|
|
*
|
|
* @param string $shouldOrNot (not| )
|
|
* @param string $userOrGroup
|
|
* @param PyStringNode|null $schemaString
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theJsonDataResponseShouldOrNotContainUserOrGroupAndMatch(
|
|
string $shouldOrNot,
|
|
string $userOrGroup,
|
|
?PyStringNode $schemaString = null
|
|
): void {
|
|
$responseBody = $this->featureContext->getJsonDecodedResponseBodyContent()->value;
|
|
$userOrGroupFound = false;
|
|
foreach ($responseBody as $value) {
|
|
if (isset($value->displayName) && $value->displayName === $userOrGroup) {
|
|
$responseBody = $value;
|
|
$userOrGroupFound = true;
|
|
break;
|
|
}
|
|
}
|
|
$shouldContain = \trim($shouldOrNot) !== 'not';
|
|
if (!$shouldContain && !$userOrGroupFound) {
|
|
return;
|
|
}
|
|
Assert::assertFalse(
|
|
!$shouldContain && $userOrGroupFound,
|
|
'Response contains user or group "' . $userOrGroup . '" but should not have.'
|
|
);
|
|
$this->featureContext->assertJsonDocumentMatchesSchema(
|
|
$responseBody,
|
|
$this->featureContext->getJSONSchema($schemaString)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Given /^the administrator "([^"]*)" has added the following users to a group "([^"]*)" at once using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorHasAddedTheFollowingUsersToAGroupAtOnceUsingTheGraphApi(string $user, string $group, TableNode $table) {
|
|
$userIds = [];
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
foreach ($table->getHash() as $row) {
|
|
$userIds[] = $this->featureContext->getAttributeOfCreatedUser($row['username'], "id");
|
|
}
|
|
$this->featureContext->verifyTableNodeColumns($table, ['username']);
|
|
$response = $this->addMultipleUsersToGroup($user, $userIds, $groupId);
|
|
$this->featureContext->theHTTPStatusCodeShouldBe(204, '', $response);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add a group "([^"]*)" to another group "([^"]*)" with PATCH request using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $groupToAdd
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddGroupToAGroupAtOnceUsingTheGraphApi(string $user, string $groupToAdd, string $group) {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$groupIdToAdd = $this->featureContext->getAttributeOfCreatedGroup($groupToAdd, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
$payload = [
|
|
"members@odata.bind" => [GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupIdToAdd)]
|
|
];
|
|
|
|
$this->featureContext->setResponse(
|
|
HttpRequestHelper::sendRequest(
|
|
GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupId),
|
|
$this->featureContext->getStepLineRef(),
|
|
'PATCH',
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
['Content-Type' => 'application/json'],
|
|
\json_encode($payload)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add a group "([^"]*)" to another group "([^"]*)" with POST request using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $groupToAdd
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddAGroupToAGroupThroughPostRequestUsingTheGraphApi(string $user, string $groupToAdd, string $group) {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$groupIdToAdd = $this->featureContext->getAttributeOfCreatedGroup($groupToAdd, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
$payload = [
|
|
"@odata.id" => GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupIdToAdd)
|
|
];
|
|
|
|
$this->featureContext->setResponse(
|
|
HttpRequestHelper::post(
|
|
GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupId . '/members/$ref'),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
['Content-Type' => 'application/json'],
|
|
\json_encode($payload)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" tries to add user "([^"]*)" to group "([^"]*)" with invalid JSON "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $adminUser
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param string $invalidJSON
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userTriesToAddUserToGroupWithInvalidJsonUsingTheGraphApi(string $adminUser, string $user, string $group, string $invalidJSON): void {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($adminUser);
|
|
|
|
$invalidJSON = $this->featureContext->substituteInLineCodes(
|
|
$invalidJSON,
|
|
null,
|
|
[],
|
|
[],
|
|
null,
|
|
$user
|
|
);
|
|
|
|
$this->featureContext->setResponse(
|
|
HttpRequestHelper::post(
|
|
GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupId . '/members/$ref'),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
['Content-Type' => 'application/json'],
|
|
\json_encode($invalidJSON)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" tries to add the following users to a group "([^"]*)" at once with invalid JSON "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param string $invalidJSON
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userTriesToAddTheFollowingUsersToAGroupAtOnceWithInvalidJsonUsingTheGraphApi(string $user, string $group, string $invalidJSON, TableNode $table): void {
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
foreach ($table->getHash() as $row) {
|
|
$invalidJSON = $this->featureContext->substituteInLineCodes(
|
|
$invalidJSON,
|
|
null,
|
|
[],
|
|
[],
|
|
null,
|
|
$row['username']
|
|
);
|
|
}
|
|
|
|
$this->featureContext->setResponse(
|
|
HttpRequestHelper::sendRequest(
|
|
GraphHelper::getFullUrl($this->featureContext->getBaseUrl(), 'groups/' . $groupId),
|
|
$this->featureContext->getStepLineRef(),
|
|
'PATCH',
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
['Content-Type' => 'application/json'],
|
|
\json_encode($invalidJSON)
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add the following invalid user ids to a group "([^"]*)" at once using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
* @param TableNode $table
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddTheFollowingUserIdWithInvalidCharacterToAGroup(string $user, string $group, TableNode $table) {
|
|
$userIds = [];
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
foreach ($table->getHash() as $row) {
|
|
$userIds[] = \implode(" ", $row);
|
|
}
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::addUsersToGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$groupId,
|
|
$userIds
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^the administrator "([^"]*)" tries to add an invalid user id "([^"]*)" to a group "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $userId
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theAdministratorTriesToAddUserIdWithInvalidCharactersToAGroup(string $user, string $userId, string $group): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$groupId = $this->featureContext->getAttributeOfCreatedGroup($group, "id");
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::addUserToGroup(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$userId,
|
|
$groupId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then the user :user should be listed once in the group :group
|
|
*
|
|
* @param string $user
|
|
* @param string $group
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function theUsersShouldBeListedOnceToAGroup(string $user, string $group): void {
|
|
$count = 0;
|
|
$members = $this->listGroupMembers($group);
|
|
$members = $this->featureContext->getJsonDecodedResponse($members);
|
|
|
|
foreach ($members as $member) {
|
|
if ($member['onPremisesSamAccountName'] === $user) {
|
|
$count++;
|
|
}
|
|
}
|
|
Assert::assertEquals(
|
|
1,
|
|
$count,
|
|
"Expected user '" . $user . "' to be added once to group '" . $group . "' but the user is listed '" . $count . "' times"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" gets the personal drive information of user "([^"]*)" using Graph API$/
|
|
* @When /^user "([^"]*)" gets own personal drive information using Graph API$/
|
|
*
|
|
* @param string $byUser
|
|
* @param string|null $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userGetsThePersonalDriveInformationOfUserUsingGraphApi(string $byUser, ?string $user = null): void {
|
|
$user = $user ?? $byUser;
|
|
$credentials = $this->getAdminOrUserCredentials($byUser);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id');
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::getPersonalDriveInformationByUserId(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials["username"],
|
|
$credentials["password"],
|
|
$userId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" exports (?:her|his) GDPR report to "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $path
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userGeneratesGDPRReportOfOwnDataToPath(string $user, string $path): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id');
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::generateGDPRReport(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$userId,
|
|
$path
|
|
)
|
|
);
|
|
$this->featureContext->pushToLastStatusCodesArrays();
|
|
}
|
|
|
|
/**
|
|
* @Then the downloaded JSON content should contain event type :eventType in item 'events' and should match
|
|
* @Then the downloaded JSON content should contain event type :eventType for :spaceType space and should match
|
|
*
|
|
* @param string $eventType
|
|
* @param string|null $spaceType
|
|
* @param PyStringNode|null $schemaString
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*
|
|
*/
|
|
public function downloadedJsonContentShouldContainEventTypeInItemAndShouldMatch(string $eventType, ?string $spaceType=null, PyStringNode $schemaString=null): void {
|
|
$actualResponseToAssert = null;
|
|
$events = $this->featureContext->getJsonDecodedResponseBodyContent()->events;
|
|
foreach ($events as $event) {
|
|
if ($event->type === $eventType) {
|
|
if ($spaceType !== null) {
|
|
if ($event->event->Type === $spaceType) {
|
|
$actualResponseToAssert = $event;
|
|
break;
|
|
}
|
|
continue;
|
|
}
|
|
$actualResponseToAssert = $event;
|
|
break;
|
|
}
|
|
}
|
|
if ($actualResponseToAssert === null) {
|
|
throw new Error(
|
|
"Response does not contain event type '" . $eventType . "'."
|
|
);
|
|
}
|
|
$this->featureContext->assertJsonDocumentMatchesSchema(
|
|
$actualResponseToAssert,
|
|
$this->featureContext->getJSONSchema($schemaString)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then the downloaded JSON content should contain key 'user' and match
|
|
*
|
|
* @param PyStringNode $schemaString
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*
|
|
*/
|
|
public function downloadedJsonContentShouldContainKeyUserAndMatch(PyStringNode $schemaString): void {
|
|
$actualResponseToAssert = $this->featureContext->getJsonDecodedResponseBodyContent();
|
|
if (!isset($actualResponseToAssert->user)) {
|
|
throw new Error(
|
|
"Response does not contain key 'user'"
|
|
);
|
|
}
|
|
$this->featureContext->assertJsonDocumentMatchesSchema(
|
|
$actualResponseToAssert->user,
|
|
$this->featureContext->getJSONSchema($schemaString)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user tries to export GDPR report of user :ofUser to :path using Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $ofUser
|
|
* @param string $path
|
|
*
|
|
* @return void
|
|
*
|
|
*/
|
|
public function userTriesToExportGdprReportOfAnotherUserUsingGraphApi(string $user, string $ofUser, string $path): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::generateGDPRReport(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$this->featureContext->getAttributeOfCreatedUser($ofUser, 'id'),
|
|
$path
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @param string $user
|
|
*
|
|
* @return ResponseInterface
|
|
* @throws GuzzleException
|
|
*/
|
|
public function getAssignedRole(string $user): ResponseInterface {
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($user, 'id') ?: $this->featureContext->getUserIdByUserName($user);
|
|
return (
|
|
GraphHelper::getAssignedRole(
|
|
$this->featureContext->getBAseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$this->featureContext->getAdminUsername(),
|
|
$this->featureContext->getAdminPassword(),
|
|
$userId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" (?:unassigns|tries to unassign) the role of user "([^"]*)" using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $ofUser
|
|
*
|
|
* @return void
|
|
*
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function theUserUnassignsTheRoleOfUserUsingTheGraphApi(string $user, string $ofUser): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($ofUser, 'id');
|
|
|
|
// get 'User' role id for nonexistent user
|
|
if (!$userId && $ofUser !== $this->featureContext->getAdminUsername()) {
|
|
$appRoleAssignmentId = $this->getRoleIdByRoleName("User");
|
|
} else {
|
|
$appRoleAssignmentId = $this->featureContext->getJsonDecodedResponse($this->getAssignedRole($ofUser))["value"][0]["id"];
|
|
}
|
|
|
|
$userId = $userId ?: $ofUser;
|
|
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::unassignRole(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$appRoleAssignmentId,
|
|
$userId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then user :user should have the role :role assigned
|
|
*
|
|
* @param string $user
|
|
* @param string $role
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function userShouldHaveTheRoleAssigned(string $user, string $role): void {
|
|
$jsonDecodedResponse = $this->featureContext->getJsonDecodedResponse($this->getAssignedRole($user))['value'][0];
|
|
if (empty($this->appEntity)) {
|
|
$this->setApplicationEntity();
|
|
}
|
|
Assert::assertEquals(
|
|
$this->appEntity["appRoles"][$role],
|
|
$jsonDecodedResponse['appRoleId'],
|
|
__METHOD__
|
|
. "\nExpected user '$user' to have role '$role' with role id '" . $this->appEntity["appRoles"][$role] .
|
|
"' but got the role id is '" . $jsonDecodedResponse['appRoleId'] . "'"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then user :user should not have any role assigned
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function userShouldNotHaveAnyRoleAssigned(string $user): void {
|
|
$jsonDecodedResponse = $this->featureContext->getJsonDecodedResponse($this->getAssignedRole($user))['value'];
|
|
Assert::assertEmpty(
|
|
$jsonDecodedResponse,
|
|
__METHOD__
|
|
. "\nExpected user '$user' to have no roles assigned but got '" . json_encode($jsonDecodedResponse) . "'"
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user changes the role of user :ofUser to role :role using the Graph API
|
|
* @When user :user tries to change the role of user :ofUser to role :role using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $ofUser
|
|
* @param string $role
|
|
*
|
|
* @return void
|
|
*
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function userChangesTheRoleOfUserToRoleUsingTheGraphApi(string $user, string $ofUser, string $role): void {
|
|
$userId = $this->featureContext->getAttributeOfCreatedUser($ofUser, 'id') ?: $ofUser;
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
if (empty($this->appEntity)) {
|
|
$this->setApplicationEntity();
|
|
}
|
|
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::assignRole(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$this->appEntity["appRoles"][$role],
|
|
$this->appEntity["id"],
|
|
$userId
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Given user :user has switched the system language to :language using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $language
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userHasSwitchedTheSystemLanguageUsingGraphApi(string $user, string $language): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$response = GraphHelper::switchSystemLanguage(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$language
|
|
);
|
|
$this->featureContext->theHTTPStatusCodeShouldBe(
|
|
200,
|
|
"Expected response status code should be 200",
|
|
$response
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user switches the system language to :language using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $language
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userSwitchesTheSystemLanguageUsingGraphApi(string $user, string $language): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::switchSystemLanguage(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
$language
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" lists the shares shared with (?:him|her)(| after clearing user cache) using the Graph API$/
|
|
*
|
|
* @param string $user
|
|
* @param string $cacheStepString
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userListsTheResourcesSharedWithThemUsingGraphApi(string $user, string $cacheStepString): void {
|
|
if ($cacheStepString !== '') {
|
|
// ENV (GRAPH_SPACES_GROUPS_CACHE_TTL | GRAPH_SPACES_USERS_CACHE_TTL) is set default to 60 sec
|
|
// which means 60 sec is required to clean up all the user|group cache once they are deleted
|
|
// for tests we have set the above ENV's to minimum which is 1 sec as we check the details for the deleted users
|
|
sleep(1);
|
|
}
|
|
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
// Sometimes listing shares might not return the updated shares list
|
|
// so try again until @client.synchronize is true for the max. number of retries (i.e. 10)
|
|
// and do not retry when the share is expected to be not synced
|
|
$tryAgain = false;
|
|
$retried = 0;
|
|
do {
|
|
$response = GraphHelper::getSharesSharedWithMe(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password']
|
|
);
|
|
|
|
$jsonBody = $this->featureContext->getJsonDecodedResponseBodyContent($response);
|
|
|
|
foreach ($jsonBody->value as $share) {
|
|
$autoSync = $this->featureContext->getUserAutoSyncSetting($credentials['username']);
|
|
$tryAgain = !$share->{'@client.synchronize'} && $autoSync && $retried < HttpRequestHelper::numRetriesOnHttpTooEarly();
|
|
|
|
if ($tryAgain) {
|
|
$retried += 1;
|
|
echo "auto-sync share for user '$user' is enabled\n";
|
|
echo "but share '$share->name' was not auto-synced, retrying ($retried)...\n";
|
|
// wait 500ms and try again
|
|
\usleep(500 * 1000);
|
|
break;
|
|
}
|
|
}
|
|
} while ($tryAgain);
|
|
|
|
$this->featureContext->setResponse($response);
|
|
$this->featureContext->pushToLastStatusCodesArrays();
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $user
|
|
* @param bool $waitForCacheExpiry
|
|
*
|
|
* @return ResponseInterface
|
|
*/
|
|
public function listSharesSharedByMe(string $user, bool $waitForCacheExpiry = false): ResponseInterface {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
if ($waitForCacheExpiry) {
|
|
// ENV (GRAPH_SPACES_GROUPS_CACHE_TTL | GRAPH_SPACES_USERS_CACHE_TTL) is set default to 60 sec
|
|
// which means 60 sec is required to clean up all the user|group cache once they are deleted
|
|
// for tests we have set the above ENV's to minimum which is 1 sec as we check the details for the deleted users
|
|
sleep(1);
|
|
}
|
|
return GraphHelper::getSharesSharedByMe(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password']
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user lists the shares shared by him/her using the Graph API
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userListsTheResourcesSharedByAUserUsingGraphApi(string $user): void {
|
|
$response = $this->listSharesSharedByMe($user);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :user lists the shares shared by him/her after clearing user/group cache using the Graph API
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function userListsTheResourcesSharedByAUserAfterClearingUserOrGroupSpaceUsingGraphApi(string $user): void {
|
|
$response = $this->listSharesSharedByMe($user, true);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @Then /^the JSON data of the response should (not )?contain resource "([^"]*)" with the following data:?$/
|
|
*
|
|
* @param string $shouldOrNot (not| )
|
|
* @param string $fileName
|
|
* @param PyStringNode $schemaString
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theJsonDataResponseShouldOrNotContainSharedByMeDetails(
|
|
string $shouldOrNot,
|
|
string $fileName,
|
|
PyStringNode $schemaString
|
|
): void {
|
|
$responseBody = $this->featureContext->getJsonDecodedResponseBodyContent()->value;
|
|
$fileOrFolderFound = false;
|
|
foreach ($responseBody as $value) {
|
|
if (isset($value->name) && $value->name === $fileName) {
|
|
$responseBody = $value;
|
|
$fileOrFolderFound = true;
|
|
break;
|
|
}
|
|
}
|
|
$shouldContain = \trim($shouldOrNot) !== 'not';
|
|
if (!$shouldContain && !$fileOrFolderFound) {
|
|
return;
|
|
}
|
|
Assert::assertFalse(
|
|
!$shouldContain && $fileOrFolderFound,
|
|
'Response contains file "' . $fileName . '" but should.'
|
|
);
|
|
$this->featureContext->assertJsonDocumentMatchesSchema(
|
|
$responseBody,
|
|
$this->featureContext->getJSONSchema($schemaString)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then the JSON data of the search response should not contain user(s) email
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function theJsonDataResponseShouldNotContainUserEmail(): void {
|
|
$responseBody = $this->featureContext->getJsonDecodedResponseBodyContent()->value;
|
|
$mailValueExist = false;
|
|
$email = "";
|
|
foreach ($responseBody as $value) {
|
|
if (isset($value->mail)) {
|
|
$mailValueExist = true;
|
|
$email = $value->mail;
|
|
break;
|
|
}
|
|
}
|
|
Assert::assertFalse(
|
|
$mailValueExist,
|
|
"Response contains email '$email' but should not."
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @Then user :byUser using password :password should be able to create a new user :user with default attributes
|
|
*
|
|
* @param string $byUser
|
|
* @param string $password
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws JsonException
|
|
*/
|
|
public function userUsingPasswordShouldBeAbleToCreateANewUserWithDefaultAttributes(string $byUser, string $password, string $user): void {
|
|
$response = GraphHelper::createUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$byUser,
|
|
$password,
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user)
|
|
);
|
|
Assert::assertEquals(
|
|
201,
|
|
$response->getStatusCode(),
|
|
__METHOD__ . " cannot create new user '$user' by user '$byUser'.\nResponse:" .
|
|
json_encode($this->featureContext->getJsonDecodedResponse($response))
|
|
);
|
|
$this->featureContext->addUserToCreatedUsersList($user, $this->featureContext->getPasswordForUser($user));
|
|
}
|
|
|
|
/**
|
|
* @Given user :byUser has changed the username to :userName
|
|
*
|
|
* @param string $byUser
|
|
* @param string $userName
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws JsonException
|
|
*/
|
|
public function theUserHasChangedItsOwnUsernameTo(string $byUser, string $userName): void {
|
|
$userId = $this->featureContext->getUserIdByUserName($byUser);
|
|
$response = GraphHelper::editUser(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$byUser,
|
|
$this->featureContext->getPasswordForUser($byUser),
|
|
$userId,
|
|
'PATCH',
|
|
$userName,
|
|
);
|
|
$this->featureContext->theHTTPStatusCodeShouldBe(200, '', $response);
|
|
$this->featureContext->updateUsernameInCreatedUserList($byUser, $userName);
|
|
}
|
|
|
|
/**
|
|
* @When user :user gets a list of permissions role definitions using the Graph API
|
|
*
|
|
* @param string $user
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
*/
|
|
public function getListOfPermissionRoleDefinitionsUsingTheGraphAPI(string $user): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::getPermissionsRoleDefinitions(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When user :user gets the :permissionRole role definition using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $permissionRole
|
|
*
|
|
* @return void
|
|
* @throws GuzzleException
|
|
* @throws Exception
|
|
*/
|
|
public function getPermissionRoleDefinitionUsingGraphAPI(string $user, string $permissionRole):void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
$this->featureContext->setResponse(
|
|
GraphHelper::getPermissionRoleDefinition(
|
|
$permissionRole,
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password'],
|
|
)
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" lists the activities for (?:folder|file) "([^"]*)" of space "([^"]*)" using the Graph API/
|
|
*
|
|
* @param string $user
|
|
* @param string $resource
|
|
* @param string $spaceName
|
|
*
|
|
* @return void
|
|
* @throws Exception
|
|
*/
|
|
public function userListsTheActivitiesForResourceOfSpaceUsingTheGraphAPI(string $user, string $resource, string $spaceName): void {
|
|
$resourceId = $this->featureContext->spacesContext->getResourceId($user, $spaceName, $resource);
|
|
$response = GraphHelper::getActivities(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$resourceId
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When user :user lists the activities of space :spaceName using the Graph API
|
|
*
|
|
* @param string $user
|
|
* @param string $spaceName
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userListsTheActivitiesOfSpaceUsingTheGraphApi(string $user, string $spaceName): void {
|
|
$spaceId = ($this->featureContext->spacesContext->getSpaceByName($user, $spaceName))["id"];
|
|
$response = GraphHelper::getActivities(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$spaceId
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When /^user "([^"]*)" lists the activities for (?:folder|file) "([^"]*)" of space "([^"]*)" with (depth|limit) "([^"]*)" using the Graph API/
|
|
*
|
|
* @param string $user
|
|
* @param string $resource
|
|
* @param string $spaceName
|
|
* @param string $filterType
|
|
* @param string $filterValue
|
|
*
|
|
* @return void
|
|
*/
|
|
public function userListsTheActivitiesForFolderOfSpaceWithDepthOrLimitUsingTheGraphApi(string $user, string $resource, string $spaceName, string $filterType, string $filterValue): void {
|
|
$resourceId = $this->featureContext->spacesContext->getResourceId($user, $spaceName, $resource);
|
|
$response = GraphHelper::getActivities(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$user,
|
|
$this->featureContext->getPasswordForUser($user),
|
|
$resourceId,
|
|
[$filterType => $filterValue]
|
|
);
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When the administrator gets federated users using the Graph API
|
|
* @When user :user tries to get federated users using the Graph API
|
|
*
|
|
* @param ?string $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theUserGetsFederatedUsersUsingTheGraphApi(?string $user = null): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
$response = GraphHelper::getFederatedUsers(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password']
|
|
);
|
|
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
|
|
/**
|
|
* @When the administrator gets federated and local users using the Graph API
|
|
* @When user :user tries to get federated and local users using the Graph API
|
|
*
|
|
* @param ?string $user
|
|
*
|
|
* @return void
|
|
*/
|
|
public function theUserGetsAllUsersUsingTheGraphApi(?string $user = null): void {
|
|
$credentials = $this->getAdminOrUserCredentials($user);
|
|
|
|
$response = GraphHelper::getAllUsers(
|
|
$this->featureContext->getBaseUrl(),
|
|
$this->featureContext->getStepLineRef(),
|
|
$credentials['username'],
|
|
$credentials['password']
|
|
);
|
|
|
|
$this->featureContext->setResponse($response);
|
|
}
|
|
}
|