2016-06-08 16:25:44 +03:00
|
|
|
<?php
|
2019-12-03 21:57:53 +03:00
|
|
|
|
2018-03-10 21:40:19 +03:00
|
|
|
declare(strict_types=1);
|
2019-12-03 21:57:53 +03:00
|
|
|
|
2016-06-08 16:25:44 +03:00
|
|
|
/**
|
|
|
|
* @copyright Copyright (c) 2016 Lukas Reschke <lukas@statuscode.ch>
|
2016-07-21 17:49:16 +03:00
|
|
|
*
|
2019-12-03 21:57:53 +03:00
|
|
|
* @author Daniel Calviño Sánchez <danxuliu@gmail.com>
|
2017-11-06 17:56:42 +03:00
|
|
|
* @author Joas Schilling <coding@schilljs.com>
|
2020-12-16 16:54:15 +03:00
|
|
|
* @author Julius Härtl <jus@bitgrid.net>
|
2016-07-21 17:49:16 +03:00
|
|
|
* @author Lukas Reschke <lukas@statuscode.ch>
|
2019-12-03 21:57:53 +03:00
|
|
|
* @author Sascha Wiswedel <sascha.wiswedel@nextcloud.com>
|
2016-06-08 16:25:44 +03:00
|
|
|
*
|
|
|
|
* @license GNU AGPL version 3 or any later version
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as
|
|
|
|
* published by the Free Software Foundation, either version 3 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Affero General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
2019-12-03 21:57:53 +03:00
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2016-06-08 16:25:44 +03:00
|
|
|
*
|
|
|
|
*/
|
2017-07-01 12:28:03 +03:00
|
|
|
|
|
|
|
namespace OCA\AdminAudit\Actions;
|
|
|
|
|
2020-06-24 17:49:16 +03:00
|
|
|
use OCP\Share\IShare;
|
2016-06-08 16:25:44 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Class Sharing logs the sharing actions
|
|
|
|
*
|
2017-07-01 12:28:03 +03:00
|
|
|
* @package OCA\AdminAudit\Actions
|
2016-06-08 16:25:44 +03:00
|
|
|
*/
|
|
|
|
class Sharing extends Action {
|
|
|
|
/**
|
|
|
|
* Logs sharing of data
|
|
|
|
*
|
|
|
|
* @param array $params
|
|
|
|
*/
|
2021-03-05 17:02:35 +03:00
|
|
|
public function shared(array $params): void {
|
2020-06-24 17:49:16 +03:00
|
|
|
if ($params['shareType'] === IShare::TYPE_LINK) {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared via link with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_USER) {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the user "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_GROUP) {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the group "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_ROOM) {
|
2018-06-30 15:00:24 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the room "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_EMAIL) {
|
2019-07-26 14:37:22 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the email recipient "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
2019-07-28 15:16:43 +03:00
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_CIRCLE) {
|
2019-07-28 15:16:43 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the circle "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_REMOTE) {
|
2019-07-28 15:16:43 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the remote user "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_REMOTE_GROUP) {
|
2019-07-28 15:16:43 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the remote group "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-12-08 14:56:54 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_DECK) {
|
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been shared to the deck card "%s" with permissions "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'permissions',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2016-06-08 16:25:44 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs unsharing of data
|
|
|
|
*
|
|
|
|
* @param array $params
|
|
|
|
*/
|
2021-03-05 17:02:35 +03:00
|
|
|
public function unshare(array $params): void {
|
2020-06-24 17:49:16 +03:00
|
|
|
if ($params['shareType'] === IShare::TYPE_LINK) {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_USER) {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the user "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_GROUP) {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the group "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_ROOM) {
|
2018-06-30 15:00:24 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the room "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_EMAIL) {
|
2019-07-26 14:37:22 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the email recipient "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
2019-07-28 15:16:43 +03:00
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_CIRCLE) {
|
2019-07-28 15:16:43 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the circle "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_REMOTE) {
|
2019-07-28 15:16:43 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the remote user "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-06-24 17:49:16 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_REMOTE_GROUP) {
|
2019-07-28 15:16:43 +03:00
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the remote group "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2020-12-08 14:56:54 +03:00
|
|
|
} elseif ($params['shareType'] === IShare::TYPE_DECK) {
|
|
|
|
$this->log(
|
|
|
|
'The %s "%s" with ID "%s" has been unshared from the deck card "%s" (Share ID: %s)',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'fileTarget',
|
|
|
|
'itemSource',
|
|
|
|
'shareWith',
|
|
|
|
'id',
|
|
|
|
]
|
|
|
|
);
|
2016-06-08 16:25:44 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs the updating of permission changes for shares
|
|
|
|
*
|
|
|
|
* @param array $params
|
|
|
|
*/
|
2021-03-05 17:02:35 +03:00
|
|
|
public function updatePermissions(array $params): void {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The permissions of the shared %s "%s" with ID "%s" have been changed to "%s"',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'path',
|
|
|
|
'itemSource',
|
|
|
|
'permissions',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs the password changes for a share
|
|
|
|
*
|
|
|
|
* @param array $params
|
|
|
|
*/
|
2021-03-05 17:02:35 +03:00
|
|
|
public function updatePassword(array $params): void {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The password of the publicly shared %s "%s" with ID "%s" has been changed',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'token',
|
|
|
|
'itemSource',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs the expiration date changes for a share
|
|
|
|
*
|
|
|
|
* @param array $params
|
|
|
|
*/
|
2021-03-05 17:02:35 +03:00
|
|
|
public function updateExpirationDate(array $params): void {
|
2021-05-19 11:09:48 +03:00
|
|
|
if ($params['date'] === null) {
|
|
|
|
$this->log(
|
2021-06-01 14:31:10 +03:00
|
|
|
'The expiration date of the publicly shared %s with ID "%s" has been removed',
|
2021-05-19 11:09:48 +03:00
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemSource',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
$this->log(
|
|
|
|
'The expiration date of the publicly shared %s with ID "%s" has been changed to "%s"',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'itemSource',
|
|
|
|
'date',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
2016-06-08 16:25:44 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Logs access of shared files
|
|
|
|
*
|
|
|
|
* @param array $params
|
|
|
|
*/
|
2021-03-05 17:02:35 +03:00
|
|
|
public function shareAccessed(array $params): void {
|
2016-06-08 16:25:44 +03:00
|
|
|
$this->log(
|
|
|
|
'The shared %s with the token "%s" by "%s" has been accessed.',
|
|
|
|
$params,
|
|
|
|
[
|
|
|
|
'itemType',
|
|
|
|
'token',
|
|
|
|
'uidOwner',
|
|
|
|
]
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|