feat: add instance config endpoint

This commit is contained in:
Maël Gangloff
2024-08-04 15:49:38 +02:00
parent e413bfedc0
commit 7cf2375952
13 changed files with 115 additions and 23 deletions

View File

@@ -24,11 +24,13 @@ use Symfony\Component\Uid\Uuid;
name: 'get_all_mine',
),
new Get(
normalizationContext: ['groups' => 'connector:list']
normalizationContext: ['groups' => 'connector:list'],
security: 'object.user == user'
),
new Post(
routeName: 'connector_create', normalizationContext: ['groups' => ['connector:create', 'connector:list']],
denormalizationContext: ['groups' => 'connector:create'],
routeName: 'connector_create',
normalizationContext: ['groups' => ['connector:create', 'connector:list']], denormalizationContext: ['groups' => 'connector:create'],
security: 'object.user == user',
name: 'create'
),
new Delete(),
@@ -44,7 +46,7 @@ class Connector
#[ORM\ManyToOne(inversedBy: 'connectors')]
#[ORM\JoinColumn(nullable: false)]
private ?User $user = null;
public ?User $user = null;
#[Groups(['connector:list', 'connector:create', 'watchlist:list'])]
#[ORM\Column(enumType: ConnectorProvider::class)]

48
src/Entity/Instance.php Normal file
View File

@@ -0,0 +1,48 @@
<?php
namespace App\Entity;
use ApiPlatform\Metadata\ApiResource;
use ApiPlatform\Metadata\Get;
use App\Controller\InstanceController;
#[ApiResource(
operations: [
new Get(
uriTemplate: '/config',
controller: InstanceController::class,
shortName: 'Configuration',
read: false,
),
]
)]
class Instance
{
private ?bool $oauthEnabled = null;
private ?bool $limitedFeatures = null;
public function isSsoLogin(): ?bool
{
return $this->oauthEnabled;
}
public function setOauthEnabled(bool $oauthEnabled): static
{
$this->oauthEnabled = $oauthEnabled;
return $this;
}
public function isLimitedFeatures(): ?bool
{
return $this->limitedFeatures;
}
public function setLimitedFeatures(bool $limitedFeatures): static
{
$this->limitedFeatures = $limitedFeatures;
return $this;
}
}

View File

@@ -27,7 +27,8 @@ use Symfony\Component\Uid\Uuid;
name: 'get_all_mine',
),
new Get(
normalizationContext: ['groups' => 'watchlist:item']
normalizationContext: ['groups' => 'watchlist:item'],
security: 'object.user == user'
),
new Get(
routeName: 'watchlist_calendar',
@@ -73,7 +74,7 @@ class WatchList
#[ORM\ManyToOne(targetEntity: User::class, inversedBy: 'watchLists')]
#[ORM\JoinColumn(nullable: false)]
private ?User $user = null;
public ?User $user = null;
/**
* @var Collection<int, Domain>