PluginProbe ʕ •ᴥ•ʔ
Booking for Appointments and Events Calendar – Amelia / trunk
Booking for Appointments and Events Calendar – Amelia vtrunk
2.4.3 2.4.2 2.4.1 2.4 trunk 1.2.1 1.2.10 1.2.11 1.2.12 1.2.13 1.2.14 1.2.15 1.2.16 1.2.17 1.2.18 1.2.19 1.2.2 1.2.20 1.2.21 1.2.22 1.2.23 1.2.24 1.2.25 1.2.26 1.2.27 1.2.28 1.2.29 1.2.3 1.2.30 1.2.31 1.2.32 1.2.33 1.2.34 1.2.35 1.2.36 1.2.37 1.2.38 1.2.4 1.2.5 1.2.6 1.2.7 1.2.8 1.2.9 2.0 2.0.1 2.0.2 2.1 2.1.1 2.1.2 2.1.3 2.2 2.2.1 2.3
ameliabooking / src / Application / Controller / Booking / Appointment / SuccessfulBookingController.php
ameliabooking / src / Application / Controller / Booking / Appointment Last commit date
AddAppointmentController.php 1 month ago AddBookingController.php 2 weeks ago ApproveBookingRemotelyController.php 1 month ago CancelBookingController.php 1 month ago CancelBookingRemotelyController.php 1 month ago DeleteAppointmentController.php 1 month ago DeleteBookingController.php 1 month ago DeleteBookingRemotelyController.php 1 month ago GetAppointmentBookingsController.php 1 month ago GetAppointmentController.php 1 month ago GetAppointmentsController.php 1 month ago GetIcsController.php 1 month ago GetTimeSlotsController.php 1 month ago ReassignBookingController.php 1 month ago RejectBookingRemotelyController.php 1 month ago SuccessfulBookingController.php 1 month ago UpdateAppointmentController.php 1 month ago UpdateAppointmentNoteController.php 1 month ago UpdateAppointmentStatusController.php 1 month ago UpdateAppointmentTimeController.php 1 month ago UpdateBookingStatusController.php 1 month ago
SuccessfulBookingController.php
69 lines
1 <?php
2
3 namespace AmeliaBooking\Application\Controller\Booking\Appointment;
4
5 use AmeliaBooking\Application\Commands\Booking\Appointment\SuccessfulBookingCommand;
6 use AmeliaBooking\Application\Commands\CommandResult;
7 use AmeliaBooking\Application\Controller\Controller;
8 use AmeliaBooking\Domain\Events\DomainEventBus;
9 use RuntimeException;
10 use AmeliaVendor\Psr\Http\Message\ServerRequestInterface as Request;
11
12 /**
13 * Class SuccessfulBookingController
14 *
15 * @package AmeliaBooking\Application\Controller\Booking\Appointment
16 */
17 class SuccessfulBookingController extends Controller
18 {
19 /**
20 * Fields for successful booking that can be received from front-end
21 *
22 * @var array
23 */
24 public $allowedFields = [
25 'type',
26 'appointmentStatusChanged',
27 'recurring',
28 'packageId',
29 'isPackageAppointment',
30 'customer',
31 'paymentId',
32 'packageCustomerId',
33 'packageBookingFromBackend',
34 ];
35
36 /**
37 * Instantiates the SuccessfulBooking command to hand it over to the Command Handler
38 *
39 * @param Request $request
40 * @param $args
41 *
42 * @return SuccessfulBookingCommand
43 * @throws RuntimeException
44 */
45 protected function instantiateCommand(Request $request, $args)
46 {
47 $command = new SuccessfulBookingCommand($args);
48
49 $requestBody = $request->getParsedBody();
50
51 $this->setCommandFields($command, $requestBody);
52
53 return $command;
54 }
55
56 /**
57 * @param DomainEventBus $eventBus
58 * @param CommandResult $result
59 *
60 * @return void
61 */
62 protected function emitSuccessEvent(DomainEventBus $eventBus, CommandResult $result)
63 {
64 if ($result->getData()) {
65 $eventBus->emit('BookingAdded', $result);
66 }
67 }
68 }
69