Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Schema generation using annotated entities and mappers

License

Notifications You must be signed in to change notification settings

cycle/annotated

Repository files navigation

Cycle ORM - Annotated Entities

PHP Version Require Latest Stable Version phpunit psalm psalm-level Codecov Total Downloads

Documentation | Cycle ORM

The package provides the ability to define Cycle ORM schema using PHP attributes.

Usage

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Column;
#[Entity]
class User
{
 #[Column(type: 'primary')]
 private int $id;
 #[Column(type: 'string(32)')]
 private string $login;
 #[Column(type: 'enum(active,disabled)')]
 private string $status;
 #[Column(type: 'decimal(5,5)')]
 private $balance;
}

Relations

HasOne

use Cycle\Annotated\Annotation\Relation\HasOne;
use Cycle\Annotated\Annotation\Entity;
#[Entity]
class User
{
 // ...
 #[HasOne(target: Address::class)]
 public ?Address $address;
}

Note Read more about HasOne.

HasMany

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\HasMany;
#[Entity]
class User
{
 // ...
 #[HasMany(target: Post::class)]
 private array $posts;
}

Note Read more about HasMany.

BelongsTo

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\BelongsTo;
#[Entity]
class Post
{
 // ...
 #[BelongsTo(target: User::class)]
 private User $user;
}

Note Read more about BelongsTo.

RefersTo

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\RefersTo;
use Cycle\Annotated\Annotation\Relation\HasMany;
#[Entity]
class User
{
 // ...
 #[RefersTo(target: Comment::class)]
 private ?Comment $lastComment;
 #[HasMany(target: Comment::class)]
 public array $comments;
 // ...
 public function addComment(Comment $c): void
 {
 $this->lastComment = $c;
 $this->comments[] = $c;
 }
 
 public function removeLastComment(): void
 {
 $this->lastComment = null;
 }
 
 public function getLastComment(): ?Comment
 {
 return $this->lastComment;
 }
}

Note Read more about RefersTo.

ManyToMany

use Cycle\Annotated\Annotation\Relation\ManyToMany;
use Cycle\Annotated\Annotation\Entity;
#[Entity]
class User
{
 // ...
 #[ManyToMany(target: Tag::class, through: UserTag::class)]
 protected array $tags;
 
 public function getTags(): array
 {
 return $this->tags;
 }
 
 public function addTag(Tag $tag): void
 {
 $this->tags[] = $tag;
 }
 
 public function removeTag(Tag $tag): void
 {
 $this->tags = array_filter($this->tags, static fn(Tag $t) => $t !== $tag);
 }
}

Note Read more about ManyToMany.

Embedded Entities

use Cycle\Annotated\Annotation\Embeddable;
use Cycle\Annotated\Annotation\Column;
use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\Embedded;
#[Embeddable]
class UserCredentials
{
 #[Column(type: 'string(255)')]
 public string $username;
 #[Column(type: 'string')]
 public string $password;
}
#[Entity]
class User
{
 #[Column(type: 'primary')]
 public int $id;
 #[Embedded(target: 'UserCredentials')]
 public UserCredentials $credentials;
 public function __construct()
 {
 $this->credentials = new UserCredentials();
 }
}

Note Read more about Embedded Entities.

BelongsToMorphed

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\Morphed\BelongsToMorphed;
#[Entity]
class Image
{
 // ...
 #[BelongsToMorphed(taget: ImageHolderInterface::class)]
 public ImageHolderInterface $imageHolder;
}

Note Read more about BelongsToMorphed.

MorphedHasOne

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\Morphed\MorphedHasOne;
#[Entity]
class User
{
 // ...
 #[MorphedHasOne(target: Image::class)]
 public $image;
}

Note Read more about MorphedHasOne.

MorphedHasMany

use Cycle\Annotated\Annotation\Entity;
use Cycle\Annotated\Annotation\Relation\Morphed\MorphedHasMany;
#[Entity]
class User
{
 // ...
 #[MorphedHasMany(target: Image::class)]
 public $images;
}

Note Read more about MorphedHasMany.

Single Table Inheritance

#[Entity]
#[DiscriminatorColumn(name: 'type')] // Discriminator column (required)
class Person
{
 #[Column(type: 'primary', primary: true)]
 protected int $id;
 #[Column(type: 'string')]
 protected string $name;
}
#[Entity]
#[InheritanceSingleTable]
class Employee extends Person
{
 #[Column(type: 'int')]
 protected int $salary;
}
#[Entity]
#[InheritanceSingleTable(value: 'foo_customer')]
class Customer extends Person
{
 #[Column(type: 'json')]
 protected array $preferences;
}

Note Read more about Single Table Inheritance.

Joined Table Inheritance

#[Entity]
class Person
{
 #[Column(primary: true)]
 protected int $id;
 
 #[Column()]
 protected int $fooId;
 #[Column(type: 'string')]
 protected string $name;
}
#[Entity]
#[InheritanceJoinedTable(outerKey: 'fooId')]
class Employee extends Person
{
 #[Column(type: 'int')]
 protected int $salary;
}
#[Entity]
#[InheritanceJoinedTable(outerKey: 'id')]
class Customer extends Person
{
 #[Column(type: 'json')]
 protected array $preferences;
}

Note Read more about Joined Table Inheritance.

License

The MIT License (MIT). Please see LICENSE for more information. Maintained by Spiral Scout.

About

Schema generation using annotated entities and mappers

Topics

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Sponsor this project

Packages

No packages published

Contributors 16

AltStyle によって変換されたページ (->オリジナル) /