Files
piratepoet/lib/Subscription/Registration.php
Pavel Dohnal 111adbe90e Fix registration of rejected users
There are multiple hooks for user registration.
https://usersinsights.com/wp/wp-content/uploads/2018/07/user-registration-hooks-2.png
The `register_post` hook is executed first and
after that there is `registration_errors`.
The captcha verification is done in `registration_errors` hook.
But because we were using `register_post` we were saving
the subscriber before the post request was verified.

[MAILPOET-2114]
2019-06-06 10:41:13 -04:00

91 lines
2.1 KiB
PHP

<?php
namespace MailPoet\Subscription;
use MailPoet\Settings\SettingsController;
use MailPoet\Subscribers\SubscriberActions;
use MailPoet\WP\Functions as WPFunctions;
class Registration {
/** @var SettingsController */
private $settings;
/** @var SubscriberActions */
private $subscriber_actions;
function __construct(
SettingsController $settings,
SubscriberActions $subscriber_actions
) {
$this->settings = $settings;
$this->subscriber_actions = $subscriber_actions;
}
function extendForm() {
$label = $this->settings->get(
'subscribe.on_register.label',
WPFunctions::get()->__('Yes, please add me to your mailing list.', 'mailpoet')
);
print '<p class="registration-form-mailpoet">
<label for="mailpoet_subscribe_on_register">
<input
type="checkbox"
id="mailpoet_subscribe_on_register"
value="1"
name="mailpoet[subscribe_on_register]"
/>&nbsp;' . esc_attr($label) . '
</label>
</p>';
}
function onMultiSiteRegister($result) {
if (empty($result['errors']->errors)) {
if (
isset($_POST['mailpoet']['subscribe_on_register'])
&& (bool)$_POST['mailpoet']['subscribe_on_register'] === true
) {
$this->subscribeNewUser(
$result['user_name'],
$result['user_email']
);
}
}
return $result;
}
function onRegister(
$errors,
$user_login,
$user_email = null
) {
if (
empty($errors->errors)
&& isset($_POST['mailpoet']['subscribe_on_register'])
&& (bool)$_POST['mailpoet']['subscribe_on_register'] === true
) {
$this->subscribeNewUser(
$user_login,
$user_email
);
}
return $errors;
}
private function subscribeNewUser($name, $email) {
$segment_ids = $this->settings->get(
'subscribe.on_register.segments',
[]
);
if (!empty($segment_ids)) {
$this->subscriber_actions->subscribe(
[
'email' => $email,
'first_name' => $name,
],
$segment_ids
);
}
}
}