SchemaBuilder
class SchemaBuilder (View source)
Traits
A class that can be instantiated or replaced via DI
Methods
An implementation of the factory method, allows you to create an instance of a class
Creates a class instance by the "singleton" design pattern.
Retrieves the context for an already stored schema which does not require booting. Useful for getting data from a saved schema at request time.
Gets a graphql-php Schema instance that can be queried
Boots a schema, persists it, and fetches it
Auto-discovers the schema based on the provided schema key in Silverstripe's configuration layer. Merges the global schema with specifics for this schema key.
No description
Details
static Injectable
create(array ...$args)
An implementation of the factory method, allows you to create an instance of a class
This method will defer class substitution to the Injector API, which can be customised via the Config API to declare substitution classes.
This can be called in one of two ways - either calling via the class directly, or calling on Object and passing the class name as the first parameter. The following are equivalent: $list = DataList::create('SiteTree'); $list = SiteTree::get();
static Injectable
singleton(string $class = null)
Creates a class instance by the "singleton" design pattern.
It will always return the same instance for this class, which can be used for performance reasons and as a simple way to access instance methods which don't rely on instance data (e.g. the custom SilverStripe static handling).
__construct(SchemaStorageCreator $storeCreator)
SchemaConfig|null
getConfig(string $key)
Retrieves the context for an already stored schema which does not require booting. Useful for getting data from a saved schema at request time.
Returns null when no stored schema can be found.
Schema|null
getSchema(string $key)
Gets a graphql-php Schema instance that can be queried
Schema
build(Schema $schema, bool $clear = false)
Stores a schema and fetches the graphql-php instance
Schema
buildByName(string $key, bool $clear = false)
Boots a schema, persists it, and fetches it
Schema
boot(string $key)
Auto-discovers the schema based on the provided schema key in Silverstripe's configuration layer. Merges the global schema with specifics for this schema key.
An instance can only be booted once to avoid conflicts with further instance level modifications such as {@link addType()}.
This method should only be used on schemas which have not been stored, and is usually only needed for the process of storing them (through {@link SchemaBuilder->build()}).