{"id":169,"date":"2022-07-02T15:35:20","date_gmt":"2022-07-02T10:05:20","guid":{"rendered":"https:\/\/magecurious.com\/blog\/?p=169"},"modified":"2022-07-09T13:53:05","modified_gmt":"2022-07-09T08:23:05","slug":"magento-2-how-to-create-custom-graphql","status":"publish","type":"post","link":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/","title":{"rendered":"Magento 2 How to Create Custom Graphql"},"content":{"rendered":"\n<p>Hello Guys! \ud83d\udc4b&nbsp;<\/p>\n\n\n\n<p class=\"has-text-align-left\">In this blog, we learn how to create custom Graphql in Magento 2 and also when to use type query, and when to use type mutation.<\/p>\n\n\n\n<p>Graphql is a query language that is developed by Facebook in 2012 but it was publicly released in 2015.<\/p>\n\n\n\n<p>Type query is used to get data or retrieve data from the Magento server<\/p>\n\n\n\n<p> While mutations is used for changes in data. Mutations can create, update and delete the data.<\/p>\n\n\n\n<p>The following example is for creating graphql with query and mutations.<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>Step1 : Create schema.graphqls in following file path.<\/code><\/pre>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>       app\\code\\Vendor\\Extension\\etc<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: xml; title: ; notranslate\" title=\"\">\ntype Mutation {\n    setCustomData(input: customInput!): customOutput @resolver(class: &quot;\\\\Vendor\\\\Extension\\\\Model\\\\Resolver\\\\CreateCustomData&quot;)\n}\ntype Query {\n    getCustomData(id: Int!): customOutput @resolver(class: &quot;\\\\Vendor\\\\Extension\\\\Model\\\\Resolver\\\\GetCustomData&quot;)\n}\ninput customInput {\n    name: String\n}\ntype customOutput {\n    id: Int\n    name: String\n}\n<\/pre><\/div>\n\n\n<pre class=\"wp-block-code\"><code>Step 2: Add CreateCustomData.php in following file path\n<\/code><\/pre>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>     app\\code\\Vendor\\Extension\\Model\\Resolver<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?php\n\ndeclare(strict_types=1);\n\nnamespace Vendor\\Extension\\Model\\Resolver;\n\nuse Magento\\Framework\\GraphQl\\Config\\Element\\Field;\nuse Magento\\Framework\\GraphQl\\Query\\ResolverInterface;\nuse Magento\\Framework\\GraphQl\\Schema\\Type\\ResolveInfo;\n\nclass CreateCustomData implements ResolverInterface\n{\n    protected $customFactory;\n\n    public function __construct(\n        \\Vendor\\Extension\\Model\\CustomFactory $customFactory\n    )\n    {\n        $this-&gt;customFactory = $customFactory;\n    }\n\n    \/**\n     * @inheritdoc\n     *\/\n    public function resolve(\n        Field $field,\n              $context,\n        ResolveInfo $info,\n        array $value = null,\n        array $args = null\n    ) {\n        $model = $this-&gt;customFactory-&gt;create();\n       \n        if(isset($args&#x5B;&#039;input&#039;])) {\n            $model-&gt;setData($args&#x5B;&#039;input&#039;]);\n            $model-&gt;save();\n        }\n\n        return $model-&gt;getData();\n    }\n}\n\n<\/pre><\/div>\n\n\n<pre class=\"wp-block-code\"><code>Step 3: Now create GetCustomData.php file in following file path\n<\/code><\/pre>\n\n\n\n<div style=\"height:30px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>      app\\code\\Vendor\\Extension\\Model\\Resolver<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: php; title: ; notranslate\" title=\"\">\n&lt;?php\n\ndeclare(strict_types=1);\n\nnamespace Vendor\\Extension\\Model\\Resolver;\n\nuse Magento\\Framework\\GraphQl\\Config\\Element\\Field;\nuse Magento\\Framework\\GraphQl\\Query\\ResolverInterface;\nuse Magento\\Framework\\GraphQl\\Schema\\Type\\ResolveInfo;\n\nclass GetCustomData implements ResolverInterface\n{\n    protected $customFactory;\n\n    public function __construct(\n        \\Vendor\\Extension\\Model\\CustomFactory $customFactory\n    )\n    {\n        $this-&gt;customFactory = $customFactory;\n    }\n\n    \/**\n     * @inheritdoc\n     *\/\n    public function resolve(\n        Field $field,\n              $context,\n        ResolveInfo $info,\n        array $value = null,\n        array $args = null\n    ) {\n        $model = $this-&gt;customFactory-&gt;create();\n        $collection = $model-&gt;getCollection();\n        \n        $data = &#x5B;];\n        foreach($collection as $item){\n            $data&#x5B;] = &#x5B;\n                &#039;id&#039; =&gt; $item-&gt;getId(),\n                &#039;name&#039; =&gt; $item-&gt;getName()\n            ];\n        }\n        \n        return $data;\n        \n    }\n}\n\n<\/pre><\/div>\n\n\n<div style=\"height:15px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<p>Hope! It will help you<\/p>\n\n\n\n<p>Thank you \ud83d\ude0a<\/p>\n\n\n\n<div style=\"height:20px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n<!-- FeedbackWP Plugin --><div  class=\"rmp-widgets-container rmp-wp-plugin rmp-main-container js-rmp-widgets-container js-rmp-widgets-container--169 \"  data-post-id=\"169\">    <!-- Rating widget -->  <div class=\"rmp-rating-widget js-rmp-rating-widget\">          <p class=\"rmp-heading rmp-heading--title\">        How useful was this post?      <\/p>              <p class=\"rmp-heading rmp-heading--subtitle\">        Click on a star to rate it!      <\/p>        <div class=\"rmp-rating-widget__icons\">      <ul class=\"rmp-rating-widget__icons-list js-rmp-rating-icons-list\">                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Not at all useful\" data-value=\"1\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Somewhat useful\" data-value=\"2\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Useful\" data-value=\"3\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Fairly useful\" data-value=\"4\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--full-highlight\"><\/i>          <\/li>                  <li class=\"rmp-rating-widget__icons-list__icon js-rmp-rating-item\" data-descriptive-rating=\"Very useful\" data-value=\"5\">              <i class=\"js-rmp-rating-icon rmp-icon rmp-icon--ratings rmp-icon--star rmp-icon--half-highlight js-rmp-replace-half-star\"><\/i>          <\/li>              <\/ul>    <\/div>    <p class=\"rmp-rating-widget__hover-text js-rmp-hover-text\"><\/p>        <button class=\"rmp-rating-widget__submit-btn rmp-btn js-submit-rating-btn\">      Submit Rating    <\/button>    <p class=\"rmp-rating-widget__results js-rmp-results \">      Average rating <span class=\"rmp-rating-widget__results__rating js-rmp-avg-rating\">4.6<\/span> \/ 5. Vote count: <span class=\"rmp-rating-widget__results__votes js-rmp-vote-count\">11<\/span>    <\/p>    <p class=\"rmp-rating-widget__not-rated js-rmp-not-rated rmp-rating-widget__not-rated--hidden\">      No votes so far! Be the first to rate this post.    <\/p>    <p class=\"rmp-rating-widget__msg js-rmp-msg\"><\/p>  <\/div>  <!--Structured data -->        <\/div>\n\n\n\n<p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Hello Guys! \ud83d\udc4b&nbsp; In this blog, we learn how to create custom Graphql in Magento 2 and also when to use type query, and when to use type mutation. Graphql is a query language that is developed by Facebook in 2012 but it was publicly released in 2015. Type query is used to get data [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":176,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[4],"tags":[32,31,17],"class_list":["post-169","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-magento-2","tag-custom-graphql","tag-graphql","tag-magento-2-2"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v26.8 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Magento 2 How to Create Custom Graphql - Magecurious<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Magento 2 How to Create Custom Graphql - Magecurious\" \/>\n<meta property=\"og:description\" content=\"Hello Guys! \ud83d\udc4b&nbsp; In this blog, we learn how to create custom Graphql in Magento 2 and also when to use type query, and when to use type mutation. Graphql is a query language that is developed by Facebook in 2012 but it was publicly released in 2015. Type query is used to get data [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/\" \/>\n<meta property=\"og:site_name\" content=\"Magecurious\" \/>\n<meta property=\"article:published_time\" content=\"2022-07-02T10:05:20+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-07-09T08:23:05+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1260\" \/>\n\t<meta property=\"og:image:height\" content=\"496\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Magecurious\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Magecurious\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Magento 2 How to Create Custom Graphql - Magecurious","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/","og_locale":"en_US","og_type":"article","og_title":"Magento 2 How to Create Custom Graphql - Magecurious","og_description":"Hello Guys! \ud83d\udc4b&nbsp; In this blog, we learn how to create custom Graphql in Magento 2 and also when to use type query, and when to use type mutation. Graphql is a query language that is developed by Facebook in 2012 but it was publicly released in 2015. Type query is used to get data [&hellip;]","og_url":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/","og_site_name":"Magecurious","article_published_time":"2022-07-02T10:05:20+00:00","article_modified_time":"2022-07-09T08:23:05+00:00","og_image":[{"width":1260,"height":496,"url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png","type":"image\/png"}],"author":"Magecurious","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Magecurious","Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#article","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/"},"author":{"name":"Magecurious","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2"},"headline":"Magento 2 How to Create Custom Graphql","datePublished":"2022-07-02T10:05:20+00:00","dateModified":"2022-07-09T08:23:05+00:00","mainEntityOfPage":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/"},"wordCount":117,"commentCount":0,"publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"image":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png","keywords":["Custom Graphql","Graphql","Magento 2"],"articleSection":["Magento 2 Blog"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/","url":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/","name":"Magento 2 How to Create Custom Graphql - Magecurious","isPartOf":{"@id":"https:\/\/magecurious.com\/blog\/#website"},"primaryImageOfPage":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#primaryimage"},"image":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#primaryimage"},"thumbnailUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png","datePublished":"2022-07-02T10:05:20+00:00","dateModified":"2022-07-09T08:23:05+00:00","breadcrumb":{"@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#primaryimage","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png","width":1260,"height":496,"caption":"featured_image"},{"@type":"BreadcrumbList","@id":"https:\/\/magecurious.com\/blog\/magento-2-how-to-create-custom-graphql\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/magecurious.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Magento 2 How to Create Custom Graphql"}]},{"@type":"WebSite","@id":"https:\/\/magecurious.com\/blog\/#website","url":"https:\/\/magecurious.com\/blog\/","name":"Magecurious","description":"Blog","publisher":{"@id":"https:\/\/magecurious.com\/blog\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/magecurious.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/magecurious.com\/blog\/#organization","name":"Magecurious","url":"https:\/\/magecurious.com\/blog\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/logo\/image\/","url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2026\/03\/cropped-New_Project.png","contentUrl":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2026\/03\/cropped-New_Project.png","width":596,"height":113,"caption":"Magecurious"},"image":{"@id":"https:\/\/magecurious.com\/blog\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/6bced7da0991e7fbbd4550006a6494e2","name":"Magecurious","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/magecurious.com\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/c9178df2190b2309da97c9f28dd475bc338275cf664d12678d7e5da51c761271?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/c9178df2190b2309da97c9f28dd475bc338275cf664d12678d7e5da51c761271?s=96&d=mm&r=g","caption":"Magecurious"},"sameAs":["https:\/\/magecurious.com"],"url":"https:\/\/magecurious.com\/blog\/author\/magecurious-wp\/"}]}},"jetpack_featured_media_url":"https:\/\/magecurious.com\/blog\/wp-content\/uploads\/2022\/07\/GraphQL-Mage1.png","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/169","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/comments?post=169"}],"version-history":[{"count":0,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/posts\/169\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media\/176"}],"wp:attachment":[{"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/media?parent=169"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/categories?post=169"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/magecurious.com\/blog\/wp-json\/wp\/v2\/tags?post=169"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}