mirror of
https://github.com/maelgangloff/domain-watchdog.git
synced 2025-12-29 16:15:04 +00:00
feat: add instance config endpoint
This commit is contained in:
@@ -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
48
src/Entity/Instance.php
Normal 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;
|
||||
}
|
||||
}
|
||||
@@ -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>
|
||||
|
||||
Reference in New Issue
Block a user