class.llms.controller.achievements.php 2.89 KB
Newer Older
cyrille's avatar
cyrille committed
1 2
<?php
/**
Cyrille's avatar
Cyrille committed
3
 * LLMS_Controller_Achievements class
cyrille's avatar
cyrille committed
4 5 6 7
 *
 * @package LifterLMS/Controllers/Classes
 *
 * @since 3.18.0
Cyrille's avatar
Cyrille committed
8
 * @version 6.0.0
cyrille's avatar
cyrille committed
9 10 11 12 13
 */

defined( 'ABSPATH' ) || exit;

/**
Cyrille's avatar
Cyrille committed
14
 * Handles awarded user achievements.
cyrille's avatar
cyrille committed
15 16 17
 *
 * @since 3.18.0
 * @since 3.35.0 Sanitize `$_POST` data.
Cyrille's avatar
Cyrille committed
18
 * @since 6.0.0 Extended from the LLMS_Abstract_Controller_User_Engagements class.
cyrille's avatar
cyrille committed
19
 */
Cyrille's avatar
Cyrille committed
20 21 22 23 24 25 26 27 28 29
class LLMS_Controller_Achievements extends LLMS_Abstract_Controller_User_Engagements {

	/**
	 * Type of user engagement.
	 *
	 * @since 6.0.0
	 *
	 * @var string
	 */
	protected $engagement_type = 'achievement';
cyrille's avatar
cyrille committed
30 31 32 33 34 35 36 37 38

	/**
	 * Constructor
	 *
	 * @since 3.18.0
	 *
	 * @return void
	 */
	public function __construct() {
Cyrille's avatar
Cyrille committed
39 40

		parent::__construct();
cyrille's avatar
cyrille committed
41 42 43 44
		add_action( 'init', array( $this, 'maybe_handle_reporting_actions' ) );
	}

	/**
Cyrille's avatar
Cyrille committed
45
	 * Returns a translated text of the given type.
cyrille's avatar
cyrille committed
46
	 *
Cyrille's avatar
Cyrille committed
47
	 * @since 6.0.0
cyrille's avatar
cyrille committed
48
	 *
Cyrille's avatar
Cyrille committed
49 50 51
	 * @param int   $text_type One of the LLMS_Abstract_Controller_User_Engagements::TEXT_ constants.
	 * @param array $variables Optional variables that are used in sprintf().
	 * @return string
cyrille's avatar
cyrille committed
52
	 */
Cyrille's avatar
Cyrille committed
53
	protected function get_text( $text_type, $variables = array() ) {
cyrille's avatar
cyrille committed
54

Cyrille's avatar
Cyrille committed
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
		switch ( $text_type ) {
			case self::TEXT_SYNC_AWARDED_ENGAGEMENT_INSUFFICIENT_PERMISSIONS:
				return sprintf(
					/* translators: %1$d: awarded achievement ID */
					__( 'Sorry, you are not allowed to edit the awarded achievement #%1$d.', 'lifterlms' ),
					( $variables['engagement_id'] ?? 0 )
				);
			case self::TEXT_SYNC_AWARDED_ENGAGEMENT_INVALID_TEMPLATE:
				return sprintf(
					/* translators: %1$d: awarded achievement ID */
					__( 'Sorry, the awarded achievement #%1$d does not have a valid achievement template.', 'lifterlms' ),
					( $variables['engagement_id'] ?? 0 )
				);
			case self::TEXT_SYNC_AWARDED_ENGAGEMENTS_INSUFFICIENT_PERMISSIONS:
				return __( 'Sorry, you are not allowed to edit awarded achievements.', 'lifterlms' );
			case self::TEXT_SYNC_AWARDED_ENGAGEMENTS_INVALID_NONCE:
				return __( 'Sorry, you are not allowed to sync awarded achievements.', 'lifterlms' );
			case self::TEXT_SYNC_MISSING_AWARDED_ENGAGEMENT_ID:
				return __( 'Sorry, you need to provide a valid awarded achievement ID.', 'lifterlms' );
			case self::TEXT_SYNC_MISSING_ENGAGEMENT_TEMPLATE_ID:
				return __( 'Sorry, you need to provide a valid achievement template ID.', 'lifterlms' );
			default:
				return parent::get_text( $text_type );
cyrille's avatar
cyrille committed
78 79 80 81
		}
	}

	/**
Cyrille's avatar
Cyrille committed
82
	 * Handle achievement form actions to download (for students and admins) and to delete (admins only)
cyrille's avatar
cyrille committed
83 84
	 *
	 * @since 3.18.0
Cyrille's avatar
Cyrille committed
85
	 * @since 3.35.0 Sanitize `$_POST` data.
cyrille's avatar
cyrille committed
86 87 88
	 *
	 * @return void
	 */
Cyrille's avatar
Cyrille committed
89
	public function maybe_handle_reporting_actions() {
cyrille's avatar
cyrille committed
90

Cyrille's avatar
Cyrille committed
91
		if ( ! llms_verify_nonce( '_llms_achievement_actions_nonce', 'llms-achievement-actions' ) ) {
cyrille's avatar
cyrille committed
92 93 94
			return;
		}

Cyrille's avatar
Cyrille committed
95 96 97
		if ( isset( $_POST['llms_delete_achievement'] ) ) {
			$this->delete( llms_filter_input( INPUT_POST, 'achievement_id', FILTER_SANITIZE_NUMBER_INT ) );
		}
cyrille's avatar
cyrille committed
98 99 100 101 102

	}
}

return new LLMS_Controller_Achievements();