summaryrefslogtreecommitdiffstats
path: root/apps/user_ldap/command/showremnants.php
blob: 3d39f9774215c174d48107ad9c48b966f3dac720 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
<?php
/**
 * Copyright (c) 2014 Arthur Schiwon <blizzz@owncloud.com>
 * This file is licensed under the Affero General Public License version 3 or
 * later.
 * See the COPYING-README file.
 */

namespace OCA\user_ldap\Command;

use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;

use OCA\user_ldap\lib\user\DeletedUsersIndex;
use OCA\User_LDAP\lib\Connection;
use OCA\User_LDAP\lib\Access;

class ShowRemnants extends Command {

	protected function configure() {
		$this
			->setName('ldap:show-remnants')
			->setDescription('shows which users are not available on LDAP anymore, but have remnants in ownCloud.')
		;
	}

	protected function execute(InputInterface $input, OutputInterface $output) {
		$dui = new DeletedUsersIndex(
			new \OC\Preferences(\OC_DB::getConnection()),
			\OC::$server->getDatabaseConnection(),
			$this->getAccess()
		);

		/** @var \Symfony\Component\Console\Helper\Table $table */
		$table = $this->getHelperSet()->get('table');
		$table->setHeaders(array(
			'ownCloud name', 'Display Name', 'LDAP UID', 'LDAP DN', 'Last Login',
			'Dir', 'Sharer'));
		$rows = array();
		$offset = 0;
		do {
			$resultSet = $dui->getUsers($offset);
			$offset += count($resultSet);
			foreach($resultSet as $user) {
				$hAS = $user->getHasActiveShares() ? 'Y' : 'N';
				$lastLogin = ($user->getLastLogin() > 0) ?
					\OCP\Util::formatDate($user->getLastLogin()) : '-';
				$rows[] = array(
					$user->getOCName(),
					$user->getDisplayName(),
					$user->getUid(),
					$user->getDN(),
					$lastLogin,
					$user->getHomePath(),
					$hAS
				);
			}
		} while (count($resultSet) === 10);

		$table->setRows($rows);
		$table->render($output);
	}

	protected function getAccess() {
		$ldap = new \OCA\user_ldap\lib\LDAP();
		$dummyConnection = new Connection($ldap, '', null);
		$userManager = new \OCA\user_ldap\lib\user\Manager(
			\OC::$server->getConfig(),
			new \OCA\user_ldap\lib\FilesystemHelper(),
			new \OCA\user_ldap\lib\LogWrapper(),
			\OC::$server->getAvatarManager(),
			new \OCP\Image()
		);
		$access = new Access($dummyConnection, $ldap, $userManager);
		return $access;
	}

}