Alliedassault           
FAQ Calendar
Go Back   Alliedassault > Lounge > Tech Questions & Problems
Reload this Page Utility for Admin's to share banned IP's with other Admin
Tech Questions & Problems Ask our resident experts about any military shooter game server administration and other technical issues.

Reply
 
Thread Tools Display Modes
Utility for Admin's to share banned IP's with other Admin
Old
  (#1)
[NBK] G.I. Jerk is Offline
Senior Member
 
Posts: 292
Join Date: Apr 2002
Location: Calgary, Ab. CanaDUH
 Send a message via ICQ to [NBK] G.I. Jerk Send a message via MSN to [NBK] G.I. Jerk  
Default Utility for Admin's to share banned IP's with other Admin - 08-27-2002, 11:41 AM

I've been writing a script (part batch, VBS, and hta) that would allow an Admin of a server to submit his list of banned IP's to a master list of banned IP's. The admin could then turn around and download a list of banned IP's that other Admin's have also submitted. The idea behind this I first thought of after reading about adminalliance.com. Basically I'm trying to make it so that if you TK on one adminalliance.com member's server and get banned, chances are you'll also be banned from ALL the admin alliance member's different servers if they use this utility I wrote. Be an asshole on one server, you're probably an asshole on them all correct?

I'll be putting out on the web tonight after I get off work, my first BETA release of this script, hoping that people will try it out and help me discover any bugs in the script. So far It's been tested under both win9x and winNT based OS's (incl XP pro). The CHOICE command in DOS is not available under WinXp-pro or Win 2000-Pro so CHOICE.com (win9x version) will be included with the script. ALSO the windows9x version of FTP.exe is used INSTEAD of the version you do have. The reason is for security. XP-pro and Win 2000's FTP.exe can't handle an IP translated into DWORD ie: 24.65.215.89 in DWORD translates to: 406968153. The reason I do this is because I don't want some banned clown probing my machine for open ports to seek revenge. Although this is FAR FROM failsafe, it does insure 99.99% of computer users wont have a clue how to find out what the server's IP really is.

The master list during the BETA testing phase will be maintained BY ME until such time as this script has been thuroughly tested. Once this trial and error period is over, it is my hope that adminalliance.com will carry forth my endevour on THEIR server so that THEY maintain the master list of TK'ing peons. If not, I guess I'll just have to be custodian of the master TK list from then on.

The script ONLY deals with banned IP's and NOT with banned names. Although I could have written the script to act on bad names, names are often not unique whereas IP addresses are and I wouldn't want to persecute the innocent MOHAA player for having the same name as some jerkoff.

Although I can write this script myself, as they say "two heads are better than one", so if there are any VBS, BATCHfile, or PERL (for linux version) script kids like myself who wish to help me make this better, please feel free to mail me ctrl_07@hotmail.com and join in on the project. Better yet... maybe someone is nice enough to actually "code" this idea into a win32 executable?

The script goes like this:....... (NOTE....some of the longer ECHO statements get botched cutting and pasting into this puny php window....it comes out fine in a DOS window)

1) Begone.bat...

@echo off

CLS
Echo.
Echo.
Echo.
Echo.
Echo.
Echo.
Echo.
echo.
echo ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ
echo Ü Ü
echo Ü Welcome to BeGone! Version 1.0 Ü
echo Ü Ü
echo Ü Time to kick to TK ASS! Ü
echo Ü Ü
echo ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ
echo.
echo.


::3 second INTRO screen
echo Wscript.Sleep 3000> sleep.vbs
start /w wscript.exe sleep.vbs
del sleep.vbs >nul



:check
::check for autokick

IF NOT EXIST "autokick.exe" GOTO notfind

goto begin

:notfind
CLS
ECHO.
ECHO You do not seem to have Autokick installed or this
ECHO batchfile isn't in the same directory as Autokick.
ECHO It MUST be run from the same directory as Autokick!
pause
goto finish

::check for ip entries in bannedip.txt. Since IP's have
::decimals, a FIND of "." will reveal IP's in the file.

:begin
FIND "." bannedip.txt >nul

::if user has a clean bannedip.txt file prompt him/her
::to download the latest master list of TK'ing goofs.

IF NOT ERRORLEVEL 1 goto putlist
goto blank

:blank
CLS
ECHO.
ECHO Autokick's bannedip.txt file seems to have no IP's in it.
ECHO.
ECHO Would you like to download the latest list of TK'ing morons?
ECHO Default YES in 10 seconds! Press Y for YES, N for NO
CHOICE /N /t:y,10
if errorlevel==2 goto finish
goto getlist

:putlist
CLS
Echo.
ECHO Would you like to submit your banned IP's to the master list?
Echo Default is YES in 10 seconds! Press Y for YES, N for NO
CHOICE /N /t:y,10
if errorlevel==2 goto update
goto sort1

:sort1

::this routine will weed out any blank lines in your bannedip.txt file
::and also occurances or two or more IP's on a single line of text.


FIND "." bannedip.txt >nul
IF NOT ERRORLEVEL 1 goto sort
goto endsort

:sort
set ip=
TYPE bannedip.txt|FIND "." | FIND /N "." >$temp$.bat
ECHO set ip=%%2 >[.bat
BFR "\5b1\5d" "\5b 1\5d " $temp$.bat -b >nul
CALL $temp$.bat
DEL $temp$.bat >nul
ECHO %ip% >>banned2.txt
BFR %ip% " " bannedip.txt -b >nul
goto sort1

:endsort
Del bannedip.txt >nul
TYPE banned2.txt|Sort >bannedip.txt
DEL banned2.txt >nul
DEL [.bat >nul
IF EXIST DEL $temp$.bat >nul
goto submit

:submit
IF EXIST 530.txt DEL 530.txt >nul

::Allowing a download of a list of morons is one thing....allowing just ANYONE to submit
::IP's to the list is asking for malicious abuse and mischief. Therefore we will only allow uploads of
::bannedip.txt to users with an account on the system. I create an .hta file (html application)
::that returns the inputed values as %USERNAME% and %PASSWORD%. These two variables are then echoed
::into the FTP upload script created below.

Call input.bat



ECHO ftp -s:putit.txt >putit.bat
ECHO open >putit.txt
ECHO 406968153 2101 >>putit.txt
ECHO %USERNAME% >>putit.txt
ECHO %PASSWORD% >>putit.txt
ECHO ascii >>putit.txt
ECHO put bannedip.txt >>putit.txt
ECHO bye >>putit.txt

::Call putit.bat and pipe it into FIND. If the login is incorrect the server will return code "530"
::This allows the script to detect bad logins and prompt the user to retype their username and password.

CALL putit.bat |FIND "530" >530.txt
type 530.txt | FIND "530"
IF NOT ERRORLEVEL 1 goto submit

:continue
DEL putit.txt >nul
DEL putit.bat >nul
IF EXIST DEL 530.txt >nul
CLS
ECHO.
ECHO Thank you for helping the MOHAA community!
ECHO.
goto update2

:update
CLS
ECHO.
:update2
Echo Would you now like to update your list with the banned IP's
Echo from master list on the server?
ECHO Default is YES in 10 seconds! Press Y for YES, N for NO
CHOICE /n /t:y,10
if errorlevel==2 goto finish
goto getlist

:getlist
ECHO ftp -s:getit.txt >getit.bat
ECHO open >getit.txt
ECHO 406968153 2101 >>getit.txt
ECHO admin >>getit.txt
ECHO admin@ >>getit.txt
ECHO ascii >>getit.txt
ECHO get master.txt >>getit.txt
ECHO bye >>getit.txt
CALL getit.bat
DEL getit.txt >nul
DEL getit.bat >nul



FC master.txt bannedip.txt |FIND "."|SORT >banned2.txt
BFR "Comparing files master.txt and BANNEDIP.TXT" "" banned2.txt -b >nul
BFR "***** BANNEDIP.TXT" "" banned2.txt -b >nul
BFR "***** master.txt" "" banned2.txt -b >nul
DEL bannedip.txt >nul
DEL master.txt >nul
REN banned2.txt bannedip.txt
goto sort2

::this opens up possibilities of duplicate IP entries so we'll rebuild
::the list using BRF to kill the duplicate entries.

:sort2


FIND "." bannedip.txt >nul
IF NOT ERRORLEVEL 1 goto resort
goto lastsort

:resort
set ip=
TYPE bannedip.txt|FIND "." | FIND /N "." >$temp$.bat
ECHO set ip=%%2 >[.bat
BFR "\5b1\5d" "\5b 1\5d " $temp$.bat -b >nul
CALL $temp$.bat
DEL $temp$.bat >nul
ECHO %ip% >>banned2.txt
BFR %ip% " " bannedip.txt -b >nul
goto sort2

:lastsort
Del bannedip.txt >nul
TYPE banned2.txt|Sort >bannedip.txt
DEL banned2.txt >nul
DEL [.bat >nul
IF EXIST DEL $temp$.bat >nul
goto finish



:finish
CLS
ECHO.
ECHO Would you like to start autokick with the new banned IP's?
ECHO.
CHOICE /N /C:yn Press Y for YES or N for NO.
if errorlevel==2 goto thanks
if errorlevel==1 goto startit

:startit
autokick.exe -a


:thanks
CLS
Echo.
Echo.
Echo.
Echo.
Echo.
Echo.
Echo.
echo.
echo ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ
echo Ü Thank you using for BeGone! Version 1.0 Ü
echo Ü Ü
echo Ü by Ü
echo Ü Ü
echo Ü ]NBK[ G.I. Jerk Ü
echo ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ ÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜÜ
echo.
echo.


::3 second EXIT screen
echo Wscript.Sleep 3000> sleep.vbs
start /w wscript.exe sleep.vbs
del sleep.vbs >nul
CLS



2)input.bat (creates the .hta authentification page)

cls
echo Please enter your user name and password in the entry box...
:: See if I can find myself
If not exist %0 goto ERROR
:: Make the web page
type %0 | find " " | find /v "Not Me!" > %TEMP%\UserIn.hta
:: Run the vbs code
start /w %TEMP%\UserIn.hta
:: At this point a batch file "%TEMP%\UserIn.bat" exists and you should
:: call it! If you don't call the batch file here and instead opt to
:: call it from another batch file, be sure NOT to delete it in the
:: "Clean up" code section below!
call %TEMP%\UserIn.bat
echo Your user name is %USERNAME%
echo Your password is %PASSWORD%

:: Clean up
del %TEMP%\UserIn.hta
del %TEMP%\UserIn.bat
pause
goto DONE

:ERROR
cls
echo %0 is not the full path and file name
echo for the batch file. You MUST call this
echo batch file with a full path and file name.
goto DONE

:HTA
:: All HTA code MUST be indented four or more spaces.
:: NOTHING else in this batch file may be indented four spaces.
<html>
<head>
<title>BeGone! v1.0 Password Entry</title>
<hta:application>
<script language="vbscript">
window.resizeTo 250,200
Sub SaveBatch()
Set fs = CreateObject("Scripting.FileSystemObject")
strFile = fs.GetAbsolutePathName(fs.BuildPath(fs.GetSpecialF older(2), "UserIn.bat"))
Set ts = fs.OpenTextFile(strFile, 2, True)
ts.WriteLine "SET USERNAME=" & document.Forms(0).elements("username").value
ts.WriteLine "SET PASSWORD=" & document.Forms(0).elements("password").value
ts.Close
End Sub
</script>
</head>
<body bgcolor="000000">
<font FACE="arial,veranda" COLOR="white">
<form>
User Name:

<input type=text name=username tabindex=1>

Password:

<input type=password name=password>

<input type=button language="vbscript" value="OK"
onclick="SaveBatch : Window.Close">
</form>
</font>
<script language=vbscript>
document.Forms(0).elements("username").focus
</script>
</body>
</html>

:DONE


Comment? Suggestions?


]NBK[ G.I. Jerk
  
Reply With Quote
Old
  (#2)
Bazooka_Joe is Offline
Senior Member
 
Posts: 12,585
Join Date: Jan 2002
Location: Staten Island, NY, USA
 Send a message via ICQ to Bazooka_Joe Send a message via AIM to Bazooka_Joe Send a message via MSN to Bazooka_Joe Send a message via Yahoo to Bazooka_Joe  
Default 08-27-2002, 03:45 PM

It's a great idea, but it should only be distributed to a group of trusted admins. If it gets in the hands of those "power-abusive" admins, who just like to add people to a ban list for getting too many kills, or for saying ass, etc. Then blocking these people on a wide variety of servers would be rather unjust and annoying.
  
Reply With Quote
Old
  (#3)
[NBK] G.I. Jerk is Offline
Senior Member
 
Posts: 292
Join Date: Apr 2002
Location: Calgary, Ab. CanaDUH
 Send a message via ICQ to [NBK] G.I. Jerk Send a message via MSN to [NBK] G.I. Jerk  
Default 08-27-2002, 07:17 PM

Yup, I agree fully. There's a good potential for abuse. One thing I was considering adding to this script (or rather the companion script that runs on the server to handle submitted IP's..ie sorting ...adding new IP's etc etc) would be to have each NEW IP submitted along with a date stamp.

The serverside script would look at the date that goes with each new IP and remove it from the "master list" after a week? 3 days? ...something along those lines. Just long enough for "punishment"...mwuahahahaha

I need a few trusted admins to help me test this.

I didn't plan of having every tom dick and harry using it for non-dedicated servers. It's more for the big time server admins. The 32 player, 24/7 type admins...like Ck...rudedog....whoever runs the 2 dozen barry's world servers...moheast west north and south too...lol. It's mostly for the dudes in the big leagues.

The way I see it, anyone who's gonna plunk down the big bucks for professional hosting is probably mature enough to handle the responsibility.

Since adminalliance.com isn't fully operational yet it's kinda hard to find responsible volunteers to test this out. I should probably get in touch with DOA and see what he thinks. I think that it should only be handed out to members in the "Alliance". That way he/we'd know who's doing what with it and help set the criteria for who gets it and who doesn't.

I hear what your saying Joe,... it would be a shame for someone to be banned "gamespy wide" for some trivial offence, but if there's on thing that really pisses me off it's leaving a good game because of TK's only to find the same clown on another server 1/2 an hour later.
  
Reply With Quote
Reply



Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off

Forum Jump



Powered by vBulletin® Version 3.8.12 by ScriptzBin
Copyright ©2000 - 2025, vBulletin Solutions Inc.
vBulletin Skin developed by: vBStyles.com
© 1998 - 2007 by Rudedog Productions | All trademarks used are properties of their respective owners. All rights reserved.