Skip to content
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.

Commit 6b8e95e

Browse files
committedJul 3, 2024
Fix SRID and options not being optional for expression in GeometryCast
1 parent a6bae05 commit 6b8e95e

File tree

1 file changed

+7
-15
lines changed

1 file changed

+7
-15
lines changed
 

‎src/GeometryCast.php

+7-15
Original file line numberDiff line numberDiff line change
@@ -36,8 +36,7 @@ public function get($model, string $key, $value, array $attributes): ?Geometry
3636
}
3737

3838
if ($value instanceof ExpressionContract) {
39-
$wkt = $this->extractWktFromExpression($value, $model->getConnection());
40-
$srid = $this->extractSridFromExpression($value, $model->getConnection());
39+
[$wkt, $srid, ...] = $this->extractFromExpression($value, $model->getConnection());
4140

4241
return $this->className::fromWkt($wkt, $srid);
4342
}
@@ -76,23 +75,16 @@ public function set($model, string $key, $value, array $attributes): ?Expression
7675
return $value->toSqlExpression($model->getConnection());
7776
}
7877

79-
private function extractWktFromExpression(ExpressionContract $expression, Connection $connection): string
80-
{
81-
$grammar = $connection->getQueryGrammar();
82-
$expressionValue = $expression->getValue($grammar);
83-
84-
preg_match('/ST_GeomFromText\(\'(.+)\', .+(, .+)?\)/', (string) $expressionValue, $match);
85-
86-
return $match[1];
87-
}
88-
89-
private function extractSridFromExpression(ExpressionContract $expression, Connection $connection): int
78+
/**
79+
* @return array{string, int, string}
80+
*/
81+
private function extractFromExpression(ExpressionContract $expression, Connection $connection): array
9082
{
9183
$grammar = $connection->getQueryGrammar();
9284
$expressionValue = $expression->getValue($grammar);
9385

94-
preg_match('/ST_GeomFromText\(\'.+\', (.+)(, .+)?\)/', (string) $expressionValue, $match);
86+
preg_match("/ST_GeomFromText\(\s*'([^']+)'\s*(?:,\s*(\d+))?\s*(?:,\s*'([^']+)')?\s*\)/", (string) $expressionValue, $matches);
9587

96-
return (int) $match[1];
88+
return [$matches[1], (int) ($matches[2] ?? 0), $matches[3] ?? ''];
9789
}
9890
}

0 commit comments

Comments
 (0)
Please sign in to comment.