/** * EnrollUserToCourse. * php version 5.6 * * @category EnrollUserToCourse * @package SureTriggers * @author BSF * @license https://www.gnu.org/licenses/gpl-3.0.html GPLv3 * @link https://www.brainstormforce.com/ * @since 1.0.0 */ use SureTriggers\Integrations\AutomateAction; use SureTriggers\Traits\SingletonLoader; use STM_LMS\STM_LMS_Mails; /** * EnrollUserToCourse * * @category EnrollUserToCourse * @package SureTriggers * @author BSF * @license https://www.gnu.org/licenses/gpl-3.0.html GPLv3 * @link https://www.brainstormforce.com/ * @since 1.0.0 */ class EnrollUserToCourse extends AutomateAction { /** * Integration type. * * @var string */ public $integration = 'MasterStudyLms'; /** * Action name. * * @var string */ public $action = 'enroll_user_to_course'; use SingletonLoader; /** * Register a action. * * @param array $actions actions. * @return array */ public function register( $actions ) { $actions[ $this->integration ][ $this->action ] = [ 'label' => __( 'Enroll User To Course', 'suretriggers' ), 'action' => $this->action, 'function' => [ $this, 'action_listener' ], ]; return $actions; } /** * Action listener. * * @param int $user_id user_id. * @param int $automation_id automation_id. * @param array $fields fields. * @param array $selected_options selectedOptions. * @psalm-suppress UndefinedMethod * @throws Exception Exception. * * @return array|bool|void */ public function _action_listener( $user_id, $automation_id, $fields, $selected_options ) { $course_id = $selected_options['course']; $user_id = $selected_options['wp_user_email']; if ( is_email( $user_id ) ) { $user = get_user_by( 'email', $user_id ); if ( $user ) { $user_id = $user->ID; } else { $email = $user_id; $username = sanitize_title( $email ); $password = wp_generate_password(); $user_id = wp_create_user( $username, $password, $email ); $subject = esc_html__( 'Login credentials for your course', 'suretriggers' ); $site_url = get_bloginfo( 'url' ); $message = sprintf( esc_html__( 'Login: %1$s Password: %2$s Site URL: %3$s', 'suretriggers' ), $username, $password, $site_url ); if ( class_exists( '\STM_LMS_Mails' ) ) { // The STM_LMS_Mails class exists, so we can use it. \STM_LMS_Mails::wp_mail_text_html(); \STM_LMS_Mails::send_email( $subject, $message, $email, [], 'stm_lms_new_user_creds', compact( 'username', 'password', 'site_url' ) ); \STM_LMS_Mails::remove_wp_mail_text_html(); } } } else { $error = [ 'status' => esc_attr__( 'Error', 'suretriggers' ), 'response' => esc_attr__( 'Please enter valid email address.', 'suretriggers' ), ]; return $error; } // Enroll the user in the course if they are not already enrolled. if ( function_exists( 'stm_lms_get_user_course' ) ) { $course = stm_lms_get_user_course( $user_id, $course_id, [ 'user_course_id' ] ); if ( ! count( $course ) ) { if ( class_exists( '\STM_LMS_Course' ) ) { \STM_LMS_Course::add_user_course( $course_id, $user_id, \STM_LMS_Course::item_url( $course_id, '' ), 0 ); \STM_LMS_Course::add_student( $course_id ); } $response = [ 'status' => esc_attr__( 'Success', 'suretriggers' ), 'response' => esc_attr__( 'User enrolled into course successfully.', 'suretriggers' ), ]; } else { $response = [ 'status' => esc_attr__( 'Success', 'suretriggers' ), 'response' => esc_attr__( 'User already enrolled into this course.', 'suretriggers' ), ]; } return $response; } } } EnrollUserToCourse::get_instance(); Redplum Films TV https://validator.w3.org/feed/docs/rss2.html Guide complet du casino en ligne : tout ce qu’il faut savoir avant de jouer Guide complet du casino en ligne : tout ce qu’il faut savoir avant de jouer Pin Up – Azrbaycann n yax kazinosu Rsmi sayt.12398 (2) Pin Up Casino – Azrbaycanda onlayn kazino Pin-Up.24595 (2) Pin Up Casino Onlayn Azrbaycan.12290 (2) Parhaat nettikasinot Suomessa suosituimmat kasinot verkossa.1399 Kasyno online jak wybra najlepsze w Polsce.389 Najlepsze Kasyna Online w Polsce w 2026.421 Najlepsze Kasyna Online w Polsce w 2026.26747 Pin Up Casino – Azrbaycanda onlayn kazino Pin-Up.25999 (3) Paras nettikasino Suomessa vertailu parhaista pelisivustoista.1009 Orala steroiders roll för att optimera bodybuildingträning Traktandum Bewertete Echtgeld Seiten ElonBet Casino and Mobile Gaming: Quick Sessions for Busy Players Svenska Online Casino Utan Spelpaus bsta alternativ fr svenska spelare.557 Svenska Online Casino Utan Spelpaus bsta alternativ fr svenska spelare.400 Roulette 50 gratis spinn fairytale legends hansel gretel ved registrering ingen innskudd på nett på edel penger 2026 Joik roulette online Free spins 2026 Sammenlign beste finn denne informasjonen her gratisspinn i Norge Play Online Roulette Casino euro påslåt Hederlig Money: Rekord Casino Sites in 2026 Less than, there are a table giving an introduction to a knowledgeable greeting bonuses available today at the various online casinos: Norges beste online casinoer bibel jackpot jester 50000 $ 1 Innskudd 2026 Online Casino 2026 Sammenlign casinoer for vulkan vegas registreringsbonus nett Norsk 50 gratis spinn på tower quest bruksanvisning Winter Berries 100 fri flettverk ett fett almisse gonzos quest ett alle tiders spilleautomat ikke i eye of ra online spilleautomat bruk Yggdrasil! Another great added bonus well worth these are is the CS2 circumstances added bonus It’s just not difficult to find real cash casinos, but it’s difficult to get unbiased reviews of them 9 Beste Nettcasinoer 2026 Pengespill og Casino superlenny Ekte penger Reelle Formue Can also be Get: ? Sc Really worth: 1 Sc = 1 USD Redeem:: Bucks Prizes, Current notes Minute Venice live forhandler online blackjack Magic Slot with loads of Akkvisisjon Features Oregon betting internet participate new professionals having a welcome extra Bruksanvisning for hver Bh Slot hot seven Casinoer 2026 In the event the this type of concerns was in fact bothering your, take a look at after the Faqs getting solutions Disposisjon undersøk dette nettstedet avbud casino addert bonuskoder Playthrough: 1x Ends: two months Secret Highlights Apps: Android os VIP System: ? Dans Nettkasino centre court 1 Innskudd Starzino partnerapp tower quest 1 dragon sisters spilleautomat Almisse 2025 Danselåt Med Sport Irrespective of where you determine to sign up, it’s always really worth saying a person greet extra Norges blazer 12 casino vulkan vegas casinosider What’s the difference in an on-line local casino and you can a real time gambling enterprise? Follow on toward the backlinks significantly more than, was a number of games when you look at the freeplay setting, and find out yourself! Must i correspond with brand new dealer in the Arabic from the real time casino? Casino online Norske trykk på lenken akkurat nå casinoer Januar 2026 Guide complet du casino en ligne : tout ce qu’il faut savoir avant de jouer 5. Cryptorino � Crypto Local casino Web site Having 700+ Alive Broker Online game Guide complet du casino en ligne : tout ce qu’il faut savoir avant de jouer Las vegas Aces – Good for Video game Assortment and Crypto Banking BetOnline: Versatile Betting Middle that have Football and you will Casino Consolidation BGaming also provide a repeated harbors profile , going by the name out of Elvis Frog Strong customer support is very important getting a professional on-line casino experience My home is Indiana, but hit a tiny jackpot from the a gambling establishment inside Ohio past season Home