# mageplaza/magento-2-reward-points-graphql

> Magento 2 Reward Points Graphql Extension

`composer require mageplaza/magento-2-reward-points-graphql`

Canonical URL: https://packagento.com/mageplaza/magento-2-reward-points-graphql

## At a glance

- **Vendor**: mageplaza (https://packagento.com/mageplaza.md)
- **Latest version**: 1.2.1 — released 2024-12-12
- **Pricing**: Free
- **Package type**: Magento 2 module
- **Status**: active, accepting new buyers

## Installation

Packagento is licence-gated, so even free packages need a licence on a project before Composer can resolve them.

1. **Sign in or create an account** at https://packagento.com/customer/account/.

2. **Add the package to your account.** Open https://packagento.com/mageplaza/magento-2-reward-points-graphql and complete the free checkout. A licence is minted automatically.

3. **Create or pick a project, then activate the licence on it.**
   - Projects represent the Magento installs you deploy to. Manage them at https://packagento.com/projects/.
   - Activate the new licence on the project you'll deploy this package to. Activation is what generates the Composer credentials scoped to that project.

4. **Add the project credentials to your Magento codebase.**

   Grab the project's public + private key from https://packagento.com/projects/ (open the project, then its Credentials tab), and add them to `auth.json`:

   ```json
   {
     "http-basic": {
       "packagento.com": {
         "username": "ppk_live_...",
         "password": "psk_live_..."
       }
     }
   }
   ```

   Add the Packagento Composer repository to `composer.json`:

   ```json
   {
     "repositories": [
       { "type": "composer", "url": "https://packagento.com" }
     ]
   }
   ```

5. **Install and apply.**

   ```bash
   composer require mageplaza/magento-2-reward-points-graphql:*
   bin/magento setup:upgrade
   bin/magento setup:di:compile
   bin/magento cache:flush
   ```

## What it does

Magento 2 Reward Points Graphql Extension

## README

**Magento 2 Reward Points GraphQL is now a part of Mageplaza Reward Points extension that adds GraphQL features.** This supports PWA compatibility. With this extension, you can get and push data on the website with GraphQL.

[Reward Points for Magento 2](https://www.mageplaza.com/magento-2-reward-points-extension/) is a powerful loyalty program that converts buyers into customers, increases conversion rates, and boosts sales with a smart automatic reward system. 

The reward point labels can be customized easily from the admin backend. You can use eye-catching point labels such as coin, flower, heart, etc., to attract customers to your reward programs. This will arouse their interest in your program and shopping in your store. Spending sliders will be another factor to increase customer experience and joyfulness when shopping in your store. Instead of filling in the number of points spent, they can pull the slider, and the corresponding point will be subtracted. 

It’s flexible for online store owners to set up rewards levels based on earning and spending rules. Reward points can also be given off when customers share your products or content on social media. This will help your products or services spread across social media while increasing the interaction between your customers and your store. Reward for behaviors is also effective as customers can earn points by performing an action. This is a great incentive for them to continue being active in your store with some actions like subscribing, purchasing, reviewing, or rating. They can even earn points by referring to their friends, who can also receive points and get an appealing discount on the store’s products. 

[Magento 2 Reward Points](https://marketplace.magento.com/mageplaza-module-reward-points.html) enables you to offer customers a transparent and reasonable point spending system that allows them to purchase products on your store by points. It makes the shopping process funnier, and customers can see the real advantages of reward points they’ve earned. 

Customers' earning and spending points can be tracked easily via an advanced report supported by the Mageplaza Report extension. The store admin will know if any customer is missing out on their points to immediately give them incentive offers or reward points to earn their interest back. Importing and exporting the reward points transaction are also done quickly, saving a lot of time for the store admin. 

### 1. How to install

Run the following command in Magento 2 root folder:

```
composer require mageplaza/module-reward-points-graphql
php bin/magento setup:upgrade
php bin/magento setup:static-content:deploy
```

**Note:** 
Magento 2 Reward Points GraphQL requires installing [Mageplaza Reward Points](https://www.mageplaza.com/magento-2-reward-points-extension/) in your Magento installation. 

### 2. How to use
To start working with Reward Points GraphQL in Magento, here are the requirements to follow: 
- Use Magento 2.3.x. Return your site to developer mode. 
- Install [chrome extension](https://chrome.google.com/webstore/detail/chromeiql/fkkiamalmpiidkljmicmjfbieiclmeij?hl=en) (currently does not support other browsers). 
- Set **GraphQL endpoint** as `http://<magento2-3-server>/graphql` in the url box. Click on Set endpoint. (e.g., `http://develop.mageplaza.com/graphql/ce232/graphql`). 
- The queries and mutations that Mageplaza support helps to see details of Transaction, Invitation, etc., through customer query, view Spending Point information, create Invite Email, and more. You can find more details [here](https://documenter.getpostman.com/view/10589000/SzRyzpww?version=latest). 

### 3. Devdocs
- [Magento 2 Reward Points API & examples](https://documenter.getpostman.com/view/10589000/SzRyzpwz?version=latest)
- [Magento 2 Reward Points GraphQL & examples](https://documenter.getpostman.com/view/10589000/SzRyzpww?version=latest)

Click on Run in Postman to add these collections to your workspace quickly.

![Magento 2 blog graphql pwa](https://i.imgur.com/lhsXlUR.gif)

### 4. Contribute to this module 
Feel free to **Fork** and contribute to this module. 

You can create a pull request. We will consider to merge your changes in the main branch. 

### 5. Get support
- Feel free to [contact us](https://www.mageplaza.com/contact.html) if you have any question. We're willing to hear from you and resolve your problems. 
- If you find this post helpful, please give us a **Star** ![star](https://i.imgur.com/S8e0ctO.png)

## Changelog

CHANGELOG: https://www.mageplaza.com/releases/reward-points

## Recent Versions

| Version | Released |
|---|---|
| 1.2.1 | 2024-12-12 |
| 1.2.0 | 2022-02-08 |
| 1.1.0 | 2020-12-10 |
| 1.0.2 | 2020-07-10 |
| 1.0.0 | 2020-03-06 |

## Quality

Latest release (1.2.1) fails the Packagento QA pipeline. Verdicts below are per-cell (Magento line × PHP version) for the matrixed tools, and run-once for the static / security tiers.


### Compatibility

Each Magento line is installed on its supported PHP versions, then the module is built (DI compile + static-content deploy). Cells show passed / failed / untested; staircase gaps render as `–`.

| Magento | PHP 8.2 | PHP 8.3 | PHP 8.4 | PHP 8.5 |
|---|---|---|---|---|
| 2.4.7 | 1 | 1 | – | – |
| 2.4.8 | – | 1 | 1 | – |
| 2.4.9 | – | – | 1 | 1 |


### Code Quality

Advisory checks against the module's source. Never affect the Compatibility verdict — a phpcs finding can't make a module incompatible.

#### Static Analysis

Coding standards (phpcs), mess detection (phpmd), copy-pasted code (cpd), PHP cross-version compatibility, composer.json validity. Each runs once for the whole module.

| Tool | Status | Findings | Summary |
|---|---|---|---|
| PHPCS | Warning | 47 | 47 warnings (ruleset: Magento2) — 44 auto-fixable with phpcbf |
| PHPMD | Warning | 6 | 6 rule violations (UnusedFormalParameter:6) |
| Cpd | Pass | 0 |  |
| Composer validate | Info | 1 | valid; 1 advisory note (composer validate --strict) |

#### PHPStan

Type-checks the module against a real Magento install. Re-runs per Magento + PHP version because resolvable symbols differ between releases.

| Magento | PHP 8.2 | PHP 8.3 | PHP 8.4 | PHP 8.5 |
|---|---|---|---|---|
| 2.4.7 | 111 | 111 | – | – |
| 2.4.8 | – | 111 | 143 | – |
| 2.4.9 | – | – | 143 | 143 |


### Tests

Unit and integration suites run per Magento + PHP cell. Test failures speak to the module's behaviour, not its compatibility with a line, so they're reported here separately.

#### Unit Tests

| Magento | PHP 8.2 | PHP 8.3 | PHP 8.4 | PHP 8.5 |
|---|---|---|---|---|
| 2.4.7 | N/A | N/A | – | – |
| 2.4.8 | – | N/A | N/A | – |
| 2.4.9 | – | – | N/A | N/A |

#### Integration Tests

| Magento | PHP 8.2 | PHP 8.3 | PHP 8.4 | PHP 8.5 |
|---|---|---|---|---|
| 2.4.7 | N/A | N/A | – | – |
| 2.4.8 | – | N/A | N/A | – |
| 2.4.9 | – | – | N/A | N/A |


### Security

Dependency-advisory audit (composer audit) plus a source malware scan. A malware detection fails the version outright.

| Tool | Status | Findings | Summary |
|---|---|---|---|
| Composer audit | Pass | 0 |  |
| Malware scan | Pass | 0 |  |

## Licence and pricing

Free. A licence is still minted on checkout and bound to your project for Composer access — no payment step.

Refundable within 14 days of first purchase via https://packagento.com/account/refunds/.

## Install via Claude Code or any MCP client

The Packagento MCP server can run the licence + project + Composer steps above in one tool call:

```
purchase_and_install_packages(
  composer_names=["mageplaza/magento-2-reward-points-graphql"],
  project_id="proj_xxx"
)
```

This handles cart, checkout, licence minting, project activation, and writes auth.json credentials. Connect a client with `claude mcp add packagento https://mcp.packagento.com`. Full setup at https://packagento.com/docs/mcp-setup.

## Vendor

mageplaza is a Magento 2 vendor on Packagento. See https://packagento.com/mageplaza.md for their full catalogue.

