mirror of
https://github.com/nextcloud/nextcloud.com.git
synced 2026-01-12 15:44:37 +00:00
Moved the ratelimits per form down to usually 2 per hour. Added a global ratelimit of 20 requests per hour. Signed-off-by: Lukas Reschke <lukas@statuscode.ch>
155 lines
6.1 KiB
PHP
155 lines
6.1 KiB
PHP
<head>
|
|
<script>
|
|
require(["require.config"], function() {
|
|
require(["pages/enterprise"])
|
|
});
|
|
</script>
|
|
<link href="<?php echo get_template_directory_uri(); ?>/assets/css/pages/enterprise.css" rel="stylesheet">
|
|
</head>
|
|
<section class="enterprise-hero-section second-menu">
|
|
<div class="container-fluid background">
|
|
<div class="container">
|
|
<div class="col-md-6 topheader">
|
|
<h1><?php echo $l->t('Nextcloud Enterprise');?></h1>
|
|
<h2><?php echo $l->t('The enterprise-ready Content Collaboration Platform');?></h2>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
<?php
|
|
require_once realpath(dirname(__FILE__)) . '/lib/ratelimiter.php';
|
|
|
|
if(!canPerformLimitedAction("provider-submit-action", 2)) {
|
|
die("Too many requests. Please try again later.");
|
|
}
|
|
|
|
if(isset($_POST['email'])) {
|
|
function died($error) {
|
|
// error code goes here
|
|
?>
|
|
<section class="section--whitepaper">
|
|
<div class="container text-center">
|
|
<h3>Sorry, there was an error with the form you submitted</h3>
|
|
<p>The error(s) detected:<br/>
|
|
<?php
|
|
echo $error . "<br />";
|
|
?>
|
|
</p>
|
|
<p>Use the back key to go to the previous page and fix the
|
|
issue!</p>
|
|
</div>
|
|
</section>
|
|
<?php
|
|
}
|
|
// validation expected data exists
|
|
if(!isset($_POST['organization']) ||
|
|
!isset($_POST['yourname']) ||
|
|
!isset($_POST['email']) ||
|
|
!isset($_POST['phone']) ||
|
|
!isset($_POST['hostingurl']) ||
|
|
!isset($_POST['targetcountries']) ||
|
|
!isset($_POST['hosting']) ||
|
|
!isset($_POST['free']) ||
|
|
!isset($_POST['description']) ||
|
|
!isset($_POST['image']))
|
|
{
|
|
died('We are sorry, but there appears to be a problem with the form you submitted - did you fill in all fields?'); }
|
|
$organization= $_POST['organization']; // required
|
|
$yourname = $_POST['yourname']; // required
|
|
$phone= $_POST['phone']; // required
|
|
$email_from = $_POST['email']; // required
|
|
$targetcountries = $_POST['targetcountries']; // required
|
|
$hosting = $_POST['hosting']; // required
|
|
$free = $_POST['free']; // required
|
|
$description = $_POST['description']; // required
|
|
$image = $_POST['image']; // required
|
|
$hostingurl= $_POST['hostingurl']; // required
|
|
$error_message = "";
|
|
|
|
$email_exp = '/^[A-Za-z0-9._%-]+@[A-Za-z0-9.-]+\.[A-Za-z]{2,10}$/';
|
|
if(!preg_match($email_exp,$email_from)) {
|
|
$error_message .= 'The email address you entered does not appear to be valid.<br />';
|
|
}
|
|
$string_exp = "/^[A-Za-z .'-]+$/";
|
|
if(!preg_match($string_exp,$yourname)) {
|
|
$error_message .= 'The name you entered does not appear to be valid.<br />';
|
|
}
|
|
$string_exp = "/^[A-Za-z .'-]+$/";
|
|
if(!preg_match($string_exp,$organization)) {
|
|
$error_message .= 'The organization you entered does not appear to be valid.<br />';
|
|
}
|
|
$string_exp = "/^((\+|00)\d{1,3})?(\d+|\s+)+\d$/";
|
|
if(!preg_match($string_exp,$phone)) {
|
|
$error_message .= 'The phone number you entered does not appear to be valid, did you add a country code like +49?<br />';
|
|
}
|
|
if(strlen($description) < 15) {
|
|
$error_message .= 'Your description is really short! <br />';
|
|
}
|
|
if(strlen($targetcountries) < 2) {
|
|
$error_message .= 'You did not enter any country code! <br />';
|
|
}
|
|
if(!filter_var($hostingurl, FILTER_VALIDATE_URL)) {
|
|
$error_message .= 'The URL you entered does not appear to be valid.<br />';
|
|
}
|
|
if(strlen($image) < 7) {
|
|
$error_message .= 'The link to an image you entered does not appear to be valid.<br />';
|
|
}
|
|
if(!filter_var($image, FILTER_VALIDATE_URL)) {
|
|
$error_message .= 'The link to an image you entered does not appear to be valid.<br />';
|
|
}
|
|
|
|
if(strlen($error_message) > 0) {
|
|
died($error_message);
|
|
} else {
|
|
function clean_string($string) {
|
|
$bad = array("content-type","bcc:","to:","cc:","href");
|
|
$string = str_replace($bad,"",$string);
|
|
return htmlspecialchars($string);
|
|
}
|
|
|
|
// the app review mailing list address
|
|
$email_message = "Form details below.\n\n";
|
|
$email_to = "jos@nextcloud.com";
|
|
$email_subject = "Provider_form";
|
|
$email_message .= "Organization: ".clean_string($organization)."\n";
|
|
$email_message .= "Contact name: ".clean_string($yourname)."\n";
|
|
$email_message .= "Email: ".clean_string($email_from)."\n";
|
|
$email_message .= "Phone: ".clean_string($phone)."\n";
|
|
$email_message .= "URL to Nc: ".clean_string($hostingurl)."\n";
|
|
$email_message .= "Hosting type: ".clean_string($hosting)."\n";
|
|
$email_message .= "Target countries: ".clean_string($targetcountries)."\n";
|
|
$email_message .= "Free plan or not: ".clean_string($free)."\n";
|
|
$email_message .= "Description: ".clean_string($description)."\n";
|
|
$email_message .= "Image: ".clean_string($image)."\n";
|
|
// create email headers
|
|
$headers = 'From: no-reply@nextcloud.com'."\r\n".
|
|
'Reply-To: '.$email_from."\r\n" .
|
|
'Content-Type: text/plain; charset=UTF-8'."\r\n" .
|
|
'Cc: '.$email_from;
|
|
// store in log
|
|
$data = [
|
|
'to' => $email_to,
|
|
'subject' => $email_subject,
|
|
'message' => $email_message,
|
|
'headers' => $headers,
|
|
];
|
|
file_put_contents('/var/log/sales-leads.txt', json_encode($data) . PHP_EOL, FILE_APPEND | LOCK_EX);
|
|
// Send the email to the list
|
|
@mail($email_to, $email_subject, $email_message, $headers);
|
|
// Second email to subscribe to the mailing list
|
|
// @mail("frank@nextcloud.org", "website form", "website form", $headers);
|
|
?>
|
|
|
|
|
|
<!-- success html here -->
|
|
<section class="section--whitepaper">
|
|
<div class="container text-center">
|
|
<h3>Thanks for letting us know you're providing Nextcloud to users!</h3>
|
|
<p>We will add you to the provider page in the next few weeks. Note that this can take a while, we're getting a lot of requests! If you have not been added within 4 weeks, <a href="/contact">contact us</a>.</p>
|
|
</div>
|
|
</section>
|
|
<?php
|
|
}
|
|
}
|
|
?>
|