You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
261 lines
5.7 KiB
261 lines
5.7 KiB
<?php |
|
# |
|
# FYI see PEAR::Mail for functions to add for batch email |
|
# |
|
global $eol; |
|
$eol = "\r\n"; |
|
# |
|
function fullsend($to, $subject, $message, $headers, $extra = null) |
|
{ |
|
if ($extra == null) |
|
$ret = mail($to, $subject, $message, $headers); |
|
else |
|
$ret = mail($to, $subject, $message, $headers, $extra); |
|
|
|
if ($ret == false) |
|
error_log("CKPWARN: ".gmdate("Y-m-d H:i:s \\U\\T\\C"). |
|
" sendmail failed? to: '$to'"); |
|
|
|
return $ret; |
|
} |
|
# |
|
function sendnoheader($to, $subject, $message, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KNoReply'])) |
|
return false; |
|
|
|
$noreply = $emailinfo['KNoReply']; |
|
|
|
$headers = "From: $noreply$eol"; |
|
$headers .= "X-Mailer: ."; |
|
|
|
return fullsend($to, $subject, $message, $headers, "-f$noreply"); |
|
} |
|
# |
|
function dontReply($emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$message = "P.S. don't reply to this e-mail, no one will get the reply$eol"; |
|
$message .= "There is a contact e-mail address (that changes often)$eol"; |
|
$message .= "at $web/ or visit us on FreeNode IRC #ckpool$eol"; |
|
|
|
return $message; |
|
} |
|
# |
|
function emailEnd($the, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
$ret = dontReply($emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "This $the was made '".gmdate("Y-M-d H:i:s \\U\\T\\C"); |
|
$message .= "' by '$whoip'$eol$eol"; |
|
$message .= $ret; |
|
|
|
return $message; |
|
} |
|
# |
|
function passWasReset($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('reset', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "Your password has been reset.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "Password Reset", $message, $emailinfo); |
|
} |
|
# |
|
function passReset($to, $code, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('password reset', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "Someone requested to reset your password.$eol$eol"; |
|
$message .= "You can ignore this message since nothing has changed yet,$eol"; |
|
$message .= "or click on the link below to reset your password.$eol"; |
|
$message .= "$web/index.php?k=reset&code=$code$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "Password Reset", $message, $emailinfo); |
|
} |
|
# |
|
function payoutAddressChanged($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('payout address change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "Your payout address has been changed.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "Payout Address Change", $message, $emailinfo); |
|
} |
|
# |
|
function emailAddressChanged($to, $whoip, $emailinfo, $old) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('email address change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "Your email address has been changed to:$eol <$to>$eol$eol"; |
|
if ($old != null && $old != '') |
|
{ |
|
$message .= "You will no longer receive notifications at the address:$eol <$old>$eol$eol"; |
|
$send = "$to,$old"; |
|
} |
|
else |
|
$send = $to; |
|
$message .= $ret; |
|
|
|
return sendnoheader($send, "EMail Address Change", $message, $emailinfo); |
|
} |
|
# |
|
function passChanged($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('password change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "Your password was changed.$eol$eol"; |
|
$message .= "If you didn't change it, then you need to urgently use$eol"; |
|
$message .= "the password reset at the pool to change it again.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "Password Change", $message, $emailinfo); |
|
} |
|
# |
|
function twofaSetup($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('2fa change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "2FA is ready to be tested.$eol"; |
|
$message .= "It will be enabled once you test it.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "2FA is Ready to be Enabled", $message, $emailinfo); |
|
} |
|
# |
|
function twofaEnabled($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('2fa change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "2FA is enabled on your account.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "2FA is Enabled", $message, $emailinfo); |
|
} |
|
# |
|
function twofaCancel($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('2fa change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "2FA setup was cancelled on your account.$eol"; |
|
$message .= "You can set it up later if you want.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "2FA was Cancelled", $message, $emailinfo); |
|
} |
|
# |
|
function twofaRemove($to, $whoip, $emailinfo) |
|
{ |
|
global $eol; |
|
|
|
if (!isset($emailinfo['KWebURL'])) |
|
return false; |
|
|
|
$web = $emailinfo['KWebURL']; |
|
|
|
$ret = emailEnd('2fa change', $whoip, $emailinfo); |
|
if ($ret === false) |
|
return false; |
|
|
|
$message = "2FA was removed from your account.$eol"; |
|
$message .= "You can set it up again later if you want.$eol$eol"; |
|
$message .= $ret; |
|
|
|
return sendnoheader($to, "2FA was Removed", $message, $emailinfo); |
|
} |
|
# |
|
# getOpts required for email |
|
# If they aren't all setup in the DB then email functions will return false |
|
function emailOptList() |
|
{ |
|
return 'KWebURL,KNoReply'; |
|
} |
|
# |
|
?>
|
|
|