• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 09:20
CEST 15:20
KST 22:20
  • Home
  • Forum
  • Calendar
  • Streams
  • Liquipedia
  • Features
  • Store
  • EPT
  • TL+
  • StarCraft 2
  • Brood War
  • Smash
  • Heroes
  • Counter-Strike
  • Overwatch
  • Liquibet
  • Fantasy StarCraft
  • TLPD
  • StarCraft 2
  • Brood War
  • Blogs
Forum Sidebar
Events/Features
News
Featured News
HomeStory Cup 27 - Info & Preview17Classic wins Code S Season 2 (2025)16Code S RO4 & Finals Preview: herO, Rogue, Classic, GuMiho0TL Team Map Contest #5: Presented by Monster Energy6Code S RO8 Preview: herO, Zoun, Bunny, Classic7
Community News
FEL Cracov 2025 (July 27) - $8000 live event13Esports World Cup 2025 - Final Player Roster12Weekly Cups (June 16-22): Clem strikes back1Weekly Cups (June 9-15): herO doubles on GSL week4Firefly suspended by EWC, replaced by Lancer12
StarCraft 2
General
The SCII GOAT: A statistical Evaluation How to Recover Stolen Bitcoin: Why Recuva Hacker S Hybrid setting keep reverting. HomeStory Cup 27 - Info & Preview Esports World Cup 2025 - Final Player Roster
Tourneys
HomeStory Cup 27 (June 27-29) FEL Cracov 2025 (July 27) - $8000 live event $200 Biweekly - StarCraft Evolution League #1 SOOPer7s Showmatches 2025 RSL: Revival, a new crowdfunded tournament series
Strategy
How did i lose this ZvP, whats the proper response Simple Questions Simple Answers [G] Darkgrid Layout
Custom Maps
[UMS] Zillion Zerglings
External Content
Mutation # 479 Worn Out Welcome Mutation # 478 Instant Karma Mutation # 477 Slow and Steady Mutation # 476 Charnel House
Brood War
General
BW General Discussion Unit and Spell Similarities BGH Auto Balance -> http://bghmmr.eu/ NaDa's Body Soma Explains: JaeDong's Defense vs Bisu
Tourneys
[Megathread] Daily Proleagues [BSL20] ProLeague LB Final - Saturday 20:00 CET Small VOD Thread 2.0 [ASL19] Grand Finals
Strategy
Simple Questions, Simple Answers I am doing this better than progamers do. [G] How to get started on ladder as a new Z player
Other Games
General Games
Stormgate/Frost Giant Megathread Path of Exile Nintendo Switch Thread What do you want from future RTS games? Beyond All Reason
Dota 2
Official 'what is Dota anymore' discussion
League of Legends
Heroes of the Storm
Simple Questions, Simple Answers Heroes of the Storm 2.0
Hearthstone
Heroes of StarCraft mini-set
TL Mafia
TL Mafia Community Thread Vanilla Mini Mafia
Community
General
Trading/Investing Thread US Politics Mega-thread Russo-Ukrainian War Thread Things Aren’t Peaceful in Palestine Canadian Politics Mega-thread
Fan Clubs
SKT1 Classic Fan Club! Maru Fan Club
Media & Entertainment
[Manga] One Piece Anime Discussion Thread [\m/] Heavy Metal Thread Korean Music Discussion
Sports
NBA General Discussion 2024 - 2025 Football Thread TeamLiquid Health and Fitness Initiative For 2023 NHL Playoffs 2024 Formula 1 Discussion
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
The Automated Ban List
Blogs
Game Sound vs. Music: The Im…
TrAiDoS
StarCraft improvement
iopq
Heero Yuy & the Tax…
KrillinFromwales
I was completely wrong ab…
jameswatts
Need Your Help/Advice
Glider
Trip to the Zoo
micronesia
Customize Sidebar...

Website Feedback

Closed Threads



Active: 673 users

MafiaTools - Page 2

Forum Index > TL Mafia
Post a Reply
Prev 1 2 3 Next All
kushm4sta
Profile Blog Joined July 2011
United States8878 Posts
August 27 2014 21:01 GMT
#21
i dont have a mac
OMGUS.net, kush sex blogs every friday night
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 27 2014 21:02 GMT
#22
On August 28 2014 06:01 kushm4sta wrote:
i dont have a mac


Why did you talk about Mac stuff then? >.>
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
kushm4sta
Profile Blog Joined July 2011
United States8878 Posts
August 27 2014 21:04 GMT
#23
bad experiences with java not on my pc though. Mostly I talked about it because I was bored.
OMGUS.net, kush sex blogs every friday night
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 27 2014 21:08 GMT
#24
Haha k
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 27 2014 21:28 GMT
#25
Professor Apathy's first suggestion has been implemented. Sorry for any possible disturbances in the usage of the website.
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 27 2014 21:30 GMT
#26
(during the implementation of the new version just now, that is)
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
gonzaw
Profile Joined December 2011
Uruguay4911 Posts
Last Edited: 2014-08-28 03:18:26
August 28 2014 02:45 GMT
#27
Cool yo.

Suggestion (it's just small tiny stuff)

When you edit stuff about a player, the "points" thing is a <textarea>.
Change it to <input type="text">, or better yet to the new HTML5 stuff like this:
<input name="points" placeholder="Points" type="number" min="0"></input>

That way you get a better input box to put it (if you use "number" you even some mini buttons to increase it).

EDIT:

2)When you go back to the "Games" menu, or stuff like that, you need to redirect.
For instance, I try to access the next URL to delete a game (by pressing the "Delete" button for instance):
http://t-teesalmi.users.cs.helsinki.fi/MafiaTools/DeleteGame?id=29

However, after the game is deleted, I go back to the "Games" menu, yet the URL is exactly the same (it says "DeleteGame?id=29").
That means that when I hit Refresh, it goes back to that same URL. I.e it tries to delete the game I already deleted, which shows this nice little fella:
java.lang.NullPointerException
Servlets.DeleteGameServlet.processRequest(DeleteGameServlet.java:53)
Servlets.DeleteGameServlet.doGet(DeleteGameServlet.java:89)
javax.servlet.http.HttpServlet.service(HttpServlet.java:617)
javax.servlet.http.HttpServlet.service(HttpServlet.java:717)


Use "Redirect" instead of "Forward". I don't remember what you were using, but if you are using servlets and tomcat or stuff, then you did something like this:
request.getRequestDispatcher("games.jsp").forward(request,response);


I think you can use "response.sendRedirect(URL)" or "request.getRequestDispatcher(URL).forward(request,response)", where URL would be the servlet action (maybe "/Games"?)

Here's more info:
http://en.wikipedia.org/wiki/Post/Redirect/Get


3)I tried testing some security stuff. Didn't see entrances for SQL injection, which is good (at least when creating things)

4)You are vulnerable to CSRF requests:
http://en.wikipedia.org/wiki/Cross-site_request_forgery

For example, you have this URL here:
http://t-teesalmi.users.cs.helsinki.fi/MafiaTools/DeleteGame?id=2

Now, if I inadvertently press that link, nothing happens since I don't own a game with id 2 (and it even shows me a nifty "Stop hacking the database!" tag :D ). But imagine that the player that DOES own the game with id 2 clicks that link. It will automatically delete his own game, even when he didn't want to (he just randomly clicked a link).
I could make it more obtrusive than that, for instance by doing something like this:
Free titties! Click Now!
Now your user clicks there thinking of free titties, but inadvertently deletes his game (check the actual URL).

5)It's protected against XSS attacks, good.
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 28 2014 12:27 GMT
#28
That's a lot of stuff :D I'll look into it tonight.
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 28 2014 19:39 GMT
#29
1) Done.

2) Done.

3) Nice to know.

4) How to prevent this? Seems like kind of a niche / not so dangerous thing though You'd require the user to be logged in on his account + knowledge of which id numbers his created games have + lure him to click a link that points to one of those id numbers. I have difficulty imagining anyone pulling all that off...

5) Nice to know.

Thanks for the more technical suggestions
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
gonzaw
Profile Joined December 2011
Uruguay4911 Posts
August 29 2014 14:21 GMT
#30
On August 29 2014 04:39 Xatalos wrote:
4) How to prevent this? Seems like kind of a niche / not so dangerous thing though You'd require the user to be logged in on his account + knowledge of which id numbers his created games have + lure him to click a link that points to one of those id numbers. I have difficulty imagining anyone pulling all that off...


You just need to add random numbers, like adding links with numbers from 1 up to 100, and you can just wait for somebody to open them up.

With today's browser navigation, you can always expect someone to be already logged in, unless you make user's session expire (say, after 10 minutes of no interaction with the web site or something).

Yeah, doubt you'll get anything if you post it as a link in this forum. But there are other ways to do so.
Easy one:

Send every player from TL Mafia an email with this message body:
<img src="http://t-teesalmi.users.cs.helsinki.fi/MafiaTools/DeleteGame?id=2" width="1" height="1" border="0">


Surely all players will regularly check their email. Once the dude that owns game with id "2" reads the email, the browser automatically sends a request to that URL, deleting his game. The user doesnt' even have to press a link.

I mean...if someone wants to fuck up you website he WILL do it. Hackers are resourceful little whippersnappers like that. I guess it's not that important for this "toy" proyect, but it's a good lesson when you make bigger stuff. I mean, you don't want to find out that ALL the games from your website were deleted with such an attack, just because there was a bored dude that checked that site out and wanted to fuck it up.

To prevent it, check the "Prevention" section in the wikipedia article. It's easier if you use a framework that does that automatically for you. If not the easiest is to add that "authentication hidden field" to the form, and send it with the request. Then check it in the server, and if it matches the one that's on the server you delete the game, if not you don't.

Basically, it's like this:
User goes to page "Games", you generate a random value XXYY and send it in the page in a hidden field
User presses button "Delete Game", sending, in the form (or cookies, or even the URL as another parameter), the value XXYY
In the server, you check that the value you get from the request is the same as the one you got (XXYY). If it's the same, you delete the game, if not you send an error.
Now if you just randomly arrive at that link from another place (like the email above), you won't send the correct value token (that gets generated ONLY when you go to the "My Games" page), so you'll never be able to mistakenly delete your own games.
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 29 2014 18:50 GMT
#31
On August 29 2014 23:21 gonzaw wrote:
Show nested quote +
On August 29 2014 04:39 Xatalos wrote:
4) How to prevent this? Seems like kind of a niche / not so dangerous thing though You'd require the user to be logged in on his account + knowledge of which id numbers his created games have + lure him to click a link that points to one of those id numbers. I have difficulty imagining anyone pulling all that off...


You just need to add random numbers, like adding links with numbers from 1 up to 100, and you can just wait for somebody to open them up.

With today's browser navigation, you can always expect someone to be already logged in, unless you make user's session expire (say, after 10 minutes of no interaction with the web site or something).

Yeah, doubt you'll get anything if you post it as a link in this forum. But there are other ways to do so.
Easy one:

Send every player from TL Mafia an email with this message body:
Show nested quote +
<img src="http://t-teesalmi.users.cs.helsinki.fi/MafiaTools/DeleteGame?id=2" width="1" height="1" border="0">


Surely all players will regularly check their email. Once the dude that owns game with id "2" reads the email, the browser automatically sends a request to that URL, deleting his game. The user doesnt' even have to press a link.

I mean...if someone wants to fuck up you website he WILL do it. Hackers are resourceful little whippersnappers like that. I guess it's not that important for this "toy" proyect, but it's a good lesson when you make bigger stuff. I mean, you don't want to find out that ALL the games from your website were deleted with such an attack, just because there was a bored dude that checked that site out and wanted to fuck it up.

To prevent it, check the "Prevention" section in the wikipedia article. It's easier if you use a framework that does that automatically for you. If not the easiest is to add that "authentication hidden field" to the form, and send it with the request. Then check it in the server, and if it matches the one that's on the server you delete the game, if not you don't.

Basically, it's like this:
User goes to page "Games", you generate a random value XXYY and send it in the page in a hidden field
User presses button "Delete Game", sending, in the form (or cookies, or even the URL as another parameter), the value XXYY
In the server, you check that the value you get from the request is the same as the one you got (XXYY). If it's the same, you delete the game, if not you send an error.
Now if you just randomly arrive at that link from another place (like the email above), you won't send the correct value token (that gets generated ONLY when you go to the "My Games" page), so you'll never be able to mistakenly delete your own games.


I guess it's impossible to make my website 100% secure with my current knowledge (if it's even possible for any website since even government/bank websites are hacked into). I'm satisfied if it's hard enough to hack that it can't be just done on any random moment of boredom

I'll look into your suggestion.
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
gonzaw
Profile Joined December 2011
Uruguay4911 Posts
August 30 2014 00:54 GMT
#32
Yeah no problem. Surely you can add more and better stuff to your website instead of wasting time on this. Just keep it in mind if this ever gets big


Here are some suggestions which might be easy to do and could improve it, at least aesthetically:
In the "Game" page, have a little reference that says something like this:
"0 points = Confirmed Scum
1-2 points = Very scummy
3 points = Scummy
4 points = Leaning scum
5 points = Null
6 points = Leaning town
7 points = Townie
8-9 points = Super townie
10 points = Confirmed Town"

Now what you do, is add a little text next to each "score". Whenever a user changes the score of someone else to, say, 7 points, put the "Townie" text next to it, and paint both "Townie" and "7" green. If he changes it to 2, then change the text to "Very scummy" and change both of them to red.
You can have variant shades of red, green, and grey, depending on the points that player has.

It's relatively easy to do (you don't have to change the database, add new pages, etc), but it can increase the usability. Because if not, users will just be looking at a huge blob of numbers and players and won't really understand what's going on, or won't really "feel" their reads coming through this point system. But a simple color system can catch a user's eye more quickly and be more pleasant to the eye
Xatalos
Profile Joined January 2011
Finland9675 Posts
August 30 2014 19:29 GMT
#33
On August 30 2014 09:54 gonzaw wrote:
Yeah no problem. Surely you can add more and better stuff to your website instead of wasting time on this. Just keep it in mind if this ever gets big


Here are some suggestions which might be easy to do and could improve it, at least aesthetically:
In the "Game" page, have a little reference that says something like this:
"0 points = Confirmed Scum
1-2 points = Very scummy
3 points = Scummy
4 points = Leaning scum
5 points = Null
6 points = Leaning town
7 points = Townie
8-9 points = Super townie
10 points = Confirmed Town"

Now what you do, is add a little text next to each "score". Whenever a user changes the score of someone else to, say, 7 points, put the "Townie" text next to it, and paint both "Townie" and "7" green. If he changes it to 2, then change the text to "Very scummy" and change both of them to red.
You can have variant shades of red, green, and grey, depending on the points that player has.

It's relatively easy to do (you don't have to change the database, add new pages, etc), but it can increase the usability. Because if not, users will just be looking at a huge blob of numbers and players and won't really understand what's going on, or won't really "feel" their reads coming through this point system. But a simple color system can catch a user's eye more quickly and be more pleasant to the eye


That's an idea worth considering. However, there's one problem with that: I wouldn't want to limit the usage of the points too much? Different users might want to use the points differently. Well, maybe that would just be more simple, so much so that it would outweigh the disadvantages of losing customization...
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Xatalos
Profile Joined January 2011
Finland9675 Posts
September 01 2014 00:15 GMT
#34
Well, if there are any more suggestions, please post them here / PM me. Not sure if I'll be able to focus that much on this project for the following weeks, since my studies will be starting now, but at least small changes should be doable on a quick schedule. Ultimately I'm not sure if this website is *that* useful compared to just a plain text file / spreadsheet... But perhaps some players will find uses for it
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
The_Templar
Profile Blog Joined January 2011
your Country52797 Posts
Last Edited: 2014-09-03 19:55:51
September 03 2014 19:53 GMT
#35
Hey. I'm trying to register on mafiatools but it's telling me every username I type is already taken. This includes The_Templar, TehTemplar, and The Templar, among other IDs I go by on other forums. There is no way these are all taken. (Some of my usernames also involve random-looking letters or obscure words)

The usernames I have tried are:
The_Templar
TehTemplar
The Templar
Lord Molyb
Lord Molybdenum
GalacticShovel
TemporaryWorker
TemplarTemp
Moderatorshe/her
TL+ Member
Blazinghand *
Profile Blog Joined December 2010
United States25551 Posts
September 03 2014 20:09 GMT
#36
oh, sorry, I made a bunch of accounts on it with those names
When you stare into the iCCup, the iCCup stares back.
TL+ Member
The_Templar
Profile Blog Joined January 2011
your Country52797 Posts
September 03 2014 20:17 GMT
#37
On September 04 2014 05:09 Blazinghand wrote:
oh, sorry, I made a bunch of accounts on it with those names

Seems legit.
Moderatorshe/her
TL+ Member
Xatalos
Profile Joined January 2011
Finland9675 Posts
September 03 2014 22:41 GMT
#38
On September 04 2014 04:53 The_Templar wrote:
Hey. I'm trying to register on mafiatools but it's telling me every username I type is already taken. This includes The_Templar, TehTemplar, and The Templar, among other IDs I go by on other forums. There is no way these are all taken. (Some of my usernames also involve random-looking letters or obscure words)

The usernames I have tried are:
The_Templar
TehTemplar
The Templar
Lord Molyb
Lord Molybdenum
GalacticShovel
TemporaryWorker
TemplarTemp


Are you sure you're not confusing the alert messages with each other? If it says "The username 'The_Templar' is already in use!" then it's already taken, but if it says something like "User 'testa' has been registered!" then it was successful. Did you try to log in on those accounts? I think you might have just created a bunch of accounts
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Xatalos
Profile Joined January 2011
Finland9675 Posts
September 03 2014 22:43 GMT
#39
I admit the success message might be a bit confusing...
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Xatalos
Profile Joined January 2011
Finland9675 Posts
September 04 2014 16:25 GMT
#40
I searched for the usernames in the database and it looks like you successfully created those accounts. Just try logging in
"The opportunity to secure ourselves against defeat lies in our own hands, but the opportunity of defeating the enemy is provided by the enemy himself." - Sun Tzu
Prev 1 2 3 Next All
Please log in or register to reply.
Live Events Refresh
HomeStory Cup
11:00
XXVII: Day 2
TaKeTV 2879
ComeBackTV 844
IndyStarCraft 330
CranKy Ducklings275
Rex116
3DClanTV 82
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
IndyStarCraft 330
Rex 116
StarCraft: Brood War
Britney 38438
Calm 9690
Rain 2823
Flash 2116
Shuttle 1999
Horang2 1740
Bisu 1660
Soma 850
Hyuk 512
BeSt 404
[ Show more ]
actioN 308
Soulkey 255
Last 206
Rush 140
GuemChi 137
Bonyth 70
TY 68
Killer 60
Noble 45
Backho 32
Free 29
Movie 28
sorry 26
Shinee 26
[sc1f]eonzerg 24
GoRush 20
NaDa 16
zelot 15
soO 15
Shine 14
IntoTheRainbow 14
ajuk12(nOOB) 13
SilentControl 13
Light 11
Icarus 8
Yoon 7
HiyA 5
Terrorterran 1
Dota 2
Gorgc5814
XcaliburYe340
Fuzer 185
febbydoto9
LuMiX1
Heroes of the Storm
Khaldor291
Other Games
singsing1850
B2W.Neo888
DeMusliM421
EnDerr1
Organizations
Dota 2
PGL Dota 2 - Main Stream24655
StarCraft: Brood War
CasterMuse 28
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 14 non-featured ]
StarCraft 2
• AfreecaTV YouTube
• intothetv
• Kozan
• IndyKCrew
• LaughNgamezSOOP
• Migwel
• sooper7s
StarCraft: Brood War
• Michael_bg 5
• BSLYoutube
• STPLYoutube
• ZZZeroYoutube
Dota 2
• C_a_k_e 1796
• Ler77
League of Legends
• Nemesis2492
Upcoming Events
CSO Cup
2h 40m
BSL: ProLeague
4h 40m
Hawk vs Dewalt
SOOP
19h 40m
SHIN vs ByuN
HomeStory Cup
22h 40m
BSL: ProLeague
1d 4h
Replay Cast
2 days
Replay Cast
2 days
WardiTV European League
3 days
The PondCast
3 days
RSL Revival
4 days
[ Show More ]
WardiTV European League
5 days
RSL Revival
5 days
Korean StarCraft League
6 days
CranKy Ducklings
6 days
RSL Revival
6 days
Liquipedia Results

Completed

Rose Open S1
2025 GSL S2
Heroes 10 EU

Ongoing

JPL Season 2
BSL 2v2 Season 3
BSL Season 20
Acropolis #3
KCM Race Survival 2025 Season 2
CSL 17: 2025 SUMMER
Copa Latinoamericana 4
Championship of Russia 2025
RSL Revival: Season 1
HSC XXVII
Murky Cup #2
BLAST.tv Austin Major 2025
ESL Impact League Season 7
IEM Dallas 2025
PGL Astana 2025
Asian Champions League '25
BLAST Rivals Spring 2025
MESA Nomadic Masters
CCT Season 2 Global Finals
IEM Melbourne 2025
YaLLa Compass Qatar 2025

Upcoming

CSLPRO Last Chance 2025
CSLPRO Chat StarLAN 3
K-Championship
uThermal 2v2 Main Event
SEL Season 2 Championship
FEL Cracov 2025
Esports World Cup 2025
FISSURE Playground #2
BLAST Open Fall 2025
BLAST Open Fall Qual
Esports World Cup 2025
BLAST Bounty Fall 2025
BLAST Bounty Fall Qual
IEM Cologne 2025
FISSURE Playground #1
TLPD

1. ByuN
2. TY
3. Dark
4. Solar
5. Stats
6. Nerchio
7. sOs
8. soO
9. INnoVation
10. Elazer
1. Rain
2. Flash
3. EffOrt
4. Last
5. Bisu
6. Soulkey
7. Mini
8. Sharp
Sidebar Settings...

Advertising | Privacy Policy | Terms Of Use | Contact Us

Original banner artwork: Jim Warren
The contents of this webpage are copyright © 2025 TLnet. All Rights Reserved.