Skip to content

Commit

Permalink
initial
Browse files Browse the repository at this point in the history
  • Loading branch information
ciruz committed Nov 12, 2013
0 parents commit 38e0d6b
Show file tree
Hide file tree
Showing 7 changed files with 407 additions and 0 deletions.
22 changes: 22 additions & 0 deletions .gitattributes
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
# Auto detect text files and perform LF normalization
* text=auto

# Custom for Visual Studio
*.cs diff=csharp
*.sln merge=union
*.csproj merge=union
*.vbproj merge=union
*.fsproj merge=union
*.dbproj merge=union

# Standard to msysgit
*.doc diff=astextplain
*.DOC diff=astextplain
*.docx diff=astextplain
*.DOCX diff=astextplain
*.dot diff=astextplain
*.DOT diff=astextplain
*.pdf diff=astextplain
*.PDF diff=astextplain
*.rtf diff=astextplain
*.RTF diff=astextplain
215 changes: 215 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,215 @@
#################
## Eclipse
#################

*.pydevproject
.project
.metadata
bin/
tmp/
*.tmp
*.bak
*.swp
*~.nib
local.properties
.classpath
.settings/
.loadpath

# External tool builders
.externalToolBuilders/

# Locally stored "Eclipse launch configurations"
*.launch

# CDT-specific
.cproject

# PDT-specific
.buildpath


#################
## Visual Studio
#################

## Ignore Visual Studio temporary files, build results, and
## files generated by popular Visual Studio add-ons.

# User-specific files
*.suo
*.user
*.sln.docstates

# Build results

[Dd]ebug/
[Rr]elease/
x64/
build/
[Bb]in/
[Oo]bj/

# MSTest test Results
[Tt]est[Rr]esult*/
[Bb]uild[Ll]og.*

*_i.c
*_p.c
*.ilk
*.meta
*.obj
*.pch
*.pdb
*.pgc
*.pgd
*.rsp
*.sbr
*.tlb
*.tli
*.tlh
*.tmp
*.tmp_proj
*.log
*.vspscc
*.vssscc
.builds
*.pidb
*.log
*.scc

# Visual C++ cache files
ipch/
*.aps
*.ncb
*.opensdf
*.sdf
*.cachefile

# Visual Studio profiler
*.psess
*.vsp
*.vspx

# Guidance Automation Toolkit
*.gpState

# ReSharper is a .NET coding add-in
_ReSharper*/
*.[Rr]e[Ss]harper

# TeamCity is a build add-in
_TeamCity*

# DotCover is a Code Coverage Tool
*.dotCover

# NCrunch
*.ncrunch*
.*crunch*.local.xml

# Installshield output folder
[Ee]xpress/

# DocProject is a documentation generator add-in
DocProject/buildhelp/
DocProject/Help/*.HxT
DocProject/Help/*.HxC
DocProject/Help/*.hhc
DocProject/Help/*.hhk
DocProject/Help/*.hhp
DocProject/Help/Html2
DocProject/Help/html

# Click-Once directory
publish/

# Publish Web Output
*.Publish.xml
*.pubxml

# NuGet Packages Directory
## TODO: If you have NuGet Package Restore enabled, uncomment the next line
#packages/

# Windows Azure Build Output
csx
*.build.csdef

# Windows Store app package directory
AppPackages/

# Others
sql/
*.Cache
ClientBin/
[Ss]tyle[Cc]op.*
~$*
*~
*.dbmdl
*.[Pp]ublish.xml
*.pfx
*.publishsettings

# RIA/Silverlight projects
Generated_Code/

# Backup & report files from converting an old project file to a newer
# Visual Studio version. Backup files are not needed, because we have git ;-)
_UpgradeReport_Files/
Backup*/
UpgradeLog*.XML
UpgradeLog*.htm

# SQL Server files
App_Data/*.mdf
App_Data/*.ldf

#############
## Windows detritus
#############

# Windows image file caches
Thumbs.db
ehthumbs.db

# Folder config file
Desktop.ini

# Recycle Bin used on file shares
$RECYCLE.BIN/

# Mac crap
.DS_Store


#############
## Python
#############

*.py[co]

# Packages
*.egg
*.egg-info
dist/
build/
eggs/
parts/
var/
sdist/
develop-eggs/
.installed.cfg

# Installer logs
pip-log.txt

# Unit test / coverage reports
.coverage
.tox

#Translations
*.mo

#Mr Developer
.mr.developer.cfg
Binary file added Honeypot/icon.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Empty file added Honeypot/index.html
Empty file.
102 changes: 102 additions & 0 deletions Honeypot/plugin.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,102 @@
<?php
// Copyright 2013 ciruz
if (!defined("IN_ESOTALK")) exit;

ET::$pluginInfo["Honeypot"] = array(
"name" => "Honeypot",
"description" => "Spam prevention with invisible form fields.",
"version" => "0.1",
"author" => "ciruz",
"authorEmail" => "[email protected]",
"authorURL" => "http://www.ciruz.net",
"license" => "MIT"
);

class ETPlugin_Honeypot extends ETPlugin {

public function userController_join($sender){
/**
* Honeypot Protection Start
*/
//hide first input with css, set second & third input to small (document ready isn't always as fast as users eye)
$css = '<style type="text/css">.form > li.etphp1{display:none;}.form > li.etphp2,.form > li.etphp3{height:1px;}</style>';
$sender->addToHead($css);

//hide second & third input with js
$js = '<script>$(document).ready(function(){ $(".etphp2,.etphp3").css("display", "none"); });</script>';
$sender->addToHead($js);

//write a simple hash to session
if(!ET::$session->get('securityHash'))
ET::$session->store('securityHash', md5(time()));
/**
* Honeypot Protection End
*/

if (ET::$session->user) $sender->redirect(URL(""));

if (!C("esoTalk.registration.open")) {
$sender->renderMessage(T("Registration Closed"), T("message.registrationClosed"));
return;
}

$sender->title = T("Sign Up");
$sender->addToHead("<meta name='robots' content='noindex, noarchive'/>");

$form = ETFactory::make("form");
$form->action = URL("user/join");

if ($form->isPostBack("cancel")) $sender->redirect(URL(R("return")));

if ($form->validPostBack("submit")) {

/* Honeypot Protection Start */
//hidden field "zipcode" has a value OR hidden security hash got changed
if($form->getValue('zipcode') != '' || ($form->getValue('phone') != ET::$session->get('securityHash')) || $form->getValue('homepage') != '')
$sender->redirect(URL("")); //redirect to startpage
/* Honeypot Protection End */

if ($form->getValue("password") != $form->getValue("confirm"))
$form->error("confirm", T("message.passwordsDontMatch"));

if (!$form->errorCount()) {

$data = array(
"username" => $form->getValue("username"),
"email" => $form->getValue("email"),
"password" => $form->getValue("password"),
"account" => ACCOUNT_MEMBER
);

if (!C("esoTalk.registration.requireEmailConfirmation")) $data["confirmedEmail"] = true;
else $data["resetPassword"] = md5(uniqid(rand()));

$model = ET::memberModel();
$memberId = $model->create($data);

if ($model->errorCount()) $form->errors($model->errors());

else {

if (C("esoTalk.registration.requireEmailConfirmation")) {
$sender->sendConfirmationEmail($data["email"], $data["username"], $memberId.$data["resetPassword"]);
$sender->renderMessage(T("Success!"), T("message.confirmEmail"));
}

else {
ET::$session->login($form->getValue("username"), $form->getValue("password"));
$sender->redirect(URL(""));
}

return;

}

}

}

$sender->data("form", $form);
$sender->render($this->getResource("join.php"));
}
}
Loading

0 comments on commit 38e0d6b

Please sign in to comment.