Completed
Branch EDTR/master (bb716e)
by
unknown
57:55 queued 49:04
created

DatetimeUpdate::mutateAndGetPayload()   C

Complexity

Conditions 11
Paths 1

Size

Total Lines 70

Duplication

Lines 70
Ratio 100 %

Importance

Changes 0
Metric Value
cc 11
nc 1
nop 2
dl 70
loc 70
rs 6.5077
c 0
b 0
f 0

How to fix   Long Method    Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
namespace EventEspresso\core\domain\services\graphql\mutators;
4
5
use EEM_Datetime;
6
use EE_Datetime;
7
use EventEspresso\core\domain\services\graphql\types\Datetime;
8
use EventEspresso\core\domain\services\graphql\data\mutations\DatetimeMutation;
9
10
use EE_Error;
11
use InvalidArgumentException;
12
use ReflectionException;
13
use EventEspresso\core\exceptions\InvalidDataTypeException;
14
use EventEspresso\core\exceptions\InvalidInterfaceException;
15
16
use GraphQL\Type\Definition\ResolveInfo;
17
use WPGraphQL\AppContext;
18
use GraphQL\Error\UserError;
19
use GraphQLRelay\Relay;
20
21 View Code Duplication
class DatetimeUpdate
22
{
23
24
    /**
25
     * Defines the mutation data modification closure.
26
     *
27
     * @param EEM_Datetime $model
28
     * @param Datetime     $type
29
     * @return callable
30
     */
31
    public static function mutateAndGetPayload(EEM_Datetime $model, Datetime $type)
32
    {
33
        /**
34
         * Updates an entity.
35
         *
36
         * @param array       $input   The input for the mutation
37
         * @param AppContext  $context The AppContext passed down to all resolvers
38
         * @param ResolveInfo $info    The ResolveInfo passed down to all resolvers
39
         * @return array
40
         * @throws UserError
41
         * @throws ReflectionException
42
         * @throws InvalidArgumentException
43
         * @throws InvalidInterfaceException
44
         * @throws InvalidDataTypeException
45
         * @throws EE_Error
46
         */
47
        return static function ($input, AppContext $context, ResolveInfo $info) use ($model, $type) {
48
            /**
49
             * Stop now if a user isn't allowed to create a datetime.
50
             */
51
            if (! current_user_can('ee_edit_events')) {
52
                // translators: the %1$s is the name of the object being mutated
53
                throw new UserError(
54
                    sprintf(__('Sorry, you are not allowed to edit %1$s', 'event_espresso'), $type->name())
55
                );
56
            }
57
            $id_parts = ! empty($input['id']) ? Relay::fromGlobalId($input['id']) : null;
58
59
            $id = ! empty($id_parts['id']) && is_int($id_parts['id']) ? $id_parts['id'] : 0;
60
            $entity = null;
61
62
            if ($id) {
63
                $entity = $model->get_one_by_ID($id);
64
            }
65
66
            /**
67
             * If there's no existing datetime, throw an exception
68
             */
69
            if (! $id || ! ($entity instanceof EE_Datetime)) {
70
                // translators: the placeholder is the name of the type being updated
71
                throw new UserError(
72
                    sprintf(__('No %1$s could be found to update', 'event_espresso'), $type->name())
73
                );
74
            }
75
76
            $tickets = [];
77
78
            $args = DatetimeMutation::prepareFields($input);
79
80
            if (isset($args['tickets'])) {
81
                $tickets = $args['tickets'];
82
                unset($args['tickets']);
83
            }
84
85
            // Update the entity
86
            $result = $entity->save($args);
87
88
            if (empty($result)) {
89
                throw new UserError(__('The object failed to update but no error was provided', 'event_espresso'));
90
            }
91
92
            if (! empty($tickets)) {
93
                DatetimeMutation::setRelatedTickets($entity, $tickets);
94
            }
95
96
            return [
97
                'id' => $id,
98
            ];
99
        };
100
    }
101
}
102