1 | <?php |
||
16 | class BackgroundScanner { |
||
17 | |||
18 | /** |
||
19 | * @var ScannerFactory |
||
20 | */ |
||
21 | private $scannerFactory; |
||
22 | |||
23 | /** |
||
24 | * @var IUserManager |
||
25 | */ |
||
26 | private $userManager; |
||
27 | |||
28 | /** |
||
29 | * @var IL10N |
||
30 | */ |
||
31 | private $l10n; |
||
32 | |||
33 | /** |
||
34 | * A constructor |
||
35 | * @param \OCA\Files_Antivirus\ScannerFactory $scannerFactory |
||
36 | * @param IUserManager $userManager |
||
37 | * @param IL10N $l10n |
||
38 | */ |
||
39 | 1 | public function __construct(ScannerFactory $scannerFactory, IUserManager $userManager, IL10N $l10n){ |
|
44 | |||
45 | /** |
||
46 | * Background scanner main job |
||
47 | * @return null |
||
48 | */ |
||
49 | 1 | public function run(){ |
|
50 | 1 | if (!$this->initFS()) { |
|
51 | return; |
||
52 | } |
||
53 | // locate files that are not checked yet |
||
54 | 1 | $dirMimeTypeId = \OC::$server->getMimeTypeLoader()->getId('httpd/unix-directory'); |
|
55 | try { |
||
56 | 1 | $qb = \OC::$server->getDatabaseConnection()->getQueryBuilder(); |
|
57 | 1 | $qb->select(['fc.fileid']) |
|
58 | 1 | ->from('filecache', 'fc') |
|
59 | 1 | ->leftJoin('fc', 'files_antivirus', 'fa', $qb->expr()->eq('fa.fileid', 'fc.fileid')) |
|
60 | 1 | ->innerJoin( |
|
61 | 1 | 'fc', |
|
62 | 1 | 'storages', |
|
63 | 1 | 'ss', |
|
64 | 1 | $qb->expr()->andX( |
|
65 | 1 | $qb->expr()->eq('fc.storage', 'ss.numeric_id'), |
|
66 | 1 | $qb->expr()->orX( |
|
67 | 1 | $qb->expr()->like('ss.id', $qb->expr()->literal('local::%')), |
|
68 | 1 | $qb->expr()->like('ss.id', $qb->expr()->literal('home::%')) |
|
69 | 1 | ) |
|
70 | 1 | ) |
|
71 | 1 | ) |
|
72 | 1 | ->where( |
|
73 | 1 | $qb->expr()->neq('fc.mimetype', $qb->expr()->literal($dirMimeTypeId)) |
|
74 | 1 | ) |
|
75 | 1 | ->andWhere( |
|
76 | 1 | $qb->expr()->orX( |
|
77 | 1 | $qb->expr()->isNull('fa.fileid'), |
|
78 | 1 | $qb->expr()->gt('fc.mtime', 'fa.check_time') |
|
79 | 1 | ) |
|
80 | 1 | ) |
|
81 | 1 | ->andWhere( |
|
82 | 1 | $qb->expr()->like('fc.path', $qb->expr()->literal('files/%')) |
|
83 | 1 | ) |
|
84 | 1 | ->andWhere( |
|
85 | 1 | $qb->expr()->neq('fc.size', $qb->expr()->literal('0')) |
|
86 | 1 | ) |
|
87 | 1 | ->setMaxResults(5) |
|
88 | ; |
||
89 | 1 | $result = $qb->execute(); |
|
90 | 1 | } catch(\Exception $e) { |
|
91 | \OC::$server->getLogger()->error( __METHOD__ . ', exception: ' . $e->getMessage(), ['app' => 'files_antivirus']); |
||
92 | return; |
||
93 | } |
||
94 | |||
95 | |||
96 | 1 | $view = new \OC\Files\View(''); |
|
97 | try { |
||
98 | 1 | while ($row = $result->fetch()) { |
|
99 | 1 | $path = $view->getPath($row['fileid']); |
|
100 | 1 | if (!is_null($path)) { |
|
101 | 1 | $item = new Item($this->l10n, $view, $path, $row['fileid']); |
|
102 | 1 | $scanner = $this->scannerFactory->getScanner(); |
|
103 | 1 | $status = $scanner->scan($item); |
|
104 | 1 | $status->dispatch($item, true); |
|
105 | 1 | } |
|
106 | 1 | } |
|
107 | 1 | } catch (\Exception $e){ |
|
108 | \OC::$server->getLogger()->error( __METHOD__ . ', exception: ' . $e->getMessage(), ['app' => 'files_antivirus']); |
||
109 | } |
||
110 | 1 | \OC_Util::tearDownFS(); |
|
111 | 1 | } |
|
112 | |||
113 | /** |
||
114 | * A hack to access files and views. Better than before. |
||
115 | * |
||
116 | * @return bool |
||
117 | */ |
||
118 | 1 | protected function initFS(){ |
|
130 | |||
131 | /** |
||
132 | * @deprecated |
||
133 | */ |
||
134 | public static function check(){ |
||
137 | } |
||
138 |