• Log InLog In
  • Register
Liquid`
Team Liquid Liquipedia
EDT 00:15
CEST 06:15
KST 13:15
  • 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
[ASL19] Finals Recap: Standing Tall9HomeStory Cup 27 - Info & Preview18Classic wins Code S Season 2 (2025)16Code S RO4 & Finals Preview: herO, Rogue, Classic, GuMiho0TL Team Map Contest #5: Presented by Monster Energy6
Community News
Flash Announces Hiatus From ASL54Weekly Cups (June 23-29): Reynor in world title form?12FEL Cracov 2025 (July 27) - $8000 live event16Esports World Cup 2025 - Final Player Roster16Weekly Cups (June 16-22): Clem strikes back1
StarCraft 2
General
The SCII GOAT: A statistical Evaluation The GOAT ranking of GOAT rankings Statistics for vetoed/disliked maps How does the number of casters affect your enjoyment of esports? Esports World Cup 2025 - Final Player Roster
Tourneys
Korean Starcraft League Week 77 Master Swan Open (Global Bronze-Master 2) RSL: Revival, a new crowdfunded tournament series [GSL 2025] Code S: Season 2 - Semi Finals & Finals $5,100+ SEL Season 2 Championship (SC: Evo)
Strategy
How did i lose this ZvP, whats the proper response Simple Questions Simple Answers
Custom Maps
[UMS] Zillion Zerglings
External Content
Mutation # 480 Moths to the Flame Mutation # 479 Worn Out Welcome Mutation # 478 Instant Karma Mutation # 477 Slow and Steady
Brood War
General
Player “Jedi” cheat on CSL Flash Announces Hiatus From ASL BGH Auto Balance -> http://bghmmr.eu/ Unit and Spell Similarities Help: rep cant save
Tourneys
[Megathread] Daily Proleagues [BSL20] Grand Finals - Sunday 20:00 CET Small VOD Thread 2.0 [BSL20] GosuLeague RO16 - Tue & Wed 20:00+CET
Strategy
Simple Questions, Simple Answers I am doing this better than progamers do.
Other Games
General Games
Stormgate/Frost Giant Megathread Nintendo Switch Thread Path of Exile 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
US Politics Mega-thread Trading/Investing Thread Things Aren’t Peaceful in Palestine Russo-Ukrainian War Thread The Games Industry And ATVI
Fan Clubs
SKT1 Classic Fan Club! Maru Fan Club
Media & Entertainment
Anime Discussion Thread [Manga] One Piece [\m/] Heavy Metal Thread
Sports
Formula 1 Discussion 2024 - 2025 Football Thread NBA General Discussion TeamLiquid Health and Fitness Initiative For 2023 NHL Playoffs 2024
World Cup 2022
Tech Support
Computer Build, Upgrade & Buying Resource Thread
TL Community
Blogs
Culture Clash in Video Games…
TrAiDoS
from making sc maps to makin…
Husyelt
Blog #2
tankgirl
StarCraft improvement
iopq
Trip to the Zoo
micronesia
Customize Sidebar...

Website Feedback

Closed Threads



Active: 613 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
Korean StarCraft League
03:00
Week 77
davetesta95
EnkiAlexander 86
HKG_Chickenman67
IntoTheiNu 47
Liquipedia
[ Submit Event ]
Live Streams
Refresh
StarCraft 2
Nina 249
PiLiPiLi 14
StarCraft: Brood War
Sea 4826
NaDa 98
Dota 2
monkeys_forever599
NeuroSwarm130
febbydoto18
LuMiX1
League of Legends
JimRising 909
Heroes of the Storm
Khaldor44
Other Games
summit1g11866
WinterStarcraft500
Livibee153
Organizations
Other Games
BasetradeTV52
StarCraft: Brood War
UltimateBattle 6
StarCraft 2
Blizzard YouTube
StarCraft: Brood War
BSLTrovo
sctven
[ Show 16 non-featured ]
StarCraft 2
• Berry_CruncH282
• Hupsaiya 96
• IndyKCrew
• sooper7s
• AfreecaTV YouTube
• Migwel
• intothetv
• LaughNgamezSOOP
• Kozan
StarCraft: Brood War
• STPLYoutube
• ZZZeroYoutube
• BSLYoutube
League of Legends
• Doublelift4876
• Lourlo999
• Stunt358
• masondota2206
Upcoming Events
CranKy Ducklings
5h 45m
RSL Revival
5h 45m
ByuN vs Cham
herO vs Reynor
FEL
11h 45m
RSL Revival
1d 5h
Clem vs Classic
SHIN vs Cure
FEL
1d 7h
BSL: ProLeague
1d 13h
Dewalt vs Bonyth
Replay Cast
2 days
Sparkling Tuna Cup
3 days
The PondCast
4 days
Replay Cast
4 days
[ Show More ]
RSL Revival
5 days
Replay Cast
5 days
RSL Revival
6 days
Liquipedia Results

Completed

BSL 2v2 Season 3
HSC XXVII
Heroes 10 EU

Ongoing

JPL Season 2
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
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

Upcoming

2025 ACS Season 2: Qualifier
CSLPRO Last Chance 2025
2025 ACS Season 2
CSLPRO Chat StarLAN 3
K-Championship
uThermal 2v2 Main Event
SEL Season 2 Championship
FEL Cracov 2025
Esports World Cup 2025
StarSeries Fall 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.