Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tim-field/graphql-wp
GraphQL endpoint for WordPress
https://github.com/tim-field/graphql-wp
graphql graphql-endpoint graphql-wp headless-cms wordpress
Last synced: 3 months ago
JSON representation
GraphQL endpoint for WordPress
- Host: GitHub
- URL: https://github.com/tim-field/graphql-wp
- Owner: tim-field
- License: gpl-3.0
- Created: 2016-01-21T22:40:10.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2021-05-17T02:15:44.000Z (over 3 years ago)
- Last Synced: 2024-08-25T21:50:55.295Z (5 months ago)
- Topics: graphql, graphql-endpoint, graphql-wp, headless-cms, wordpress
- Language: PHP
- Size: 462 KB
- Stars: 303
- Watchers: 15
- Forks: 23
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-graphql - graphql-wp - WordPress plugin that exposes a GraphQL endpoint. (Libraries / PHP Libraries)
- awesome-graphql - graphql-wp - WordPress plugin that exposes a GraphQL endpoint. (Libraries / PHP Libraries)
README
# graphql-wp
A GraphQL endpoint for WordPress that's easy to customize.
This is a WordPress Plugin that exposes a GraphQL endpoint at **/graphql**.
Uses this excellent [graphql-php](https://github.com/webonyx/graphql-php) library.
Supports Relay Connections.
## Install
`composer require mohiohio/graphql-wp`
If your aren't familiar with using composer with WordPress I'd recommend using a setup like [bedrock](https://roots.io/bedrock/). Otherwise you will at the least need to [require autoload.php](https://getcomposer.org/doc/01-basic-usage.md#autoloading) for this to work.
## Using
The best way to explore / develop with this is by visiting `/graphiql` after installation. This will show you the endpoints and arguments that are available. Note this will only work if you are a logged in admin user.
![https://github.com/tim-field/graphql-wp/raw/master/.readme.md/graphiql.png](https://github.com/tim-field/graphql-wp/raw/master/.readme.md/graphiql.png)
### wp_query
This is designed to follow WordPress' existing WP Query functions. So as a rule you can pass the same parameters as your can to [WP Query](https://codex.wordpress.org/Class_Reference/WP_Query)\*.
\*_In reality there are a lot of params you can pass to WP_Query, and I've only implemented the ones that I've needed so far. But adding more is trivial as the arguments are just passed directly to the get_posts function, so its just a matter of defining them in the schema._
```graphql
query example {
wp_query {
posts(first: 10) {
edges {
node {
title
name
terms(taxonomy: "category") {
name
slug
}
}
}
}
}
}
```Will give you
```json
{
"data": {
"wp_query": {
"posts": {
"edges": [
{
"node": {
"title": "Dashboard",
"name": "hello-world",
"terms": [
{
"name": "Uncategorized",
"slug": "uncategorized"
}
]
}
}
]
}
}
}
}
```### Post
And of course you can get an individual post
```graphql
query example {
wp_post(ID: 9) {
title
content
status
}
}
```### Custom Fields
Any meta fields are available like so
```graphql
query example {
wp_post(ID: 9) {
title
foo: meta_value(key: "foo")
bar: meta_value(key: "bar")
}
}
```If you want to define your own resolver / type you can extend the field schema for a post type like so.
```php
// There is a get_{post_type}_schema call available for each post type
add_filter('graphql-wp/get_post_schema', function($schema) {$schema['fields'] = function() use ($schema) {
// Note call to "parent" function here
return $schema['fields']() + [
'foo' => [
'type' => Type::string(),
'resolve' => function($post) {
return get_post_meta($post->ID, 'foo' ,true);
}
],
'bar' => [
'type' => Type::string(),
'resolve' => function($post) {
return get_post_meta($post->ID, 'bar' ,true);
}
]
];
};
return $schema;
});
```### Custom Post Types
This is how you can add custom post types ( which have custom fields ) to a client specific plugin.
graphql-wp/get_post_types is a good hook for this.
Where `$types` is a hash of the schema we are working with, so just add new items into this and you are good to go.```php
use GraphQL\Type\Definition\Type;
use Mohiohio\GraphQLWP\Type\Definition\Post;
use Mohiohio\GraphQLWP\Type\Definition\Attachment;class Foo extends Post {
static function getDescription() {
return "A custom post type example, for post type `foo`";
}static function getFieldSchema() {
return parent::getFieldSchema() + [
'website' => [
'type' => Type::string(),
'resolve' => function($post) {
return get_post_meta($post->ID,'website',true);
},
],
'image' => [
'type' => Attachment::getInstance(),
'resolve' => function($post) {
$attachment_id = get_post_meta($post->ID,'image',true);
return $attachment_id ? get_post($attachment_id) : null;
},
]
];
}
}add_filter('graphql-wp/schema-types', function($types){
return array_merge($types, [
Foo::getInstance()
]);
});
```### In the wild
http://www.page1management.com/
https://www.wokexpress.co.nz/menu