관리-도구
편집 파일: KkartPayments.php
<?php /** * Kkart Admin Kkart Payments Note Provider. * * Adds a note to the merchant's inbox showing the benefits of the Kkart Payments. */ namespace Automattic\Kkart\Admin\Notes; defined( 'ABSPATH' ) || exit; /** * Kkart_Payments */ class KkartPayments { /** * Note traits. */ use NoteTraits; /** * Name of the note for use in the database. */ const NOTE_NAME = 'kkart-admin-kkart-payments'; /** * Name of the note for use in the database. */ const PLUGIN_SLUG = 'kkart-payments'; /** * Name of the note for use in the database. */ const PLUGIN_FILE = 'kkart-payments/kkart-payments.php'; /** * Attach hooks. */ public function __construct() { add_action( 'init', array( $this, 'install_on_action' ) ); add_action( 'kkart-admin-kkart-payments_add_note', array( $this, 'add_note' ) ); } /** * Maybe add a note on Kkart Payments for US based sites older than a week without the plugin installed. */ public static function possibly_add_note() { if ( ! self::kkart_admin_active_for( WEEK_IN_SECONDS ) || 'US' !== KKART()->countries->get_base_country() ) { return; } $data_store = \KKART_Data_Store::load( 'admin-note' ); // We already have this note? Then mark the note as actioned. $note_ids = $data_store->get_notes_with_name( self::NOTE_NAME ); if ( ! empty( $note_ids ) ) { $note_id = array_pop( $note_ids ); $note = Notes::get_note( $note_id ); if ( false === $note ) { return; } // If the Kkart Payments plugin was installed after the note was created, make sure it's marked as actioned. if ( self::is_installed() && Note::E_KKART_ADMIN_NOTE_ACTIONED !== $note->get_status() ) { $note->set_status( Note::E_KKART_ADMIN_NOTE_ACTIONED ); $note->save(); } return; } $current_date = new \DateTime(); $publish_date = new \DateTime( '2020-04-14' ); if ( $current_date >= $publish_date ) { $note = self::get_note(); if ( self::can_be_added() ) { $note->save(); } return; } else { $hook_name = sprintf( '%s_add_note', self::NOTE_NAME ); if ( ! KKART()->queue()->get_next( $hook_name ) ) { KKART()->queue()->schedule_single( $publish_date->getTimestamp(), $hook_name ); } } } /** * Add a note about Kkart Payments. * * @return Note */ public static function get_note() { $note = new Note(); $note->set_title( __( 'Try the new way to get paid', 'kkart' ) ); $note->set_content( __( 'Securely accept credit and debit cards on your site. Manage transactions without leaving your WordPress dashboard. Only with <strong>Kkart Payments</strong>.', 'kkart' ) . '<br><br>' . sprintf( /* translators: 1: opening link tag, 2: closing tag */ __( 'By clicking "Get started", you agree to our %1$sTerms of Service%2$s', 'kkart' ), '<a href="https://wordpress.com/tos/" target="_blank">', '</a>' ) ); $note->set_content_data( (object) array() ); $note->set_type( Note::E_KKART_ADMIN_NOTE_MARKETING ); $note->set_name( self::NOTE_NAME ); $note->set_source( 'kkart-admin' ); $note->add_action( 'learn-more', __( 'Learn more', 'kkart' ), 'https://kkart.com/payments/', Note::E_KKART_ADMIN_NOTE_UNACTIONED ); $note->add_action( 'get-started', __( 'Get started', 'kkart' ), kkart_admin_url( '&action=setup-kkart-payments' ), Note::E_KKART_ADMIN_NOTE_ACTIONED, true ); // Create the note as "actioned" if the plugin is already installed. if ( self::is_installed() ) { $note->set_status( Note::E_KKART_ADMIN_NOTE_ACTIONED ); } return $note; } /** * Check if the Kkart Payments plugin is active or installed. */ protected static function is_installed() { if ( defined( 'KKART_Payments' ) ) { return true; } include_once KKART_ADMIN_DIR . 'includes/plugin.php'; return 0 === validate_plugin( self::PLUGIN_FILE ); } /** * Install and activate Kkart Payments. * * @return boolean Whether the plugin was successfully activated. */ private function install_and_activate_wcpay() { $install_request = array( 'plugins' => self::PLUGIN_SLUG ); $installer = new \Automattic\Kkart\Admin\API\Plugins(); $result = $installer->install_plugins( $install_request ); if ( is_wp_error( $result ) ) { return false; } $activate_request = array( 'plugins' => self::PLUGIN_SLUG ); $result = $installer->activate_plugins( $activate_request ); if ( is_wp_error( $result ) ) { return false; } return true; } /** * Install & activate Kkart Payments plugin, and redirect to setup. */ public function install_on_action() { // TODO: Need to validate this request more strictly since we're taking install actions directly? /* phpcs:disable WordPress.Security.NonceVerification */ if ( ! isset( $_GET['page'] ) || 'kkart-admin' !== $_GET['page'] || ! isset( $_GET['action'] ) || 'setup-kkart-payments' !== $_GET['action'] ) { return; } /* phpcs:enable */ if ( ! current_user_can( 'install_plugins' ) ) { return; } $this->install_and_activate_wcpay(); // Kkart Payments is installed at this point, so link straight into the onboarding flow. $connect_url = add_query_arg( array( 'wcpay-connect' => '1', '_wpnonce' => wp_create_nonce( 'wcpay-connect' ), ), admin_url() ); wp_safe_redirect( $connect_url ); exit; } }