chrisbryan17's picture
Upload folder using huggingface_hub
d2897cd verified
<?php
namespace Mautic\UserBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
use Mautic\CoreBundle\Doctrine\Mapping\ClassMetadataBuilder;
class UserToken
{
/**
* @var int
*/
private $id;
/**
* @var User
*/
private $user;
/**
* @var string
*/
private $authorizator;
/**
* @var string
*/
private $secret;
/**
* @var \DateTimeInterface|null
*/
private $expiration;
/**
* @var bool
*/
private $oneTimeOnly = true;
public static function loadMetadata(ORM\ClassMetadata $metadata): void
{
$builder = new ClassMetadataBuilder($metadata);
$builder->setTable('user_tokens')
->setCustomRepositoryClass(UserTokenRepository::class);
$builder->addId();
$builder->createManyToOne('user', User::class)
->addJoinColumn('user_id', 'id', false, false, 'CASCADE')
->build();
$builder->createField('authorizator', 'string')
->length(32)
->build();
$builder->createField('secret', 'string')
->length(120)
->unique()
->build();
$builder->createField('expiration', 'datetime')
->nullable()
->build();
$builder->createField('oneTimeOnly', 'boolean')
->columnName('one_time_only')
->build();
}
/**
* @return User
*/
public function getUser()
{
return $this->user;
}
/**
* @param User $user
*
* @return UserToken
*/
public function setUser($user)
{
$this->user = $user;
return $this;
}
/**
* @return string
*/
public function getAuthorizator()
{
return $this->authorizator;
}
/**
* @param string $authorizator
*
* @return UserToken
*/
public function setAuthorizator($authorizator)
{
$this->authorizator = $authorizator;
return $this;
}
/**
* @return string
*/
public function getSecret()
{
return $this->secret;
}
/**
* Use \Mautic\UserBundle\Entity\UserTokenRepositoryInterface::generateSecret to get valid secret.
*
* @param string $secret
*
* @return UserToken
*/
public function setSecret($secret)
{
$this->secret = $secret;
return $this;
}
/**
* @return \DateTimeInterface|null
*/
public function getExpiration()
{
return $this->expiration;
}
/**
* @param \DateTime|null $expiration
*
* @return UserToken
*/
public function setExpiration($expiration = null)
{
$this->expiration = $expiration;
return $this;
}
/**
* @return bool
*/
public function isOneTimeOnly()
{
return $this->oneTimeOnly;
}
/**
* @param bool $oneTimeOnly
*
* @return UserToken
*/
public function setOneTimeOnly($oneTimeOnly = true)
{
$this->oneTimeOnly = $oneTimeOnly;
return $this;
}
}