Skip to content

Commit

Permalink
feat: Make boolean quirk an enum
Browse files Browse the repository at this point in the history
Signed-off-by: jld3103 <[email protected]>
  • Loading branch information
provokateurin committed Dec 12, 2023
1 parent f4bda54 commit 9efa1ef
Showing 1 changed file with 17 additions and 5 deletions.
22 changes: 17 additions & 5 deletions src/OpenApiType.php
Original file line number Diff line number Diff line change
Expand Up @@ -68,13 +68,25 @@ public function toArray(string $openapiVersion, bool $isParameter = false): arra
] : [],
);
}

$type = $this->type;
$defaultValue = $this->defaultValue;
$enum = $this->enum;
if ($isParameter && $type == "boolean") {
$type = "integer";
$enum = [0, 1];
if ($this->hasDefaultValue) {
$defaultValue = $defaultValue === true ? 1 : 0;
}
}

$values = array_merge(
$this->ref != null ? ["\$ref" => $this->ref] : [],
$this->type != null ? ["type" => $isParameter && $this->type == "boolean" ? "integer" : $this->type] : [],
$type != null ? ["type" => $type] : [],
$this->format != null ? ["format" => $this->format] : [],
$this->nullable ? ["nullable" => true] : [],
$this->hasDefaultValue && $this->defaultValue !== null ? ["default" => $isParameter && $this->type == "boolean" ? $this->defaultValue === true ? 1 : 0 : $this->defaultValue] : [],
$this->enum != null && count($this->enum) > 0 ? ["enum" => $this->enum] : [],
$this->hasDefaultValue && $this->defaultValue !== null ? ["default" => $defaultValue] : [],
$enum != null && count($enum) > 0 ? ["enum" => $enum] : [],
$this->description != null && $this->description != "" && !$isParameter ? ["description" => $this->description] : [],
$this->items != null ? ["items" => $this->items->toArray($openapiVersion)] : [],
$this->minLength !== null ? ["minLength" => $this->minLength] : [],
Expand Down Expand Up @@ -185,7 +197,7 @@ static function resolve(string $context, array $definitions, ParamTagValueNode|N
$values = [];
/** @var ConstTypeNode $type */
foreach ($node->types as $type) {
$values[] = (int) $type->constExpr->value;
$values[] = (int)$type->constExpr->value;
}

if (count(array_filter($values, fn(string $value) => $value == '')) > 0) {
Expand Down Expand Up @@ -247,7 +259,7 @@ enum: [$node->constExpr->value],
return new OpenApiType(
type: "integer",
format: "int64",
enum: [(int) $node->constExpr->value],
enum: [(int)$node->constExpr->value],
);
}

Expand Down

0 comments on commit 9efa1ef

Please sign in to comment.