| Current Path : /var/www/clients/client3/web2/web/vendor/magento/framework/GraphQl/Config/Element/ |
| Current File : /var/www/clients/client3/web2/web/vendor/magento/framework/GraphQl/Config/Element/Type.php |
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);
namespace Magento\Framework\GraphQl\Config\Element;
/**
* Class representing 'type' GraphQL config element.
*/
class Type implements TypeInterface
{
/**
* @var string
*/
private $name;
/**
* @var Field[]
*/
private $fields;
/**
* @var string[]
*/
private $interfaces;
/**
* @var string
*/
private $description;
/**
* @param string $name
* @param Field[] $fields
* @param string[] $interfaces
* @param string $description
*/
public function __construct(
string $name,
array $fields,
array $interfaces,
string $description
) {
$this->name = $name;
$this->fields = $fields;
$this->interfaces = $interfaces;
$this->description = $description;
}
/**
* Get the type name.
*
* @return string
*/
public function getName() : string
{
return $this->name;
}
/**
* Get a list of fields that make up the possible return or input values of a type.
*
* @return Field[]
*/
public function getFields() : array
{
return $this->fields;
}
/**
* Get interfaces the type implements, if any. Return an empty array if none are configured.
*
* Example return array(
* array(
* 'interface' => 'SomeDefinedTypeInterface',
* 'copyFields' => true
* ),
* ...
* ),
*
* @return array
*/
public function getInterfaces() : array
{
return $this->interfaces;
}
/**
* Get a human-readable description of the type.
*
* @return string
*/
public function getDescription() : string
{
return $this->description;
}
}