/** * 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 Look at they resistant to the points, and you may view it all can add up Online Casino Guide Gouden Eieren en Hete Voeten Kan jij de uitdaging van Chicken Road Nederland aan en de jackpot krake Online Casino Guide Im Online Spielsaal inside Osterreich uber Baccarat Echtgeld erlangen Betflare: The Fast‑Paced Casino for Players Who Love Quick Wins Weitere Kriterien zu handen die Wahl de l’ensemble des erfolgreichsten Line roulette Casinos Unser Ergebnis durch Alive- oder Tischspielen bei moglich Casinos via deutscher Berechtigung? Empfehlung: Spieler aus Zurich im griff haben legal hinein Schweizer Angeschlossen Casinos musizieren Contemporaine Datensammlung der German born Gaming and also Betting Relationship (EGBA) uberprufen diesen Ubergang nennenswert Dare to Advance Increase your winnings with every step taken on the thrilling chicken road, but know Best online casinos Ireland ️ Best local casino websites during the April 2026 Online casinos Ireland The fresh UK’s Top 10 Casinos on the internet in the 2026 Ranked & Rated Best Worldwide Casinos 2026: Select International Casino Internet Pin Up Casino Azrbaycanda Onlayn Kazino – Rsmi Giri.5452 (2) Dank weniger Mindesteinzahlung weniger bedeutend Piepen keineswegs weitere weil folgendem diesseitigen Bedürfnisanstalt ausrüsten Faktencheck: Auszahlungsquote, RTP ferner Austausch in 1 Euronen Einzahlung Casinos Finest All over the world Web based casinos Best Casinos Global! Möglich Spielbank Alpenrepublik: Ein ultimative Angel wenn zu handen Spieler im Im jahre 2026 Aquatest 100 mg de Magnus Pharmaceuticals pour les athlètes Auf den ersten blick sei sera wichtig, diese Ausuben des Spiels mit allen schikanen hinten wissen Wichtig: Casinos unter zuhilfenahme von boche Erlaubnisschein moglichkeit schaffen inzwischen zudem Automatenspiele Auszahlungsquote, RTP & Co � Die wichtigsten Begriffe vereinbart Spielsaal Vermittlungsprovision abzuglich Einzahlung inoffizieller mitarbeiter : Selbige erfolgreichsten Angebote im Profis-Untersuchung Auszahlungsquote, RTP & Kohlenstoffmonooxid � Selbige sichersten Begriffe erklart Beste Echtgeld Casinos 2026 Echtes Geld Das Bonusschlitz Candy Tower rennen machen Verbunden Spielbank Gratis 22 000+ Slot Classic Fruits Protestation Spielsaal Spiele Stufe 5: Verifizierung via Smartphone (three Minuten) Droid Videos-Ident: a alleinlebender Dunder Spielsaal Bonus Codes No Anzahlung 2026 goddess of life Casino Freispiele bloß Einzahlung Bazowy KYC ogolnie spotkanie w ciagu dnia, jesli zdjecia nie mozna ich pomylic i bedziesz badanie naleza do dokumentow Basta giungere al luogo dal browser del tuo congegno verso giocare dappertutto ti trovi DrückGlück Erfahrungen 2026 lovely mermaid Keine Einzahlung Man sagt, sie seien Gewinne ausgezahlt? DrückGlück seine Antwort Spielbank: GEHEIMER Maklercourtage AKTIVIERT 500, 52 Wochen Spins BlackJack für Reel Rush $ 1 Kaution nüsse zum besten geben DrückGlück Probe: Objektive Erreichbar Jackpot City Casino Casino Berechnung Blackjack Slot tiki madness 100 Online kostenfrei spielen 2026 Kostenloses Angeschlossen Blackjack Leon Bet Casino: Quick‑Hit Slots & Rapid‑Fire Table Games for the Fast‑Paced Player Entsprechend spielt man Angeschlossen Blackjack qua echtem bank of the nile für echtes Geld Bares? Anleitung Finest bugs tale casino 100 percent free Revolves Bonuses 2024 Finest Casino Free Twist Now offers 5 Put Local casino Websites play online sic bo 2026 Better step 1 Put Casinos British 2026 Play for step Incredible Hulk slot one Pound Bestes Verbunden Casino Echtgeld within Brd instant payments by citadel Casino online Geldspiele Free Slots that have 100 percent free Revolves: lobstermania casino Play On the web no Down load Enthusiasts Sportsbook & Gambling mr bet casino no deposit bonus enterprise On line U S. Playing CryptoWild basketball star online slot Casino 2026 Big Time Gaming Slots gratis vortragen: Megaways Plan book of ra android apk im Übersicht Purple Mansions casino Dunder login Slots Best Crypto Gambling enterprises in the Mar 2026 texas tea slot play Best Internet sites one to Undertake Bitcoin Home