utils = $utils; } /** * Gets all the credential data for the given user * @param $userId * @param $item_guid * @return SharingACL[] */ public function getCredentialPermissions(IUser $userId, $item_guid){ $sql = "SELECT * FROM ". self::TABLE_NAME ." WHERE user_id = ? AND item_guid = ?"; return $this->findEntities($sql, [$userId, $item_guid]); } public function createACLEntry(SharingACL $acl){ return $this->insert($acl); } /** * Gets the currently accepted share requests from the given user for the given vault guid * @param $user_id * @param $vault_id * @return SharingACL[] */ public function getVaultEntries($user_id, $vault_id) { $q = "SELECT * FROM ". self::TABLE_NAME ." WHERE user_id = ? AND vault_guid = ?"; return $this->findEntities($q, [$user_id, $vault_id]); } /** * Gets the acl for a given item guid * @param $user_id * @param $item_guid * @return SharingACL */ public function getItemACL($user_id, $item_guid) { $q = "SELECT * FROM " . self::TABLE_NAME . " WHERE item_guid = ? AND "; $filter = [$item_guid]; if ($user_id === null){ $q .= 'user_id is null'; } else { $q .= 'user_id = ? '; $filter[] = $user_id; } return $this->findEntity($q, $filter); } /** * Update the acl for a given item guid * @param $user_id * @param $item_guid * @return SharingACL */ public function updateCredentialACL(SharingACL $sharingACL) { return $this->update($sharingACL); } /** * Gets the currently accepted share requests from the given user for the given vault guid * @param $user_id * @param $vault_id * @return SharingACL[] */ public function getCredentialAclList($item_guid) { $q = "SELECT * FROM ". self::TABLE_NAME ." WHERE item_guid = ?"; return $this->findEntities($q, [$item_guid]); } public function deleteShareACL(SharingACL $ACL){ return $this->delete($ACL); } }