You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

67 lines
1.8 KiB

3 years ago
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2018 Bjoern Schiessle <bjoern@schiessle.org>
  4. *
  5. * @author Bjoern Schiessle <bjoern@schiessle.org>
  6. *
  7. * @license GNU AGPL version 3 or any later version
  8. *
  9. * This program is free software: you can redistribute it and/or modify
  10. * it under the terms of the GNU Affero General Public License as
  11. * published by the Free Software Foundation, either version 3 of the
  12. * License, or (at your option) any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU Affero General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU Affero General Public License
  20. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  21. *
  22. */
  23. namespace OC\Federation;
  24. use OCP\Federation\ICloudFederationNotification;
  25. /**
  26. * Class CloudFederationNotification
  27. *
  28. * @package OC\Federation
  29. *
  30. * @since 14.0.0
  31. */
  32. class CloudFederationNotification implements ICloudFederationNotification {
  33. private $message = [];
  34. /**
  35. * add a message to the notification
  36. *
  37. * @param string $notificationType (e.g. SHARE_ACCEPTED)
  38. * @param string $resourceType (e.g. file, calendar, contact,...)
  39. * @param string $providerId id of the share
  40. * @param array $notification payload of the notification
  41. *
  42. * @since 14.0.0
  43. */
  44. public function setMessage($notificationType, $resourceType, $providerId, array $notification) {
  45. $this->message = [
  46. 'notificationType' => $notificationType,
  47. 'resourceType' => $resourceType,
  48. 'providerId' => $providerId,
  49. 'notification' => $notification,
  50. ];
  51. }
  52. /**
  53. * get message, ready to send out
  54. *
  55. * @return array
  56. *
  57. * @since 14.0.0
  58. */
  59. public function getMessage() {
  60. return $this->message;
  61. }
  62. }