This plugin adds Upload support to the WPGraphQL plugin as specified by graphql-multipart-request-spec.
- PHP >= 7.1
- WordPress >= 5.0
- WPGraphQL >= 1.0.0
You can install and activate the plugin like any WordPress plugin. Download the .zip from Github and add to your plugins directory, then activate.
Once the plugin is active, the Upload
scalar type will be available to your mutation input fields.
If you're using composer:
composer require dre1080/wp-graphql-upload
Then you can start using in your mutations like so:
register_graphql_mutation(
'upload', [
'inputFields' => [
'file' => [
'type' => ['non_null' => 'Upload'],
],
],
'outputFields' => [
'text' => [
'type' => 'String',
'resolve' => function ($payload) {
return $payload['text'];
},
],
],
'mutateAndGetPayload' => function ($input) {
if (!function_exists('wp_handle_sideload')) {
require_once(ABSPATH . 'wp-admin/includes/file.php');
}
wp_handle_sideload($input['file'], [
'test_form' => false,
'test_type' => false,
]);
return [
'text' => 'Uploaded file was "' . $input['file']['name'] . '" (' . $input['file']['type'] . ').',
];
}
]
);
Requirements:
To run the tests, run the following commands:
bin/install-wp-tests.sh
vendor/bin/phpunit