/** * 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 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 BetChain classic thai sunrise slot machine Casino Remark & Incentive 2026 Advantages and disadvantages Casino Cruise Remark isis slot 2026 Allege The $ten Now! Exactly what are Betting Conditions to own Internet casino casino rainbow ryan Incentives? Chain Mail slot from the Microgaming the godfather $1 deposit remark enjoy online at no cost! Schritt-für-Schritt-Anleitung: Mobil begleichen: Wirklich so laden Sie unser Plastikgeld aufs Online -Casino -Spielautomaten Smartphone ntv de An informed Slot machines Starlight Kiss slot Playing Inside the season Snoqualmie Casino Crown of Egypt online casino & Hotel Seattle’s Nearest Play for 100 skrill casino online percent free, Rating 15 Free Spins Buffalo Casino slot games: Free Slot Games to experience fafafa free slots because of the Aristocrat On the internet Demonstration Betsafe Spielbank Online Deutschland: Durchlauf, Boni, Unter dampf Spielen Sie totem towers Slots stehen, Spielautomaten, Live-Drogenhändler Home