@@ -91,9 +91,9 @@ discard block |
||
91 | 91 | * @throws SparqlHelperException if the checker uses SPARQL and the query times out or some other error occurs |
92 | 92 | * @return CheckResult |
93 | 93 | */ |
94 | - public function checkConstraint( Context $context, Constraint $constraint ) { |
|
95 | - if ( $context->getSnakRank() === Statement::RANK_DEPRECATED ) { |
|
96 | - return new CheckResult( $context, $constraint, [], CheckResult::STATUS_DEPRECATED ); |
|
94 | + public function checkConstraint(Context $context, Constraint $constraint) { |
|
95 | + if ($context->getSnakRank() === Statement::RANK_DEPRECATED) { |
|
96 | + return new CheckResult($context, $constraint, [], CheckResult::STATUS_DEPRECATED); |
|
97 | 97 | } |
98 | 98 | |
99 | 99 | $parameters = []; |
@@ -105,8 +105,8 @@ discard block |
||
105 | 105 | $constraintTypeItemId |
106 | 106 | ); |
107 | 107 | $parameters['class'] = array_map( |
108 | - function( $id ) { |
|
109 | - return new ItemId( $id ); |
|
108 | + function($id) { |
|
109 | + return new ItemId($id); |
|
110 | 110 | }, |
111 | 111 | $classes |
112 | 112 | ); |
@@ -116,19 +116,19 @@ discard block |
||
116 | 116 | $constraintTypeItemId |
117 | 117 | ); |
118 | 118 | $relationIds = []; |
119 | - if ( $relation === 'instance' || $relation === 'instanceOrSubclass' ) { |
|
120 | - $relationIds[] = $this->config->get( 'WBQualityConstraintsInstanceOfId' ); |
|
119 | + if ($relation === 'instance' || $relation === 'instanceOrSubclass') { |
|
120 | + $relationIds[] = $this->config->get('WBQualityConstraintsInstanceOfId'); |
|
121 | 121 | } |
122 | - if ( $relation === 'subclass' || $relation === 'instanceOrSubclass' ) { |
|
123 | - $relationIds[] = $this->config->get( 'WBQualityConstraintsSubclassOfId' ); |
|
122 | + if ($relation === 'subclass' || $relation === 'instanceOrSubclass') { |
|
123 | + $relationIds[] = $this->config->get('WBQualityConstraintsSubclassOfId'); |
|
124 | 124 | } |
125 | - $parameters['relation'] = [ $relation ]; |
|
125 | + $parameters['relation'] = [$relation]; |
|
126 | 126 | |
127 | 127 | $snak = $context->getSnak(); |
128 | 128 | |
129 | - if ( !$snak instanceof PropertyValueSnak ) { |
|
129 | + if (!$snak instanceof PropertyValueSnak) { |
|
130 | 130 | // nothing to check |
131 | - return new CheckResult( $context, $constraint, $parameters, CheckResult::STATUS_COMPLIANCE ); |
|
131 | + return new CheckResult($context, $constraint, $parameters, CheckResult::STATUS_COMPLIANCE); |
|
132 | 132 | } |
133 | 133 | |
134 | 134 | $dataValue = $snak->getDataValue(); |
@@ -137,23 +137,23 @@ discard block |
||
137 | 137 | * error handling: |
138 | 138 | * type of $dataValue for properties with 'Value type' constraint has to be 'wikibase-entityid' |
139 | 139 | */ |
140 | - if ( !$dataValue instanceof EntityIdValue ) { |
|
141 | - $message = ( new ViolationMessage( 'wbqc-violation-message-value-needed-of-type' ) ) |
|
142 | - ->withEntityId( new ItemId( $constraintTypeItemId ), Role::CONSTRAINT_TYPE_ITEM ) |
|
143 | - ->withDataValueType( 'wikibase-entityid' ); |
|
144 | - return new CheckResult( $context, $constraint, $parameters, CheckResult::STATUS_VIOLATION, $message ); |
|
140 | + if (!$dataValue instanceof EntityIdValue) { |
|
141 | + $message = (new ViolationMessage('wbqc-violation-message-value-needed-of-type')) |
|
142 | + ->withEntityId(new ItemId($constraintTypeItemId), Role::CONSTRAINT_TYPE_ITEM) |
|
143 | + ->withDataValueType('wikibase-entityid'); |
|
144 | + return new CheckResult($context, $constraint, $parameters, CheckResult::STATUS_VIOLATION, $message); |
|
145 | 145 | } |
146 | 146 | |
147 | 147 | try { |
148 | - $item = $this->entityLookup->getEntity( $dataValue->getEntityId() ); |
|
149 | - } catch ( UnresolvedEntityRedirectException $e ) { |
|
148 | + $item = $this->entityLookup->getEntity($dataValue->getEntityId()); |
|
149 | + } catch (UnresolvedEntityRedirectException $e) { |
|
150 | 150 | // Edge case (double redirect): Pretend the entity doesn't exist |
151 | 151 | $item = null; |
152 | 152 | } |
153 | 153 | |
154 | - if ( !( $item instanceof StatementListProvidingEntity ) ) { |
|
155 | - $message = new ViolationMessage( 'wbqc-violation-message-value-entity-must-exist' ); |
|
156 | - return new CheckResult( $context, $constraint, $parameters, CheckResult::STATUS_VIOLATION, $message ); |
|
154 | + if (!($item instanceof StatementListProvidingEntity)) { |
|
155 | + $message = new ViolationMessage('wbqc-violation-message-value-entity-must-exist'); |
|
156 | + return new CheckResult($context, $constraint, $parameters, CheckResult::STATUS_VIOLATION, $message); |
|
157 | 157 | } |
158 | 158 | |
159 | 159 | $statements = $item->getStatements(); |
@@ -164,7 +164,7 @@ discard block |
||
164 | 164 | $classes |
165 | 165 | ); |
166 | 166 | |
167 | - if ( $result->getBool() ) { |
|
167 | + if ($result->getBool()) { |
|
168 | 168 | $message = null; |
169 | 169 | $status = CheckResult::STATUS_COMPLIANCE; |
170 | 170 | } else { |
@@ -178,11 +178,11 @@ discard block |
||
178 | 178 | $status = CheckResult::STATUS_VIOLATION; |
179 | 179 | } |
180 | 180 | |
181 | - return ( new CheckResult( $context, $constraint, $parameters, $status, $message ) ) |
|
182 | - ->withMetadata( $result->getMetadata() ); |
|
181 | + return (new CheckResult($context, $constraint, $parameters, $status, $message)) |
|
182 | + ->withMetadata($result->getMetadata()); |
|
183 | 183 | } |
184 | 184 | |
185 | - public function checkConstraintParameters( Constraint $constraint ) { |
|
185 | + public function checkConstraintParameters(Constraint $constraint) { |
|
186 | 186 | $constraintParameters = $constraint->getConstraintParameters(); |
187 | 187 | $constraintTypeItemId = $constraint->getConstraintTypeItemId(); |
188 | 188 | $exceptions = []; |
@@ -191,7 +191,7 @@ discard block |
||
191 | 191 | $constraintParameters, |
192 | 192 | $constraintTypeItemId |
193 | 193 | ); |
194 | - } catch ( ConstraintParameterException $e ) { |
|
194 | + } catch (ConstraintParameterException $e) { |
|
195 | 195 | $exceptions[] = $e; |
196 | 196 | } |
197 | 197 | try { |
@@ -199,7 +199,7 @@ discard block |
||
199 | 199 | $constraintParameters, |
200 | 200 | $constraintTypeItemId |
201 | 201 | ); |
202 | - } catch ( ConstraintParameterException $e ) { |
|
202 | + } catch (ConstraintParameterException $e) { |
|
203 | 203 | $exceptions[] = $e; |
204 | 204 | } |
205 | 205 | return $exceptions; |
@@ -53,7 +53,7 @@ discard block |
||
53 | 53 | $this->config = $config; |
54 | 54 | $this->timeParser = new IsoTimestampParser(); |
55 | 55 | $this->timeCalculator = new TimeValueCalculator(); |
56 | - $this->timeValueComparer = new TimeValueComparer( $this->timeCalculator ); |
|
56 | + $this->timeValueComparer = new TimeValueComparer($this->timeCalculator); |
|
57 | 57 | $this->unitConverter = $unitConverter; |
58 | 58 | } |
59 | 59 | |
@@ -61,10 +61,10 @@ discard block |
||
61 | 61 | * @param UnboundedQuantityValue $value |
62 | 62 | * @return UnboundedQuantityValue $value converted to standard units if possible, otherwise unchanged $value. |
63 | 63 | */ |
64 | - private function standardize( UnboundedQuantityValue $value ) { |
|
65 | - if ( $this->unitConverter !== null ) { |
|
66 | - $standard = $this->unitConverter->toStandardUnits( $value ); |
|
67 | - if ( $standard !== null ) { |
|
64 | + private function standardize(UnboundedQuantityValue $value) { |
|
65 | + if ($this->unitConverter !== null) { |
|
66 | + $standard = $this->unitConverter->toStandardUnits($value); |
|
67 | + if ($standard !== null) { |
|
68 | 68 | return $standard; |
69 | 69 | } else { |
70 | 70 | return $value; |
@@ -86,33 +86,33 @@ discard block |
||
86 | 86 | * when $lhs is respectively less than, equal to, or greater than $rhs. |
87 | 87 | * (In other words, just like the “spaceship” operator <=>.) |
88 | 88 | */ |
89 | - public function getComparison( DataValue $lhs = null, DataValue $rhs = null ) { |
|
90 | - if ( $lhs === null || $rhs === null ) { |
|
89 | + public function getComparison(DataValue $lhs = null, DataValue $rhs = null) { |
|
90 | + if ($lhs === null || $rhs === null) { |
|
91 | 91 | return 0; |
92 | 92 | } |
93 | 93 | |
94 | - if ( $lhs->getType() !== $rhs->getType() ) { |
|
95 | - throw new InvalidArgumentException( 'Different data value types' ); |
|
94 | + if ($lhs->getType() !== $rhs->getType()) { |
|
95 | + throw new InvalidArgumentException('Different data value types'); |
|
96 | 96 | } |
97 | 97 | |
98 | - switch ( $lhs->getType() ) { |
|
98 | + switch ($lhs->getType()) { |
|
99 | 99 | case 'time': |
100 | 100 | /** @var TimeValue $lhs */ |
101 | 101 | /** @var TimeValue $rhs */ |
102 | 102 | '@phan-var TimeValue $lhs'; |
103 | 103 | '@phan-var TimeValue $rhs'; |
104 | - return $this->timeValueComparer->getComparison( $lhs, $rhs ); |
|
104 | + return $this->timeValueComparer->getComparison($lhs, $rhs); |
|
105 | 105 | case 'quantity': |
106 | 106 | /** @var QuantityValue|UnboundedQuantityValue $lhs */ |
107 | 107 | /** @var QuantityValue|UnboundedQuantityValue $rhs */ |
108 | 108 | '@phan-var QuantityValue|UnboundedQuantityValue $lhs'; |
109 | 109 | '@phan-var QuantityValue|UnboundedQuantityValue $rhs'; |
110 | - $lhsStandard = $this->standardize( $lhs ); |
|
111 | - $rhsStandard = $this->standardize( $rhs ); |
|
112 | - return $lhsStandard->getAmount()->compare( $rhsStandard->getAmount() ); |
|
110 | + $lhsStandard = $this->standardize($lhs); |
|
111 | + $rhsStandard = $this->standardize($rhs); |
|
112 | + return $lhsStandard->getAmount()->compare($rhsStandard->getAmount()); |
|
113 | 113 | } |
114 | 114 | |
115 | - throw new InvalidArgumentException( 'Unsupported data value type' ); |
|
115 | + throw new InvalidArgumentException('Unsupported data value type'); |
|
116 | 116 | } |
117 | 117 | |
118 | 118 | /** |
@@ -127,71 +127,71 @@ discard block |
||
127 | 127 | * @throws InvalidArgumentException if the values do not both have the same, supported data value type |
128 | 128 | * @return UnboundedQuantityValue |
129 | 129 | */ |
130 | - public function getDifference( DataValue $minuend, DataValue $subtrahend ) { |
|
131 | - if ( $minuend->getType() === 'time' && $subtrahend->getType() === 'time' ) { |
|
132 | - $minuendSeconds = $this->timeCalculator->getTimestamp( $minuend ); |
|
133 | - $subtrahendSeconds = $this->timeCalculator->getTimestamp( $subtrahend ); |
|
130 | + public function getDifference(DataValue $minuend, DataValue $subtrahend) { |
|
131 | + if ($minuend->getType() === 'time' && $subtrahend->getType() === 'time') { |
|
132 | + $minuendSeconds = $this->timeCalculator->getTimestamp($minuend); |
|
133 | + $subtrahendSeconds = $this->timeCalculator->getTimestamp($subtrahend); |
|
134 | 134 | return UnboundedQuantityValue::newFromNumber( |
135 | 135 | $minuendSeconds - $subtrahendSeconds, |
136 | - $this->config->get( 'WBQualityConstraintsSecondUnit' ) |
|
136 | + $this->config->get('WBQualityConstraintsSecondUnit') |
|
137 | 137 | ); |
138 | 138 | } |
139 | - if ( $minuend->getType() === 'quantity' && $subtrahend->getType() === 'quantity' ) { |
|
140 | - $minuendStandard = $this->standardize( $minuend ); |
|
141 | - $subtrahendStandard = $this->standardize( $subtrahend ); |
|
139 | + if ($minuend->getType() === 'quantity' && $subtrahend->getType() === 'quantity') { |
|
140 | + $minuendStandard = $this->standardize($minuend); |
|
141 | + $subtrahendStandard = $this->standardize($subtrahend); |
|
142 | 142 | $minuendValue = $minuendStandard->getAmount()->getValueFloat(); |
143 | 143 | $subtrahendValue = $subtrahendStandard->getAmount()->getValueFloat(); |
144 | 144 | $diff = $minuendValue - $subtrahendValue; |
145 | 145 | // we don’t check whether both quantities have the same standard unit – |
146 | 146 | // that’s the job of a different constraint type, Units (T164372) |
147 | - return UnboundedQuantityValue::newFromNumber( $diff, $minuendStandard->getUnit() ); |
|
147 | + return UnboundedQuantityValue::newFromNumber($diff, $minuendStandard->getUnit()); |
|
148 | 148 | } |
149 | 149 | |
150 | - throw new InvalidArgumentException( 'Unsupported or different data value types' ); |
|
150 | + throw new InvalidArgumentException('Unsupported or different data value types'); |
|
151 | 151 | } |
152 | 152 | |
153 | - public function getDifferenceInYears( TimeValue $minuend, TimeValue $subtrahend ) { |
|
154 | - if ( !preg_match( '/^([-+]\d{1,16})-(.*)$/', $minuend->getTime(), $minuendMatches ) || |
|
155 | - !preg_match( '/^([-+]\d{1,16})-(.*)$/', $subtrahend->getTime(), $subtrahendMatches ) |
|
153 | + public function getDifferenceInYears(TimeValue $minuend, TimeValue $subtrahend) { |
|
154 | + if (!preg_match('/^([-+]\d{1,16})-(.*)$/', $minuend->getTime(), $minuendMatches) || |
|
155 | + !preg_match('/^([-+]\d{1,16})-(.*)$/', $subtrahend->getTime(), $subtrahendMatches) |
|
156 | 156 | ) { |
157 | - throw new InvalidArgumentException( 'TimeValue::getTime() did not match expected format' ); |
|
157 | + throw new InvalidArgumentException('TimeValue::getTime() did not match expected format'); |
|
158 | 158 | } |
159 | - $minuendYear = (float)$minuendMatches[1]; |
|
160 | - $subtrahendYear = (float)$subtrahendMatches[1]; |
|
159 | + $minuendYear = (float) $minuendMatches[1]; |
|
160 | + $subtrahendYear = (float) $subtrahendMatches[1]; |
|
161 | 161 | $minuendRest = $minuendMatches[2]; |
162 | 162 | $subtrahendRest = $subtrahendMatches[2]; |
163 | 163 | |
164 | 164 | // calculate difference of years |
165 | 165 | $diff = $minuendYear - $subtrahendYear; |
166 | - if ( $minuendYear > 0.0 && $subtrahendYear < 0.0 ) { |
|
166 | + if ($minuendYear > 0.0 && $subtrahendYear < 0.0) { |
|
167 | 167 | $diff -= 1.0; // there is no year 0, remove it from difference |
168 | - } elseif ( $minuendYear < 0.0 && $subtrahendYear > 0.0 ) { |
|
168 | + } elseif ($minuendYear < 0.0 && $subtrahendYear > 0.0) { |
|
169 | 169 | $diff -= -1.0; // there is no year 0, remove it from negative difference |
170 | 170 | } |
171 | 171 | |
172 | 172 | // adjust for date within year by parsing the month-day part within the same year |
173 | - $minuendDateValue = $this->timeParser->parse( '+0000000000001970-' . $minuendRest ); |
|
174 | - $subtrahendDateValue = $this->timeParser->parse( '+0000000000001970-' . $subtrahendRest ); |
|
175 | - $minuendDateSeconds = $this->timeCalculator->getTimestamp( $minuendDateValue ); |
|
176 | - $subtrahendDateSeconds = $this->timeCalculator->getTimestamp( $subtrahendDateValue ); |
|
177 | - if ( $minuendDateSeconds < $subtrahendDateSeconds ) { |
|
173 | + $minuendDateValue = $this->timeParser->parse('+0000000000001970-'.$minuendRest); |
|
174 | + $subtrahendDateValue = $this->timeParser->parse('+0000000000001970-'.$subtrahendRest); |
|
175 | + $minuendDateSeconds = $this->timeCalculator->getTimestamp($minuendDateValue); |
|
176 | + $subtrahendDateSeconds = $this->timeCalculator->getTimestamp($subtrahendDateValue); |
|
177 | + if ($minuendDateSeconds < $subtrahendDateSeconds) { |
|
178 | 178 | // difference in the last year is actually less than one full year |
179 | 179 | // e. g. 1975-03-01 - 1974-09-01 is just six months |
180 | 180 | // (we don’t need sub-year precision in the difference, adjusting by 0.5 is enough) |
181 | 181 | $diff -= 0.5; |
182 | - } elseif ( $minuendDateSeconds > $subtrahendDateSeconds ) { |
|
182 | + } elseif ($minuendDateSeconds > $subtrahendDateSeconds) { |
|
183 | 183 | // difference in the last year is actually more than one full year |
184 | 184 | // e. g. 1975-09-01 - 1974-03-01 is 18 months |
185 | 185 | // (we don’t need sub-year precision in the difference, adjusting by 0.5 is enough) |
186 | 186 | $diff += 0.5; |
187 | 187 | } |
188 | 188 | |
189 | - $unit = $this->config->get( 'WBQualityConstraintsYearUnit' ); |
|
190 | - return UnboundedQuantityValue::newFromNumber( $diff, $unit ); |
|
189 | + $unit = $this->config->get('WBQualityConstraintsYearUnit'); |
|
190 | + return UnboundedQuantityValue::newFromNumber($diff, $unit); |
|
191 | 191 | } |
192 | 192 | |
193 | - public function isFutureTime( TimeValue $timeValue ) { |
|
194 | - return $this->timeValueComparer->isFutureTime( $timeValue ); |
|
193 | + public function isFutureTime(TimeValue $timeValue) { |
|
194 | + return $this->timeValueComparer->isFutureTime($timeValue); |
|
195 | 195 | } |
196 | 196 | |
197 | 197 | } |
@@ -80,23 +80,23 @@ discard block |
||
80 | 80 | * @return bool |
81 | 81 | * @throws OverflowException if $entitiesChecked exceeds the configured limit |
82 | 82 | */ |
83 | - private function isSubclassOf( EntityId $comparativeClass, array $classesToCheck, &$entitiesChecked = 0 ) { |
|
84 | - $maxEntities = $this->config->get( 'WBQualityConstraintsTypeCheckMaxEntities' ); |
|
83 | + private function isSubclassOf(EntityId $comparativeClass, array $classesToCheck, &$entitiesChecked = 0) { |
|
84 | + $maxEntities = $this->config->get('WBQualityConstraintsTypeCheckMaxEntities'); |
|
85 | 85 | if ( ++$entitiesChecked > $maxEntities ) { |
86 | - throw new OverflowException( 'Too many entities to check' ); |
|
86 | + throw new OverflowException('Too many entities to check'); |
|
87 | 87 | } |
88 | 88 | |
89 | - $item = $this->entityLookup->getEntity( $comparativeClass ); |
|
90 | - if ( !( $item instanceof StatementListProvider ) ) { |
|
89 | + $item = $this->entityLookup->getEntity($comparativeClass); |
|
90 | + if (!($item instanceof StatementListProvider)) { |
|
91 | 91 | return false; // lookup failed, probably because item doesn't exist |
92 | 92 | } |
93 | 93 | |
94 | - $subclassId = $this->config->get( 'WBQualityConstraintsSubclassOfId' ); |
|
94 | + $subclassId = $this->config->get('WBQualityConstraintsSubclassOfId'); |
|
95 | 95 | /** @var Statement $statement */ |
96 | - foreach ( $item->getStatements()->getByPropertyId( new PropertyId( $subclassId ) ) as $statement ) { |
|
96 | + foreach ($item->getStatements()->getByPropertyId(new PropertyId($subclassId)) as $statement) { |
|
97 | 97 | $mainSnak = $statement->getMainSnak(); |
98 | 98 | |
99 | - if ( !( $this->hasCorrectType( $mainSnak ) ) ) { |
|
99 | + if (!($this->hasCorrectType($mainSnak))) { |
|
100 | 100 | continue; |
101 | 101 | } |
102 | 102 | /** @var PropertyValueSnak $mainSnak */ |
@@ -106,11 +106,11 @@ discard block |
||
106 | 106 | '@phan-var EntityIdValue $dataValue'; |
107 | 107 | $comparativeClass = $dataValue->getEntityId(); |
108 | 108 | |
109 | - if ( in_array( $comparativeClass->getSerialization(), $classesToCheck ) ) { |
|
109 | + if (in_array($comparativeClass->getSerialization(), $classesToCheck)) { |
|
110 | 110 | return true; |
111 | 111 | } |
112 | 112 | |
113 | - if ( $this->isSubclassOf( $comparativeClass, $classesToCheck, $entitiesChecked ) ) { |
|
113 | + if ($this->isSubclassOf($comparativeClass, $classesToCheck, $entitiesChecked)) { |
|
114 | 114 | return true; |
115 | 115 | } |
116 | 116 | } |
@@ -131,48 +131,48 @@ discard block |
||
131 | 131 | * @return CachedBool |
132 | 132 | * @throws SparqlHelperException if SPARQL is used and the query times out or some other error occurs |
133 | 133 | */ |
134 | - public function isSubclassOfWithSparqlFallback( EntityId $comparativeClass, array $classesToCheck ) { |
|
134 | + public function isSubclassOfWithSparqlFallback(EntityId $comparativeClass, array $classesToCheck) { |
|
135 | 135 | try { |
136 | 136 | $entitiesChecked = 0; |
137 | - $start1 = microtime( true ); |
|
138 | - $isSubclass = $this->isSubclassOf( $comparativeClass, $classesToCheck, $entitiesChecked ); |
|
139 | - $end1 = microtime( true ); |
|
137 | + $start1 = microtime(true); |
|
138 | + $isSubclass = $this->isSubclassOf($comparativeClass, $classesToCheck, $entitiesChecked); |
|
139 | + $end1 = microtime(true); |
|
140 | 140 | $this->dataFactory->timing( |
141 | 141 | 'wikibase.quality.constraints.type.php.success.timing', |
142 | - ( $end1 - $start1 ) * 1000 |
|
142 | + ($end1 - $start1) * 1000 |
|
143 | 143 | ); |
144 | 144 | $this->dataFactory->timing( // not really a timing, but works like one (we want percentiles etc.) |
145 | 145 | 'wikibase.quality.constraints.type.php.success.entities', |
146 | 146 | $entitiesChecked |
147 | 147 | ); |
148 | 148 | |
149 | - return new CachedBool( $isSubclass, Metadata::blank() ); |
|
150 | - } catch ( OverflowException $e ) { |
|
151 | - $end1 = microtime( true ); |
|
149 | + return new CachedBool($isSubclass, Metadata::blank()); |
|
150 | + } catch (OverflowException $e) { |
|
151 | + $end1 = microtime(true); |
|
152 | 152 | $this->dataFactory->timing( |
153 | 153 | 'wikibase.quality.constraints.type.php.overflow.timing', |
154 | - ( $end1 - $start1 ) * 1000 |
|
154 | + ($end1 - $start1) * 1000 |
|
155 | 155 | ); |
156 | 156 | |
157 | - if ( !( $this->sparqlHelper instanceof DummySparqlHelper ) ) { |
|
157 | + if (!($this->sparqlHelper instanceof DummySparqlHelper)) { |
|
158 | 158 | $this->dataFactory->increment( |
159 | 159 | 'wikibase.quality.constraints.sparql.typeFallback' |
160 | 160 | ); |
161 | 161 | |
162 | - $start2 = microtime( true ); |
|
162 | + $start2 = microtime(true); |
|
163 | 163 | $hasType = $this->sparqlHelper->hasType( |
164 | 164 | $comparativeClass->getSerialization(), |
165 | 165 | $classesToCheck |
166 | 166 | ); |
167 | - $end2 = microtime( true ); |
|
167 | + $end2 = microtime(true); |
|
168 | 168 | $this->dataFactory->timing( |
169 | 169 | 'wikibase.quality.constraints.type.sparql.success.timing', |
170 | - ( $end2 - $start2 ) * 1000 |
|
170 | + ($end2 - $start2) * 1000 |
|
171 | 171 | ); |
172 | 172 | |
173 | 173 | return $hasType; |
174 | 174 | } else { |
175 | - return new CachedBool( false, Metadata::blank() ); |
|
175 | + return new CachedBool(false, Metadata::blank()); |
|
176 | 176 | } |
177 | 177 | } |
178 | 178 | } |
@@ -190,13 +190,13 @@ discard block |
||
190 | 190 | * @return CachedBool |
191 | 191 | * @throws SparqlHelperException if SPARQL is used and the query times out or some other error occurs |
192 | 192 | */ |
193 | - public function hasClassInRelation( StatementList $statements, array $relationIds, array $classesToCheck ) { |
|
193 | + public function hasClassInRelation(StatementList $statements, array $relationIds, array $classesToCheck) { |
|
194 | 194 | $metadatas = []; |
195 | 195 | |
196 | - foreach ( $this->getStatementsByPropertyIds( $statements, $relationIds ) as $statement ) { |
|
196 | + foreach ($this->getStatementsByPropertyIds($statements, $relationIds) as $statement) { |
|
197 | 197 | $mainSnak = $statement->getMainSnak(); |
198 | 198 | |
199 | - if ( !$this->hasCorrectType( $mainSnak ) ) { |
|
199 | + if (!$this->hasCorrectType($mainSnak)) { |
|
200 | 200 | continue; |
201 | 201 | } |
202 | 202 | /** @var PropertyValueSnak $mainSnak */ |
@@ -206,24 +206,24 @@ discard block |
||
206 | 206 | '@phan-var EntityIdValue $dataValue'; |
207 | 207 | $comparativeClass = $dataValue->getEntityId(); |
208 | 208 | |
209 | - if ( in_array( $comparativeClass->getSerialization(), $classesToCheck ) ) { |
|
209 | + if (in_array($comparativeClass->getSerialization(), $classesToCheck)) { |
|
210 | 210 | // discard $metadatas, we know this is fresh |
211 | - return new CachedBool( true, Metadata::blank() ); |
|
211 | + return new CachedBool(true, Metadata::blank()); |
|
212 | 212 | } |
213 | 213 | |
214 | - $result = $this->isSubclassOfWithSparqlFallback( $comparativeClass, $classesToCheck ); |
|
214 | + $result = $this->isSubclassOfWithSparqlFallback($comparativeClass, $classesToCheck); |
|
215 | 215 | $metadatas[] = $result->getMetadata(); |
216 | - if ( $result->getBool() ) { |
|
216 | + if ($result->getBool()) { |
|
217 | 217 | return new CachedBool( |
218 | 218 | true, |
219 | - Metadata::merge( $metadatas ) |
|
219 | + Metadata::merge($metadatas) |
|
220 | 220 | ); |
221 | 221 | } |
222 | 222 | } |
223 | 223 | |
224 | 224 | return new CachedBool( |
225 | 225 | false, |
226 | - Metadata::merge( $metadatas ) |
|
226 | + Metadata::merge($metadatas) |
|
227 | 227 | ); |
228 | 228 | } |
229 | 229 | |
@@ -232,7 +232,7 @@ discard block |
||
232 | 232 | * @return bool |
233 | 233 | * @phan-assert PropertyValueSnak $mainSnak |
234 | 234 | */ |
235 | - private function hasCorrectType( Snak $mainSnak ) { |
|
235 | + private function hasCorrectType(Snak $mainSnak) { |
|
236 | 236 | return $mainSnak instanceof PropertyValueSnak |
237 | 237 | && $mainSnak->getDataValue()->getType() === 'wikibase-entityid'; |
238 | 238 | } |
@@ -249,12 +249,12 @@ discard block |
||
249 | 249 | ) { |
250 | 250 | $statementArrays = []; |
251 | 251 | |
252 | - foreach ( $propertyIdSerializations as $propertyIdSerialization ) { |
|
253 | - $propertyId = new PropertyId( $propertyIdSerialization ); |
|
254 | - $statementArrays[] = $statements->getByPropertyId( $propertyId )->toArray(); |
|
252 | + foreach ($propertyIdSerializations as $propertyIdSerialization) { |
|
253 | + $propertyId = new PropertyId($propertyIdSerialization); |
|
254 | + $statementArrays[] = $statements->getByPropertyId($propertyId)->toArray(); |
|
255 | 255 | } |
256 | 256 | |
257 | - return call_user_func_array( 'array_merge', $statementArrays ); |
|
257 | + return call_user_func_array('array_merge', $statementArrays); |
|
258 | 258 | } |
259 | 259 | |
260 | 260 | /** |
@@ -266,10 +266,10 @@ discard block |
||
266 | 266 | * |
267 | 267 | * @return ViolationMessage |
268 | 268 | */ |
269 | - public function getViolationMessage( PropertyId $propertyId, EntityId $entityId, array $classes, $checker, $relation ) { |
|
269 | + public function getViolationMessage(PropertyId $propertyId, EntityId $entityId, array $classes, $checker, $relation) { |
|
270 | 270 | $classes = array_map( |
271 | - function( $itemIdSerialization ) { |
|
272 | - return new ItemId( $itemIdSerialization ); |
|
271 | + function($itemIdSerialization) { |
|
272 | + return new ItemId($itemIdSerialization); |
|
273 | 273 | }, |
274 | 274 | $classes |
275 | 275 | ); |
@@ -281,10 +281,10 @@ discard block |
||
281 | 281 | // wbqc-violation-message-valueType-instance |
282 | 282 | // wbqc-violation-message-valueType-subclass |
283 | 283 | // wbqc-violation-message-valueType-instanceOrSubclass |
284 | - return ( new ViolationMessage( 'wbqc-violation-message-' . $checker . '-' . $relation ) ) |
|
285 | - ->withEntityId( $propertyId, Role::CONSTRAINT_PROPERTY ) |
|
286 | - ->withEntityId( $entityId, Role::SUBJECT ) |
|
287 | - ->withEntityIdList( $classes, Role::OBJECT ); |
|
284 | + return (new ViolationMessage('wbqc-violation-message-'.$checker.'-'.$relation)) |
|
285 | + ->withEntityId($propertyId, Role::CONSTRAINT_PROPERTY) |
|
286 | + ->withEntityId($entityId, Role::SUBJECT) |
|
287 | + ->withEntityIdList($classes, Role::OBJECT); |
|
288 | 288 | } |
289 | 289 | |
290 | 290 | } |
@@ -13,8 +13,8 @@ discard block |
||
13 | 13 | * @param ContextCursor $cursor |
14 | 14 | * @return array |
15 | 15 | */ |
16 | - public function serialize( ContextCursor $cursor ) { |
|
17 | - if ( $cursor instanceof EntityContextCursor ) { |
|
16 | + public function serialize(ContextCursor $cursor) { |
|
17 | + if ($cursor instanceof EntityContextCursor) { |
|
18 | 18 | return [ |
19 | 19 | 't' => '\entity', |
20 | 20 | 'i' => $cursor->getEntityId(), |
@@ -30,9 +30,9 @@ discard block |
||
30 | 30 | 'h' => $cursor->getSnakHash(), |
31 | 31 | ]; |
32 | 32 | |
33 | - if ( $type === Context::TYPE_QUALIFIER || $type === Context::TYPE_REFERENCE ) { |
|
33 | + if ($type === Context::TYPE_QUALIFIER || $type === Context::TYPE_REFERENCE) { |
|
34 | 34 | $serialization['P'] = $cursor->getSnakPropertyId(); |
35 | - if ( $type === Context::TYPE_REFERENCE ) { |
|
35 | + if ($type === Context::TYPE_REFERENCE) { |
|
36 | 36 | /** @var ReferenceContextCursor $cursor */ |
37 | 37 | '@phan-var ReferenceContextCursor $cursor'; |
38 | 38 | $serialization['r'] = $cursor->getReferenceHash(); |
@@ -74,19 +74,19 @@ discard block |
||
74 | 74 | * |
75 | 75 | * @return self |
76 | 76 | */ |
77 | - public static function newFromGlobalState( ApiMain $main, $name, $prefix = '' ) { |
|
77 | + public static function newFromGlobalState(ApiMain $main, $name, $prefix = '') { |
|
78 | 78 | $repo = WikibaseRepo::getDefaultInstance(); |
79 | - $helperFactory = $repo->getApiHelperFactory( RequestContext::getMain() ); |
|
79 | + $helperFactory = $repo->getApiHelperFactory(RequestContext::getMain()); |
|
80 | 80 | $language = $repo->getUserLanguage(); |
81 | 81 | |
82 | 82 | $entityIdHtmlLinkFormatterFactory = $repo->getEntityIdHtmlLinkFormatterFactory(); |
83 | 83 | $entityIdHtmlLinkFormatter = $entityIdHtmlLinkFormatterFactory |
84 | - ->getEntityIdFormatter( $language ); |
|
84 | + ->getEntityIdFormatter($language); |
|
85 | 85 | $formatterOptions = new FormatterOptions(); |
86 | - $formatterOptions->setOption( SnakFormatter::OPT_LANG, $language->getCode() ); |
|
86 | + $formatterOptions->setOption(SnakFormatter::OPT_LANG, $language->getCode()); |
|
87 | 87 | $valueFormatterFactory = $repo->getValueFormatterFactory(); |
88 | 88 | $dataValueFormatter = $valueFormatterFactory |
89 | - ->getValueFormatter( SnakFormatter::FORMAT_HTML, $formatterOptions ); |
|
89 | + ->getValueFormatter(SnakFormatter::FORMAT_HTML, $formatterOptions); |
|
90 | 90 | $config = MediaWikiServices::getInstance()->getMainConfig(); |
91 | 91 | $violationMessageRenderer = new MultilingualTextViolationMessageRenderer( |
92 | 92 | $entityIdHtmlLinkFormatter, |
@@ -126,9 +126,9 @@ discard block |
||
126 | 126 | StatementGuidParser $statementGuidParser, |
127 | 127 | IBufferingStatsdDataFactory $dataFactory |
128 | 128 | ) { |
129 | - parent::__construct( $main, $name, $prefix ); |
|
129 | + parent::__construct($main, $name, $prefix); |
|
130 | 130 | |
131 | - $this->apiErrorReporter = $apiHelperFactory->getErrorReporter( $this ); |
|
131 | + $this->apiErrorReporter = $apiHelperFactory->getErrorReporter($this); |
|
132 | 132 | $this->delegatingConstraintChecker = $delegatingConstraintChecker; |
133 | 133 | $this->violationMessageRenderer = $violationMessageRenderer; |
134 | 134 | $this->statementGuidParser = $statementGuidParser; |
@@ -143,39 +143,39 @@ discard block |
||
143 | 143 | $params = $this->extractRequestParams(); |
144 | 144 | $result = $this->getResult(); |
145 | 145 | |
146 | - $propertyIds = $this->parsePropertyIds( $params[self::PARAM_PROPERTY_ID] ); |
|
147 | - $constraintIds = $this->parseConstraintIds( $params[self::PARAM_CONSTRAINT_ID] ); |
|
146 | + $propertyIds = $this->parsePropertyIds($params[self::PARAM_PROPERTY_ID]); |
|
147 | + $constraintIds = $this->parseConstraintIds($params[self::PARAM_CONSTRAINT_ID]); |
|
148 | 148 | |
149 | - $this->checkPropertyIds( $propertyIds, $result ); |
|
150 | - $this->checkConstraintIds( $constraintIds, $result ); |
|
149 | + $this->checkPropertyIds($propertyIds, $result); |
|
150 | + $this->checkConstraintIds($constraintIds, $result); |
|
151 | 151 | |
152 | - $result->addValue( null, 'success', 1 ); |
|
152 | + $result->addValue(null, 'success', 1); |
|
153 | 153 | } |
154 | 154 | |
155 | 155 | /** |
156 | 156 | * @param array|null $propertyIdSerializations |
157 | 157 | * @return PropertyId[] |
158 | 158 | */ |
159 | - private function parsePropertyIds( $propertyIdSerializations ) { |
|
160 | - if ( $propertyIdSerializations === null ) { |
|
159 | + private function parsePropertyIds($propertyIdSerializations) { |
|
160 | + if ($propertyIdSerializations === null) { |
|
161 | 161 | return []; |
162 | - } elseif ( empty( $propertyIdSerializations ) ) { |
|
162 | + } elseif (empty($propertyIdSerializations)) { |
|
163 | 163 | $this->apiErrorReporter->dieError( |
164 | - 'If ' . self::PARAM_PROPERTY_ID . ' is specified, it must be nonempty.', |
|
164 | + 'If '.self::PARAM_PROPERTY_ID.' is specified, it must be nonempty.', |
|
165 | 165 | 'no-data' |
166 | 166 | ); |
167 | 167 | } |
168 | 168 | |
169 | 169 | return array_map( |
170 | - function( $propertyIdSerialization ) { |
|
170 | + function($propertyIdSerialization) { |
|
171 | 171 | try { |
172 | - return new PropertyId( $propertyIdSerialization ); |
|
173 | - } catch ( InvalidArgumentException $e ) { |
|
172 | + return new PropertyId($propertyIdSerialization); |
|
173 | + } catch (InvalidArgumentException $e) { |
|
174 | 174 | $this->apiErrorReporter->dieError( |
175 | 175 | "Invalid id: $propertyIdSerialization", |
176 | 176 | 'invalid-property-id', |
177 | 177 | 0, // default argument |
178 | - [ self::PARAM_PROPERTY_ID => $propertyIdSerialization ] |
|
178 | + [self::PARAM_PROPERTY_ID => $propertyIdSerialization] |
|
179 | 179 | ); |
180 | 180 | } |
181 | 181 | }, |
@@ -187,35 +187,35 @@ discard block |
||
187 | 187 | * @param array|null $constraintIds |
188 | 188 | * @return string[] |
189 | 189 | */ |
190 | - private function parseConstraintIds( $constraintIds ) { |
|
191 | - if ( $constraintIds === null ) { |
|
190 | + private function parseConstraintIds($constraintIds) { |
|
191 | + if ($constraintIds === null) { |
|
192 | 192 | return []; |
193 | - } elseif ( empty( $constraintIds ) ) { |
|
193 | + } elseif (empty($constraintIds)) { |
|
194 | 194 | $this->apiErrorReporter->dieError( |
195 | - 'If ' . self::PARAM_CONSTRAINT_ID . ' is specified, it must be nonempty.', |
|
195 | + 'If '.self::PARAM_CONSTRAINT_ID.' is specified, it must be nonempty.', |
|
196 | 196 | 'no-data' |
197 | 197 | ); |
198 | 198 | } |
199 | 199 | |
200 | 200 | return array_map( |
201 | - function( $constraintId ) { |
|
201 | + function($constraintId) { |
|
202 | 202 | try { |
203 | - $propertyId = $this->statementGuidParser->parse( $constraintId )->getEntityId(); |
|
204 | - if ( !$propertyId instanceof PropertyId ) { |
|
203 | + $propertyId = $this->statementGuidParser->parse($constraintId)->getEntityId(); |
|
204 | + if (!$propertyId instanceof PropertyId) { |
|
205 | 205 | $this->apiErrorReporter->dieError( |
206 | 206 | "Invalid property ID: {$propertyId->getSerialization()}", |
207 | 207 | 'invalid-property-id', |
208 | 208 | 0, // default argument |
209 | - [ self::PARAM_CONSTRAINT_ID => $constraintId ] |
|
209 | + [self::PARAM_CONSTRAINT_ID => $constraintId] |
|
210 | 210 | ); |
211 | 211 | } |
212 | 212 | return $constraintId; |
213 | - } catch ( StatementGuidParsingException $e ) { |
|
213 | + } catch (StatementGuidParsingException $e) { |
|
214 | 214 | $this->apiErrorReporter->dieError( |
215 | 215 | "Invalid statement GUID: $constraintId", |
216 | 216 | 'invalid-guid', |
217 | 217 | 0, // default argument |
218 | - [ self::PARAM_CONSTRAINT_ID => $constraintId ] |
|
218 | + [self::PARAM_CONSTRAINT_ID => $constraintId] |
|
219 | 219 | ); |
220 | 220 | } |
221 | 221 | }, |
@@ -227,12 +227,12 @@ discard block |
||
227 | 227 | * @param PropertyId[] $propertyIds |
228 | 228 | * @param ApiResult $result |
229 | 229 | */ |
230 | - private function checkPropertyIds( array $propertyIds, ApiResult $result ) { |
|
231 | - foreach ( $propertyIds as $propertyId ) { |
|
232 | - $result->addArrayType( $this->getResultPathForPropertyId( $propertyId ), 'assoc' ); |
|
230 | + private function checkPropertyIds(array $propertyIds, ApiResult $result) { |
|
231 | + foreach ($propertyIds as $propertyId) { |
|
232 | + $result->addArrayType($this->getResultPathForPropertyId($propertyId), 'assoc'); |
|
233 | 233 | $allConstraintExceptions = $this->delegatingConstraintChecker |
234 | - ->checkConstraintParametersOnPropertyId( $propertyId ); |
|
235 | - foreach ( $allConstraintExceptions as $constraintId => $constraintParameterExceptions ) { |
|
234 | + ->checkConstraintParametersOnPropertyId($propertyId); |
|
235 | + foreach ($allConstraintExceptions as $constraintId => $constraintParameterExceptions) { |
|
236 | 236 | $this->addConstraintParameterExceptionsToResult( |
237 | 237 | $constraintId, |
238 | 238 | $constraintParameterExceptions, |
@@ -246,15 +246,15 @@ discard block |
||
246 | 246 | * @param string[] $constraintIds |
247 | 247 | * @param ApiResult $result |
248 | 248 | */ |
249 | - private function checkConstraintIds( array $constraintIds, ApiResult $result ) { |
|
250 | - foreach ( $constraintIds as $constraintId ) { |
|
251 | - if ( $result->getResultData( $this->getResultPathForConstraintId( $constraintId ) ) ) { |
|
249 | + private function checkConstraintIds(array $constraintIds, ApiResult $result) { |
|
250 | + foreach ($constraintIds as $constraintId) { |
|
251 | + if ($result->getResultData($this->getResultPathForConstraintId($constraintId))) { |
|
252 | 252 | // already checked as part of checkPropertyIds() |
253 | 253 | continue; |
254 | 254 | } |
255 | 255 | $constraintParameterExceptions = $this->delegatingConstraintChecker |
256 | - ->checkConstraintParametersOnConstraintId( $constraintId ); |
|
257 | - $this->addConstraintParameterExceptionsToResult( $constraintId, $constraintParameterExceptions, $result ); |
|
256 | + ->checkConstraintParametersOnConstraintId($constraintId); |
|
257 | + $this->addConstraintParameterExceptionsToResult($constraintId, $constraintParameterExceptions, $result); |
|
258 | 258 | } |
259 | 259 | } |
260 | 260 | |
@@ -262,18 +262,18 @@ discard block |
||
262 | 262 | * @param PropertyId $propertyId |
263 | 263 | * @return string[] |
264 | 264 | */ |
265 | - private function getResultPathForPropertyId( PropertyId $propertyId ) { |
|
266 | - return [ $this->getModuleName(), $propertyId->getSerialization() ]; |
|
265 | + private function getResultPathForPropertyId(PropertyId $propertyId) { |
|
266 | + return [$this->getModuleName(), $propertyId->getSerialization()]; |
|
267 | 267 | } |
268 | 268 | |
269 | 269 | /** |
270 | 270 | * @param string $constraintId |
271 | 271 | * @return string[] |
272 | 272 | */ |
273 | - private function getResultPathForConstraintId( $constraintId ) { |
|
274 | - $propertyId = $this->statementGuidParser->parse( $constraintId )->getEntityId(); |
|
273 | + private function getResultPathForConstraintId($constraintId) { |
|
274 | + $propertyId = $this->statementGuidParser->parse($constraintId)->getEntityId(); |
|
275 | 275 | '@phan-var PropertyId $propertyId'; |
276 | - return array_merge( $this->getResultPathForPropertyId( $propertyId ), [ $constraintId ] ); |
|
276 | + return array_merge($this->getResultPathForPropertyId($propertyId), [$constraintId]); |
|
277 | 277 | } |
278 | 278 | |
279 | 279 | /** |
@@ -288,8 +288,8 @@ discard block |
||
288 | 288 | $constraintParameterExceptions, |
289 | 289 | ApiResult $result |
290 | 290 | ) { |
291 | - $path = $this->getResultPathForConstraintId( $constraintId ); |
|
292 | - if ( $constraintParameterExceptions === null ) { |
|
291 | + $path = $this->getResultPathForConstraintId($constraintId); |
|
292 | + if ($constraintParameterExceptions === null) { |
|
293 | 293 | $result->addValue( |
294 | 294 | $path, |
295 | 295 | self::KEY_STATUS, |
@@ -299,12 +299,12 @@ discard block |
||
299 | 299 | $result->addValue( |
300 | 300 | $path, |
301 | 301 | self::KEY_STATUS, |
302 | - empty( $constraintParameterExceptions ) ? self::STATUS_OKAY : self::STATUS_NOT_OKAY |
|
302 | + empty($constraintParameterExceptions) ? self::STATUS_OKAY : self::STATUS_NOT_OKAY |
|
303 | 303 | ); |
304 | 304 | $result->addValue( |
305 | 305 | $path, |
306 | 306 | self::KEY_PROBLEMS, |
307 | - array_map( [ $this, 'formatConstraintParameterException' ], $constraintParameterExceptions ) |
|
307 | + array_map([$this, 'formatConstraintParameterException'], $constraintParameterExceptions) |
|
308 | 308 | ); |
309 | 309 | } |
310 | 310 | } |
@@ -315,7 +315,7 @@ discard block |
||
315 | 315 | * @param ConstraintParameterException $e |
316 | 316 | * @return string[] |
317 | 317 | */ |
318 | - private function formatConstraintParameterException( ConstraintParameterException $e ) { |
|
318 | + private function formatConstraintParameterException(ConstraintParameterException $e) { |
|
319 | 319 | return [ |
320 | 320 | self::KEY_MESSAGE_HTML => $this->violationMessageRenderer->render( |
321 | 321 | $e->getViolationMessage() |
@@ -348,8 +348,8 @@ discard block |
||
348 | 348 | return [ |
349 | 349 | 'action=wbcheckconstraintparameters&propertyid=P247' |
350 | 350 | => 'apihelp-wbcheckconstraintparameters-example-propertyid-1', |
351 | - 'action=wbcheckconstraintparameters&' . |
|
352 | - 'constraintid=P247$0fe1711e-4c0f-82ce-3af0-830b721d0fba|' . |
|
351 | + 'action=wbcheckconstraintparameters&'. |
|
352 | + 'constraintid=P247$0fe1711e-4c0f-82ce-3af0-830b721d0fba|'. |
|
353 | 353 | 'P225$cdc71e4a-47a0-12c5-dfb3-3f6fc0b6613f' |
354 | 354 | => 'apihelp-wbcheckconstraintparameters-example-constraintid-2', |
355 | 355 | ]; |
@@ -84,9 +84,9 @@ discard block |
||
84 | 84 | * @throws ConstraintParameterException |
85 | 85 | * @return CheckResult |
86 | 86 | */ |
87 | - public function checkConstraint( Context $context, Constraint $constraint ) { |
|
88 | - if ( $context->getSnakRank() === Statement::RANK_DEPRECATED ) { |
|
89 | - return new CheckResult( $context, $constraint, [], CheckResult::STATUS_DEPRECATED ); |
|
87 | + public function checkConstraint(Context $context, Constraint $constraint) { |
|
88 | + if ($context->getSnakRank() === Statement::RANK_DEPRECATED) { |
|
89 | + return new CheckResult($context, $constraint, [], CheckResult::STATUS_DEPRECATED); |
|
90 | 90 | } |
91 | 91 | |
92 | 92 | $parameters = []; |
@@ -94,28 +94,28 @@ discard block |
||
94 | 94 | |
95 | 95 | $snak = $context->getSnak(); |
96 | 96 | |
97 | - if ( !$snak instanceof PropertyValueSnak ) { |
|
97 | + if (!$snak instanceof PropertyValueSnak) { |
|
98 | 98 | // nothing to check |
99 | - return new CheckResult( $context, $constraint, $parameters, CheckResult::STATUS_COMPLIANCE ); |
|
99 | + return new CheckResult($context, $constraint, $parameters, CheckResult::STATUS_COMPLIANCE); |
|
100 | 100 | } |
101 | 101 | |
102 | 102 | $dataValue = $snak->getDataValue(); |
103 | 103 | |
104 | - list( $min, $max ) = $this->parseRangeParameter( |
|
104 | + list($min, $max) = $this->parseRangeParameter( |
|
105 | 105 | $constraintParameters, |
106 | 106 | $constraint->getConstraintTypeItemId(), |
107 | 107 | $dataValue->getType() |
108 | 108 | ); |
109 | 109 | $parameterKey = $dataValue->getType() === 'quantity' ? 'quantity' : 'date'; |
110 | - if ( $min !== null ) { |
|
111 | - $parameters['minimum_' . $parameterKey] = [ $min ]; |
|
110 | + if ($min !== null) { |
|
111 | + $parameters['minimum_'.$parameterKey] = [$min]; |
|
112 | 112 | } |
113 | - if ( $max !== null ) { |
|
114 | - $parameters['maximum_' . $parameterKey] = [ $max ]; |
|
113 | + if ($max !== null) { |
|
114 | + $parameters['maximum_'.$parameterKey] = [$max]; |
|
115 | 115 | } |
116 | 116 | |
117 | - if ( $this->rangeCheckerHelper->getComparison( $min, $dataValue ) > 0 || |
|
118 | - $this->rangeCheckerHelper->getComparison( $dataValue, $max ) > 0 |
|
117 | + if ($this->rangeCheckerHelper->getComparison($min, $dataValue) > 0 || |
|
118 | + $this->rangeCheckerHelper->getComparison($dataValue, $max) > 0 |
|
119 | 119 | ) { |
120 | 120 | $message = $this->getViolationMessage( |
121 | 121 | $context->getSnak()->getPropertyId(), |
@@ -131,16 +131,16 @@ discard block |
||
131 | 131 | |
132 | 132 | if ( |
133 | 133 | $dataValue instanceof TimeValue && |
134 | - ( $min instanceof NowValue || $max instanceof NowValue ) && |
|
135 | - $this->rangeCheckerHelper->isFutureTime( $dataValue ) |
|
134 | + ($min instanceof NowValue || $max instanceof NowValue) && |
|
135 | + $this->rangeCheckerHelper->isFutureTime($dataValue) |
|
136 | 136 | ) { |
137 | - $dependencyMetadata = DependencyMetadata::ofFutureTime( $dataValue ); |
|
137 | + $dependencyMetadata = DependencyMetadata::ofFutureTime($dataValue); |
|
138 | 138 | } else { |
139 | 139 | $dependencyMetadata = DependencyMetadata::blank(); |
140 | 140 | } |
141 | 141 | |
142 | - return ( new CheckResult( $context, $constraint, $parameters, $status, $message ) ) |
|
143 | - ->withMetadata( Metadata::ofDependencyMetadata( $dependencyMetadata ) ); |
|
142 | + return (new CheckResult($context, $constraint, $parameters, $status, $message)) |
|
143 | + ->withMetadata(Metadata::ofDependencyMetadata($dependencyMetadata)); |
|
144 | 144 | } |
145 | 145 | |
146 | 146 | /** |
@@ -151,8 +151,8 @@ discard block |
||
151 | 151 | * @throws ConstraintParameterException if the parameter is invalid or missing |
152 | 152 | * @return DataValue[] a pair of two data values, either of which may be null to signify an open range |
153 | 153 | */ |
154 | - private function parseRangeParameter( array $constraintParameters, $constraintTypeItemId, $type ) { |
|
155 | - switch ( $type ) { |
|
154 | + private function parseRangeParameter(array $constraintParameters, $constraintTypeItemId, $type) { |
|
155 | + switch ($type) { |
|
156 | 156 | case 'quantity': |
157 | 157 | return $this->constraintParameterParser->parseQuantityRangeParameter( |
158 | 158 | $constraintParameters, |
@@ -166,10 +166,10 @@ discard block |
||
166 | 166 | } |
167 | 167 | |
168 | 168 | throw new ConstraintParameterException( |
169 | - ( new ViolationMessage( 'wbqc-violation-message-value-needed-of-types-2' ) ) |
|
170 | - ->withEntityId( new ItemId( $constraintTypeItemId ), Role::CONSTRAINT_TYPE_ITEM ) |
|
171 | - ->withDataValueType( 'quantity' ) |
|
172 | - ->withDataValueType( 'time' ) |
|
169 | + (new ViolationMessage('wbqc-violation-message-value-needed-of-types-2')) |
|
170 | + ->withEntityId(new ItemId($constraintTypeItemId), Role::CONSTRAINT_TYPE_ITEM) |
|
171 | + ->withDataValueType('quantity') |
|
172 | + ->withDataValueType('time') |
|
173 | 173 | ); |
174 | 174 | } |
175 | 175 | |
@@ -181,7 +181,7 @@ discard block |
||
181 | 181 | * |
182 | 182 | * @return ViolationMessage |
183 | 183 | */ |
184 | - private function getViolationMessage( PropertyId $predicate, DataValue $value, $min, $max ) { |
|
184 | + private function getViolationMessage(PropertyId $predicate, DataValue $value, $min, $max) { |
|
185 | 185 | // possible message keys: |
186 | 186 | // wbqc-violation-message-range-quantity-closed |
187 | 187 | // wbqc-violation-message-range-quantity-leftopen |
@@ -194,39 +194,39 @@ discard block |
||
194 | 194 | // wbqc-violation-message-range-time-rightopen |
195 | 195 | // wbqc-violation-message-range-time-rightopen-leftnow |
196 | 196 | $messageKey = 'wbqc-violation-message-range'; |
197 | - $messageKey .= '-' . $value->getType(); |
|
197 | + $messageKey .= '-'.$value->getType(); |
|
198 | 198 | // at least one of $min, $max is set, otherwise there could be no violation |
199 | - $messageKey .= '-' . ( $min !== null ? ( $max !== null ? 'closed' : 'rightopen' ) : 'leftopen' ); |
|
200 | - if ( $min instanceof NowValue ) { |
|
199 | + $messageKey .= '-'.($min !== null ? ($max !== null ? 'closed' : 'rightopen') : 'leftopen'); |
|
200 | + if ($min instanceof NowValue) { |
|
201 | 201 | $messageKey .= '-leftnow'; |
202 | - } elseif ( $max instanceof NowValue ) { |
|
202 | + } elseif ($max instanceof NowValue) { |
|
203 | 203 | $messageKey .= '-rightnow'; |
204 | 204 | } |
205 | - $message = ( new ViolationMessage( $messageKey ) ) |
|
206 | - ->withEntityId( $predicate, Role::PREDICATE ) |
|
207 | - ->withDataValue( $value, Role::OBJECT ); |
|
208 | - if ( $min !== null && !( $min instanceof NowValue ) ) { |
|
209 | - $message = $message->withDataValue( $min, Role::OBJECT ); |
|
205 | + $message = (new ViolationMessage($messageKey)) |
|
206 | + ->withEntityId($predicate, Role::PREDICATE) |
|
207 | + ->withDataValue($value, Role::OBJECT); |
|
208 | + if ($min !== null && !($min instanceof NowValue)) { |
|
209 | + $message = $message->withDataValue($min, Role::OBJECT); |
|
210 | 210 | } |
211 | - if ( $max !== null && !( $max instanceof NowValue ) ) { |
|
212 | - $message = $message->withDataValue( $max, Role::OBJECT ); |
|
211 | + if ($max !== null && !($max instanceof NowValue)) { |
|
212 | + $message = $message->withDataValue($max, Role::OBJECT); |
|
213 | 213 | } |
214 | 214 | return $message; |
215 | 215 | } |
216 | 216 | |
217 | - public function checkConstraintParameters( Constraint $constraint ) { |
|
217 | + public function checkConstraintParameters(Constraint $constraint) { |
|
218 | 218 | $constraintParameters = $constraint->getConstraintParameters(); |
219 | 219 | $exceptions = []; |
220 | 220 | try { |
221 | 221 | // we don’t have a data value here, so get the type from the property instead |
222 | 222 | // (the distinction between data type and data value type is irrelevant for 'quantity' and 'time') |
223 | - $type = $this->propertyDataTypeLookup->getDataTypeIdForProperty( $constraint->getPropertyId() ); |
|
223 | + $type = $this->propertyDataTypeLookup->getDataTypeIdForProperty($constraint->getPropertyId()); |
|
224 | 224 | $this->parseRangeParameter( |
225 | 225 | $constraintParameters, |
226 | 226 | $constraint->getConstraintTypeItemId(), |
227 | 227 | $type |
228 | 228 | ); |
229 | - } catch ( ConstraintParameterException $e ) { |
|
229 | + } catch (ConstraintParameterException $e) { |
|
230 | 230 | $exceptions[] = $e; |
231 | 231 | } |
232 | 232 | return $exceptions; |
@@ -26,7 +26,7 @@ discard block |
||
26 | 26 | /** |
27 | 27 | * @param ConstraintLookup $lookup The lookup to which all queries are delegated. |
28 | 28 | */ |
29 | - public function __construct( ConstraintLookup $lookup ) { |
|
29 | + public function __construct(ConstraintLookup $lookup) { |
|
30 | 30 | $this->lookup = $lookup; |
31 | 31 | } |
32 | 32 | |
@@ -35,10 +35,10 @@ discard block |
||
35 | 35 | * |
36 | 36 | * @return Constraint[] |
37 | 37 | */ |
38 | - public function queryConstraintsForProperty( PropertyId $propertyId ) { |
|
38 | + public function queryConstraintsForProperty(PropertyId $propertyId) { |
|
39 | 39 | $id = $propertyId->getSerialization(); |
40 | - if ( !array_key_exists( $id, $this->cache ) ) { |
|
41 | - $this->cache[$id] = $this->lookup->queryConstraintsForProperty( $propertyId ); |
|
40 | + if (!array_key_exists($id, $this->cache)) { |
|
41 | + $this->cache[$id] = $this->lookup->queryConstraintsForProperty($propertyId); |
|
42 | 42 | } |
43 | 43 | return $this->cache[$id]; |
44 | 44 | } |
@@ -64,6 +64,7 @@ |
||
64 | 64 | * |
65 | 65 | * @param ?array $result |
66 | 66 | * @param array[] &$container |
67 | + * @return void |
|
67 | 68 | */ |
68 | 69 | public function storeCheckResultInArray( ?array $result, array &$container ); |
69 | 70 |
@@ -65,6 +65,6 @@ |
||
65 | 65 | * @param ?array $result |
66 | 66 | * @param array[] &$container |
67 | 67 | */ |
68 | - public function storeCheckResultInArray( ?array $result, array &$container ); |
|
68 | + public function storeCheckResultInArray(?array $result, array &$container); |
|
69 | 69 | |
70 | 70 | } |
@@ -35,7 +35,7 @@ discard block |
||
35 | 35 | * @codeCoverageIgnore This method is not supported. |
36 | 36 | */ |
37 | 37 | public function getType() { |
38 | - throw new LogicException( 'EntityContextCursor has no full associated context' ); |
|
38 | + throw new LogicException('EntityContextCursor has no full associated context'); |
|
39 | 39 | } |
40 | 40 | |
41 | 41 | public function getEntityId() { |
@@ -46,35 +46,35 @@ discard block |
||
46 | 46 | * @codeCoverageIgnore This method is not supported. |
47 | 47 | */ |
48 | 48 | public function getStatementPropertyId() { |
49 | - throw new LogicException( 'EntityContextCursor has no full associated context' ); |
|
49 | + throw new LogicException('EntityContextCursor has no full associated context'); |
|
50 | 50 | } |
51 | 51 | |
52 | 52 | /** |
53 | 53 | * @codeCoverageIgnore This method is not supported. |
54 | 54 | */ |
55 | 55 | public function getStatementGuid() { |
56 | - throw new LogicException( 'EntityContextCursor has no full associated context' ); |
|
56 | + throw new LogicException('EntityContextCursor has no full associated context'); |
|
57 | 57 | } |
58 | 58 | |
59 | 59 | /** |
60 | 60 | * @codeCoverageIgnore This method is not supported. |
61 | 61 | */ |
62 | 62 | public function getSnakPropertyId() { |
63 | - throw new LogicException( 'EntityContextCursor has no full associated context' ); |
|
63 | + throw new LogicException('EntityContextCursor has no full associated context'); |
|
64 | 64 | } |
65 | 65 | |
66 | 66 | /** |
67 | 67 | * @codeCoverageIgnore This method is not supported. |
68 | 68 | */ |
69 | 69 | public function getSnakHash() { |
70 | - throw new LogicException( 'EntityContextCursor has no full associated context' ); |
|
70 | + throw new LogicException('EntityContextCursor has no full associated context'); |
|
71 | 71 | } |
72 | 72 | |
73 | 73 | /** |
74 | 74 | * @codeCoverageIgnore This method is not supported. |
75 | 75 | */ |
76 | - public function &getMainArray( array &$container ) { |
|
77 | - throw new LogicException( 'EntityContextCursor cannot store check results' ); |
|
76 | + public function &getMainArray(array &$container) { |
|
77 | + throw new LogicException('EntityContextCursor cannot store check results'); |
|
78 | 78 | } |
79 | 79 | |
80 | 80 | /** |
@@ -83,14 +83,14 @@ discard block |
||
83 | 83 | * @param ?array $result must be null |
84 | 84 | * @param array[] &$container |
85 | 85 | */ |
86 | - public function storeCheckResultInArray( ?array $result, array &$container ) { |
|
87 | - if ( $result !== null ) { |
|
88 | - throw new LogicException( 'EntityContextCursor cannot store check results' ); |
|
86 | + public function storeCheckResultInArray(?array $result, array &$container) { |
|
87 | + if ($result !== null) { |
|
88 | + throw new LogicException('EntityContextCursor cannot store check results'); |
|
89 | 89 | } |
90 | 90 | |
91 | 91 | // this ensures that the claims array is present in the $container, |
92 | 92 | // populating it if necessary, even though we ignore the return value |
93 | - $this->getClaimsArray( $container ); |
|
93 | + $this->getClaimsArray($container); |
|
94 | 94 | } |
95 | 95 | |
96 | 96 | } |