diff options
Diffstat (limited to 'phpBB')
167 files changed, 984 insertions, 385 deletions
| diff --git a/phpBB/adm/style/acp_attachments.html b/phpBB/adm/style/acp_attachments.html index 950e9bb6f9..ee3f8ec354 100644 --- a/phpBB/adm/style/acp_attachments.html +++ b/phpBB/adm/style/acp_attachments.html @@ -16,7 +16,7 @@  		<p>{WARNING_MSG}</p>  	</div>  <!-- ENDIF --> -	 +  <!-- IF S_NOTIFY -->  	<div class="successbox">  		<h3>{L_NOTIFY}</h3> @@ -216,7 +216,7 @@  		</p>  		</fieldset> - +		{S_FORM_TOKEN}  		</form>  	<!-- ELSE --> @@ -258,6 +258,7 @@  				<input class="button2" name="add" type="submit" value="{L_SUBMIT}" />  		</p>  		</fieldset> +		{S_FORM_TOKEN}  		</form>  	<!-- ENDIF --> @@ -280,7 +281,7 @@  		<input type="submit" id="add_extension_check" name="add_extension_check" class="button2" value="{L_SUBMIT}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  	<br /> @@ -320,7 +321,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> -	 +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_ORPHAN --> @@ -368,7 +369,7 @@  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_bbcodes.html b/phpBB/adm/style/acp_bbcodes.html index 8d9827b672..48b117cfc9 100644 --- a/phpBB/adm/style/acp_bbcodes.html +++ b/phpBB/adm/style/acp_bbcodes.html @@ -77,7 +77,7 @@  	<!-- END token -->  	</tbody>  	</table> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -111,7 +111,7 @@  		<input class="button2" name="submit" type="submit" value="{L_ADD_BBCODE}" />  	</p>  	</fieldset> - +{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_board.html b/phpBB/adm/style/acp_board.html index c7501ce088..2569b162ca 100644 --- a/phpBB/adm/style/acp_board.html +++ b/phpBB/adm/style/acp_board.html @@ -45,6 +45,7 @@  </fieldset> +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html --> diff --git a/phpBB/adm/style/acp_bots.html b/phpBB/adm/style/acp_bots.html index 2f65a0fbec..92778472d8 100644 --- a/phpBB/adm/style/acp_bots.html +++ b/phpBB/adm/style/acp_bots.html @@ -51,7 +51,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -94,7 +94,7 @@  		<input class="button2" name="submit" type="submit" value="{L_SUBMIT}" />  		<p class="small"><a href="#" onclick="marklist('acp_bots', 'mark', true);">{L_MARK_ALL}</a> • <a href="#" onclick="marklist('acp_bots', 'mark', false);">{L_UNMARK_ALL}</a></p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_captcha.html b/phpBB/adm/style/acp_captcha.html index b5c12f29b1..ecb60e4b59 100644 --- a/phpBB/adm/style/acp_captcha.html +++ b/phpBB/adm/style/acp_captcha.html @@ -64,7 +64,7 @@  	<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />   	<input class="button2" type="submit" id="preview" name="preview" value="{L_PREVIEW}" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html --> diff --git a/phpBB/adm/style/acp_database.html b/phpBB/adm/style/acp_database.html index fcb79920fc..dc24b55bb1 100644 --- a/phpBB/adm/style/acp_database.html +++ b/phpBB/adm/style/acp_database.html @@ -25,6 +25,7 @@  	<!-- ENDIF -->  	</fieldset> +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -85,7 +86,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_disallow.html b/phpBB/adm/style/acp_disallow.html index e9d6cb6c51..020135e227 100644 --- a/phpBB/adm/style/acp_disallow.html +++ b/phpBB/adm/style/acp_disallow.html @@ -39,7 +39,7 @@  	<p>{L_NO_DISALLOWED}</p>  <!-- ENDIF -->  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html --> diff --git a/phpBB/adm/style/acp_email.html b/phpBB/adm/style/acp_email.html index b2c12c944d..bb891de0b4 100644 --- a/phpBB/adm/style/acp_email.html +++ b/phpBB/adm/style/acp_email.html @@ -48,7 +48,7 @@  	<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  </p>  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html --> diff --git a/phpBB/adm/style/acp_forums.html b/phpBB/adm/style/acp_forums.html index 802cd81815..ee83beacf3 100644 --- a/phpBB/adm/style/acp_forums.html +++ b/phpBB/adm/style/acp_forums.html @@ -312,7 +312,7 @@  		<input class="button1" type="submit" id="submit" name="update" value="{L_SUBMIT}" />   		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_DELETE_FORUM --> @@ -361,7 +361,7 @@  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_CONTINUE_SYNC --> @@ -470,7 +470,7 @@  		<input class="button2" type="submit" value="{L_GO}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  	<form id="forums" method="post" action="{U_ACTION}"> @@ -481,7 +481,7 @@  		<input type="text" name="forum_name" value="" maxlength="255" />  		<input class="button2" name="addforum" type="submit" value="{L_CREATE_FORUM}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_groups.html b/phpBB/adm/style/acp_groups.html index f1b4c4ecaa..b615099b7c 100644 --- a/phpBB/adm/style/acp_groups.html +++ b/phpBB/adm/style/acp_groups.html @@ -155,7 +155,7 @@  		<input class="button1" type="submit" id="submit" name="update" value="{L_SUBMIT}" />   		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_LIST --> @@ -261,7 +261,7 @@  		<input class="button2" type="submit" name="addusers" value="{L_SUBMIT}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -310,7 +310,7 @@  			<input type="hidden" name="add" value="1" />  		<!-- ENDIF -->  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  	<h1>{L_SPECIAL_GROUPS}</h1> diff --git a/phpBB/adm/style/acp_icons.html b/phpBB/adm/style/acp_icons.html index 6a8db53f08..e02840f1c5 100644 --- a/phpBB/adm/style/acp_icons.html +++ b/phpBB/adm/style/acp_icons.html @@ -160,7 +160,7 @@  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_CHOOSE_PAK --> @@ -195,7 +195,7 @@  	</p>  	<!-- ENDIF -->  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -257,7 +257,7 @@  		<input class="button2" name="add" type="submit" value="{L_ICON_ADD}" />   <input class="button2" type="submit" name="edit" value="{L_ICON_EDIT}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_inactive.html b/phpBB/adm/style/acp_inactive.html index dc447d00fc..b5a05ec799 100755 --- a/phpBB/adm/style/acp_inactive.html +++ b/phpBB/adm/style/acp_inactive.html @@ -65,7 +65,7 @@ - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/adm/style/acp_jabber.html b/phpBB/adm/style/acp_jabber.html index 43f7f51375..b57ad59af5 100644 --- a/phpBB/adm/style/acp_jabber.html +++ b/phpBB/adm/style/acp_jabber.html @@ -59,7 +59,7 @@  	<input class="button1" type="submit" id="submit" name="submit" value="{L_SUBMIT}" />   	<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html --> diff --git a/phpBB/adm/style/acp_language.html b/phpBB/adm/style/acp_language.html index c016251d38..a6f99c2b56 100644 --- a/phpBB/adm/style/acp_language.html +++ b/phpBB/adm/style/acp_language.html @@ -55,7 +55,7 @@  		<input type="submit" name="update_details" class="button2" value="{L_SUBMIT}" />  	</p>  	</fieldset> -	 +	{S_FORM_TOKEN}  	</form>  	<br /><br /> @@ -92,7 +92,7 @@  		<!-- END missing -->  		</tbody>  		</table> - +		{S_FORM_TOKEN}  		</form>  		<br /><br /> @@ -161,7 +161,7 @@  	</tr>  	</tbody>  	</table> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_UPLOAD --> @@ -201,7 +201,7 @@  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  		<input class="button1" type="submit" name="test_connection" value="{L_TEST_CONNECTION}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> diff --git a/phpBB/adm/style/acp_logs.html b/phpBB/adm/style/acp_logs.html index e18c4882c5..cc1765e2a4 100644 --- a/phpBB/adm/style/acp_logs.html +++ b/phpBB/adm/style/acp_logs.html @@ -79,7 +79,7 @@  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/adm/style/acp_modules.html b/phpBB/adm/style/acp_modules.html index cae5781c8d..729ac56c5e 100644 --- a/phpBB/adm/style/acp_modules.html +++ b/phpBB/adm/style/acp_modules.html @@ -116,7 +116,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> diff --git a/phpBB/adm/style/acp_permission_roles.html b/phpBB/adm/style/acp_permission_roles.html index 80b1003003..f6ca6081aa 100644 --- a/phpBB/adm/style/acp_permission_roles.html +++ b/phpBB/adm/style/acp_permission_roles.html @@ -125,7 +125,7 @@  	<fieldset class="quick">  		<input type="submit" class="button1" name="submit" value="{L_SUBMIT}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  	<a href="#maincontent">» {L_BACK_TO_TOP}</a><br /> @@ -179,7 +179,7 @@  	<fieldset class="quick">  		{L_CREATE_ROLE}: <input type="text" name="role_name" value="" maxlength="255" /><!-- IF S_ROLE_OPTIONS --> <select name="options_from"><option value="0" selected="selected">{L_CREATE_ROLE_FROM}</option>{S_ROLE_OPTIONS}</select><!-- ENDIF --> <input class="button2" type="submit" name="add" value="{L_SUBMIT}" /><br />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  	<!-- IF S_DISPLAY_ROLE_MASK --> diff --git a/phpBB/adm/style/acp_permissions.html b/phpBB/adm/style/acp_permissions.html index d30a38e697..a4797fcc4f 100644 --- a/phpBB/adm/style/acp_permissions.html +++ b/phpBB/adm/style/acp_permissions.html @@ -39,7 +39,7 @@  		</p>  		</fieldset> - +		{S_FORM_TOKEN}  		</form>  		<!-- IF S_FORUM_MULTIPLE --> @@ -60,7 +60,7 @@  			</p>  			</fieldset> - +			{S_FORM_TOKEN}  			</form>  		<!-- ENDIF --> @@ -83,7 +83,7 @@  			<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  		</p>  		</fieldset> - +		{S_FORM_TOKEN}  		</form>  	<!-- ELSEIF S_SELECT_GROUP and S_CAN_SELECT_GROUP --> @@ -103,7 +103,7 @@  		</p>  		</fieldset> - +		{S_FORM_TOKEN}  		</form>  		<!-- ELSEIF S_SELECT_USERGROUP --> @@ -128,7 +128,7 @@  				{S_HIDDEN_FIELDS}  				<input type="submit" class="button2" name="action[delete]" value="{L_REMOVE_PERMISSIONS}" style="width: 46% !important;" />   <input class="button1" type="submit" name="submit_edit_options" value="{L_EDIT_PERMISSIONS}" style="width: 46% !important;" />  			</fieldset> -			 +			{S_FORM_TOKEN}  			</form>  			<form id="add_user" method="post" action="{U_ACTION}"> @@ -146,7 +146,7 @@  				{S_HIDDEN_FIELDS}  				<input class="button1" type="submit" name="submit_add_options" value="{L_ADD_PERMISSIONS}" />  			</fieldset> -			 +			{S_FORM_TOKEN}  			</form>  		<!-- ENDIF --> @@ -173,7 +173,7 @@  				{S_HIDDEN_FIELDS}  				<input class="button2" type="submit" name="action[delete]" value="{L_REMOVE_PERMISSIONS}" style="width: 46% !important;" />   <input class="button1" type="submit" name="submit_edit_options" value="{L_EDIT_PERMISSIONS}" style="width: 46% !important;" />  			</fieldset> -			 +			{S_FORM_TOKEN}  			</form>  			<form id="add_groups" method="post" action="{U_ACTION}"> @@ -190,6 +190,7 @@  				<input type="submit" class="button1" name="submit_add_options" value="{L_ADD_PERMISSIONS}" />  			</fieldset> +			{S_FORM_TOKEN}  			</form>  		<!-- ENDIF --> @@ -216,6 +217,7 @@  				<input class="button1" type="submit" name="submit" value="{L_VIEW_PERMISSIONS}" />  			</fieldset> +			{S_FORM_TOKEN}  			</form>  			<form id="add_user" method="post" action="{U_ACTION}"> @@ -234,7 +236,7 @@  				{S_HIDDEN_FIELDS}  				<input type="submit" name="submit" value="{L_VIEW_PERMISSIONS}" class="button1" />  			</fieldset> - +			{S_FORM_TOKEN}  			</form>  		</div> @@ -257,6 +259,7 @@  				<input class="button1" type="submit" name="submit" value="{L_VIEW_PERMISSIONS}" />  			</fieldset> +			{S_FORM_TOKEN}  			</form>  			<form id="group" method="post" action="{U_ACTION}"> @@ -275,6 +278,7 @@  				<input type="submit" name="submit" value="{L_VIEW_PERMISSIONS}" class="button1" />  			</fieldset> +			{S_FORM_TOKEN}  			</form>  		</div> @@ -318,7 +322,7 @@  			<input class="button2" type="submit" name="submit" value="{L_GO}" />  		</fieldset> -	 +		{S_FORM_TOKEN}	  		</form>  	<!-- ENDIF --> @@ -346,7 +350,8 @@  	</fieldset>  	<br /><br /> - +	 +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_profile.html b/phpBB/adm/style/acp_profile.html index bd9f0cc9a0..912e58b43c 100644 --- a/phpBB/adm/style/acp_profile.html +++ b/phpBB/adm/style/acp_profile.html @@ -156,7 +156,7 @@  		</fieldset>  	<!-- ENDIF --> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -217,7 +217,7 @@  		<input class="button1" type="submit" name="submit" value="{L_CREATE_NEW_FIELD}" />  		<input type="hidden" name="create" value="1" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_prune_forums.html b/phpBB/adm/style/acp_prune_forums.html index 8d8f913b53..14a367ce27 100644 --- a/phpBB/adm/style/acp_prune_forums.html +++ b/phpBB/adm/style/acp_prune_forums.html @@ -101,7 +101,7 @@  		<input class="button1" type="submit" id="submit" name="submit" value="{L_SUBMIT}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_prune_users.html b/phpBB/adm/style/acp_prune_users.html index 9a2926df7f..7d84146267 100644 --- a/phpBB/adm/style/acp_prune_users.html +++ b/phpBB/adm/style/acp_prune_users.html @@ -53,7 +53,7 @@  	<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  </p>  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html --> diff --git a/phpBB/adm/style/acp_ranks.html b/phpBB/adm/style/acp_ranks.html index 0bc8636f7d..482fbcb02c 100644 --- a/phpBB/adm/style/acp_ranks.html +++ b/phpBB/adm/style/acp_ranks.html @@ -52,7 +52,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -90,7 +90,7 @@  		<input class="button2" name="add" type="submit" value="{L_ADD_RANK}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_reasons.html b/phpBB/adm/style/acp_reasons.html index 3ad32e7d39..221a776a24 100644 --- a/phpBB/adm/style/acp_reasons.html +++ b/phpBB/adm/style/acp_reasons.html @@ -54,7 +54,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -118,7 +118,8 @@  		<input class="button2" name="addreason" type="submit" value="{L_ADD_NEW_REASON}" />  	</p>  	</fieldset> - +	 +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_search.html b/phpBB/adm/style/acp_search.html index 9afe9c5789..d4937c6ecc 100644 --- a/phpBB/adm/style/acp_search.html +++ b/phpBB/adm/style/acp_search.html @@ -61,6 +61,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</fieldset> +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_INDEX --> @@ -90,6 +91,7 @@  				<input class="button1" type="submit" id="continue" name="continue" value="{L_CONTINUE}" onclick="popup_progress_bar('{S_CONTINUE_INDEXING}');" />   				<input class="button2" type="submit" id="cancel" name="cancel" value="{L_CANCEL}" />  			</fieldset> +		{S_FORM_TOKEN}  		</form>  	<!-- ELSE --> @@ -140,7 +142,7 @@  			<!-- ENDIF -->  			</p>  			</fieldset> - +			{S_FORM_TOKEN}  			</form>  		<!-- END backend --> diff --git a/phpBB/adm/style/acp_styles.html b/phpBB/adm/style/acp_styles.html index 0908c19480..a067e1a16b 100644 --- a/phpBB/adm/style/acp_styles.html +++ b/phpBB/adm/style/acp_styles.html @@ -27,7 +27,7 @@  		<input class="button1" type="submit" name="update" value="{L_DELETE}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_EDIT_IMAGESET --> @@ -148,7 +148,7 @@  		<legend>{L_SUBMIT}</legend>  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  <input class="button2" type="reset" value="{L_RESET}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_EDIT_TEMPLATE or S_EDIT_THEME --> @@ -172,7 +172,8 @@  	</dl>  	</fieldset>  	<!-- ENDIF --> - +	 +	{S_FORM_TOKEN}  	</form>  	<!-- IF TEMPLATE_FILE or (S_EDIT_THEME and S_THEME_IN_DB) --> @@ -254,7 +255,8 @@  			{S_HIDDEN_FIELDS}  			<input class="button1" id="save" type="submit" name="save" value="{L_SUBMIT}" />  		</fieldset> - +		 +		{S_FORM_TOKEN}  		</form>  	<!-- ENDIF --> @@ -304,6 +306,7 @@  	</p>  	</fieldset> +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_EXPORT --> @@ -361,6 +364,7 @@  	</p>  	</fieldset> +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_FRONTEND --> @@ -505,7 +509,8 @@  		<legend>{L_SUBMIT}</legend>  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</fieldset> - +	 +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_users.html b/phpBB/adm/style/acp_users.html index cc369bab66..593889e7d1 100644 --- a/phpBB/adm/style/acp_users.html +++ b/phpBB/adm/style/acp_users.html @@ -47,7 +47,7 @@  	<fieldset class="quick">  		<input type="submit" name="update" value="{L_SUBMIT}" class="button1" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -70,7 +70,7 @@  	<fieldset class="quick">  		{L_SELECT_FORM}: <select name="mode" onchange="if (this.options[this.selectedIndex].value != '') this.form.submit();">{S_FORM_OPTIONS}</select> <input class="button2" type="submit" value="{L_GO}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> @@ -110,7 +110,7 @@  	<fieldset class="quick">  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_SIGNATURE --> @@ -145,7 +145,7 @@  			{L_USER_GROUP_ADD}: <select name="g">{S_GROUP_OPTIONS}</select> <input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  		</fieldset>  	<!-- ENDIF --> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_ATTACHMENTS --> @@ -202,7 +202,7 @@  		<input class="button2" type="submit" name="delmarked" value="{L_DELETE_MARKED}" />  		<p class="small"><a href="#" onclick="marklist('user_attachments', 'mark', true);">{L_MARK_ALL}</a> • <a href="#" onclick="marklist('user_attachments', 'mark', false);">{L_UNMARK_ALL}</a></p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_PERMISSIONS --> @@ -218,7 +218,7 @@  			{L_SELECT_FORUM}: <select name="f">{S_FORUM_OPTIONS}</select>   			<input class="button2" type="submit" value="{L_GO}" name="select" />  		</fieldset> - +	{S_FORM_TOKEN}  	</form>  	<div class="clearfix"> </div> diff --git a/phpBB/adm/style/acp_users_avatar.html b/phpBB/adm/style/acp_users_avatar.html index c2590ebca0..2b5745ebb6 100644 --- a/phpBB/adm/style/acp_users_avatar.html +++ b/phpBB/adm/style/acp_users_avatar.html @@ -71,5 +71,6 @@  	<fieldset class="quick">  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</fieldset> - +	 +	{S_FORM_TOKEN}  	</form>
\ No newline at end of file diff --git a/phpBB/adm/style/acp_users_feedback.html b/phpBB/adm/style/acp_users_feedback.html index e1d4076e4d..e11a8e6ec1 100644 --- a/phpBB/adm/style/acp_users_feedback.html +++ b/phpBB/adm/style/acp_users_feedback.html @@ -72,5 +72,5 @@  	<fieldset class="quick">  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>
\ No newline at end of file diff --git a/phpBB/adm/style/acp_users_overview.html b/phpBB/adm/style/acp_users_overview.html index 2dfb82e52f..da699968c5 100644 --- a/phpBB/adm/style/acp_users_overview.html +++ b/phpBB/adm/style/acp_users_overview.html @@ -64,7 +64,7 @@  </p>  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- IF not S_USER_FOUNDER or S_FOUNDER --> @@ -137,7 +137,8 @@  	</p>  	</fieldset> - +	 +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/adm/style/acp_users_prefs.html b/phpBB/adm/style/acp_users_prefs.html index 1dfa6a614b..b8b847bd14 100644 --- a/phpBB/adm/style/acp_users_prefs.html +++ b/phpBB/adm/style/acp_users_prefs.html @@ -154,4 +154,5 @@  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</fieldset> +	{S_FORM_TOKEN}  	</form>
\ No newline at end of file diff --git a/phpBB/adm/style/acp_users_profile.html b/phpBB/adm/style/acp_users_profile.html index 6a50887141..959494f5e3 100644 --- a/phpBB/adm/style/acp_users_profile.html +++ b/phpBB/adm/style/acp_users_profile.html @@ -63,4 +63,5 @@  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />  	</fieldset> +	{S_FORM_TOKEN}  	</form>
\ No newline at end of file diff --git a/phpBB/adm/style/acp_users_signature.html b/phpBB/adm/style/acp_users_signature.html index 9d6b8d11e9..e51b5ab68d 100644 --- a/phpBB/adm/style/acp_users_signature.html +++ b/phpBB/adm/style/acp_users_signature.html @@ -113,5 +113,5 @@  		<input class="button1" type="submit" name="update" value="{L_SUBMIT}" />   		<input class="button2" type="submit" name="preview" value="{L_PREVIEW}" />  	</fieldset> - +{S_FORM_TOKEN}  </form>
\ No newline at end of file diff --git a/phpBB/adm/style/acp_words.html b/phpBB/adm/style/acp_words.html index 055a616f70..3f99637418 100644 --- a/phpBB/adm/style/acp_words.html +++ b/phpBB/adm/style/acp_words.html @@ -29,7 +29,7 @@  		<input class="button2" type="reset" id="reset" name="reset" value="{L_RESET}" />  	</p>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -67,7 +67,7 @@  	</table>  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/develop/create_schema_files.php b/phpBB/develop/create_schema_files.php index 5d974639b1..34ac224c9c 100644 --- a/phpBB/develop/create_schema_files.php +++ b/phpBB/develop/create_schema_files.php @@ -1842,6 +1842,8 @@ function get_schema_struct()  			'user_interests'			=> array('TEXT_UNI', ''),  			'user_actkey'				=> array('VCHAR:32', ''),  			'user_newpasswd'			=> array('VCHAR_UNI:32', ''), +			'user_form_salt'			=> array('VCHAR_UNI:32', ''), +  		),  		'PRIMARY_KEY'	=> 'user_id',  		'KEYS'			=> array( @@ -2020,4 +2022,6 @@ EOF;  	return '';  } +echo 'done'; +  ?>
\ No newline at end of file diff --git a/phpBB/includes/acp/acp_attachments.php b/phpBB/includes/acp/acp_attachments.php index ae4eb9bc1a..7f85542264 100644 --- a/phpBB/includes/acp/acp_attachments.php +++ b/phpBB/includes/acp/acp_attachments.php @@ -27,6 +27,14 @@ class acp_attachments  		$submit = (isset($_POST['submit'])) ? true : false;  		$action = request_var('action', ''); +		$form_key = 'acp_attach'; +		add_form_key($form_key); + +		if ($submit && !check_form_key($form_key)) +		{ +			trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING); +		} +  		switch ($mode)  		{  			case 'attach': diff --git a/phpBB/includes/acp/acp_ban.php b/phpBB/includes/acp/acp_ban.php index f5669b2c04..5871710702 100644 --- a/phpBB/includes/acp/acp_ban.php +++ b/phpBB/includes/acp/acp_ban.php @@ -23,11 +23,18 @@ class acp_ban  		include($phpbb_root_path . 'includes/functions_user.' . $phpEx);  		$bansubmit	= (isset($_POST['bansubmit'])) ? true : false; -		$unbansubmit= (isset($_POST['unbansubmit'])) ? true : false; +		$unbansubmit = (isset($_POST['unbansubmit'])) ? true : false;  		$current_time = time();  		$user->add_lang(array('acp/ban', 'acp/users'));  		$this->tpl_name = 'acp_ban'; +		$form_key = 'acp_ban'; +		add_form_key($form_key); + +		if(($bansubmit || $unbansubmit) && !check_form_key($form_key)) +		{ +			trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING); +		}  		// Ban submitted?  		if ($bansubmit) diff --git a/phpBB/includes/acp/acp_bbcodes.php b/phpBB/includes/acp/acp_bbcodes.php index 235028fc3c..1eaec67e89 100644 --- a/phpBB/includes/acp/acp_bbcodes.php +++ b/phpBB/includes/acp/acp_bbcodes.php @@ -28,6 +28,9 @@ class acp_bbcodes  		$this->tpl_name = 'acp_bbcodes';  		$this->page_title = 'ACP_BBCODES'; +		$form_key = 'acp_bbcodes'; + +		add_form_key($form_key);  		// Set up mode-specific vars  		switch ($action) diff --git a/phpBB/includes/acp/acp_board.php b/phpBB/includes/acp/acp_board.php index 7cee81ffe2..a2d91e9196 100644 --- a/phpBB/includes/acp/acp_board.php +++ b/phpBB/includes/acp/acp_board.php @@ -27,6 +27,9 @@ class acp_board  		$action	= request_var('action', '');  		$submit = (isset($_POST['submit'])) ? true : false; +		$form_key = 'acp_board'; +		add_form_key($form_key); +  		/**  		*	Validation types are:  		*		string, int, bool, @@ -314,6 +317,8 @@ class acp_board  						'chg_passforce'			=> array('lang' => 'FORCE_PASS_CHANGE',		'validate' => 'int',	'type' => 'text:3:3', 'explain' => true, 'append' => ' ' . $user->lang['DAYS']),  						'max_login_attempts'	=> array('lang' => 'MAX_LOGIN_ATTEMPTS',	'validate' => 'int',	'type' => 'text:3:3', 'explain' => true),  						'tpl_allow_php'			=> array('lang' => 'TPL_ALLOW_PHP',			'validate' => 'bool',	'type' => 'radio:yes_no', 'explain' => true), +						'form_token_lifetime'	=> array('lang' => 'FORM_TIME_MAX',			'validate' => 'int',	'type' => 'text:5:5', 'explain' => true, 'append' => ' ' . $user->lang['SECONDS']), +						'form_token_mintime'	=> array('lang' => 'FORM_TIME_MIN',			'validate' => 'int',	'type' => 'text:5:5', 'explain' => true, 'append' => ' ' . $user->lang['SECONDS']),  					)  				);  			break; @@ -360,6 +365,10 @@ class acp_board  		// We validate the complete config if whished  		validate_config_vars($display_vars['vars'], $cfg_array, $error); +		if ($submit && !check_form_key($form_key)) +		{ +			$error[] = $user->lang['FORM_INVALID']; +		}  		// Do not write values if there is an error  		if (sizeof($error))  		{ diff --git a/phpBB/includes/acp/acp_bots.php b/phpBB/includes/acp/acp_bots.php index 93108c7fec..50458718ba 100644 --- a/phpBB/includes/acp/acp_bots.php +++ b/phpBB/includes/acp/acp_bots.php @@ -35,6 +35,13 @@ class acp_bots  		$user->add_lang('acp/bots');  		$this->tpl_name = 'acp_bots';  		$this->page_title = 'ACP_BOTS'; +		$form_key = 'acp_bots'; +		add_form_key($form_key); + +		if ($submit && !check_form_key($form_key)) +		{ +			$error[] = $user->lang['FORM_INVALID']; +		}  		// User wants to do something, how inconsiderate of them!  		switch ($action) diff --git a/phpBB/includes/acp/acp_captcha.php b/phpBB/includes/acp/acp_captcha.php index 496f66e4f9..80b6b625e3 100644 --- a/phpBB/includes/acp/acp_captcha.php +++ b/phpBB/includes/acp/acp_captcha.php @@ -57,9 +57,12 @@ class acp_captcha  		$this->tpl_name = 'acp_captcha';  		$this->page_title = 'ACP_VC_SETTINGS'; +		$form_key = 'acp_captcha'; +		add_form_key($form_key); +  		$submit = request_var('submit', ''); -		 -		if ($submit) + +		if ($submit && check_form_key($form_key))  		{  			$config_vars = array_keys($config_vars);  			foreach ($config_vars as $config_var) @@ -73,6 +76,10 @@ class acp_captcha  			}  			trigger_error($user->lang['CONFIG_UPDATED'] . adm_back_link($this->u_action));  		} +		else if ($submit) +		{ +				trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action)); +		}  		else  		{ diff --git a/phpBB/includes/acp/acp_disallow.php b/phpBB/includes/acp/acp_disallow.php index 4be61ad778..0423c4cc38 100644 --- a/phpBB/includes/acp/acp_disallow.php +++ b/phpBB/includes/acp/acp_disallow.php @@ -28,9 +28,17 @@ class acp_disallow  		$this->tpl_name = 'acp_disallow';  		$this->page_title = 'ACP_DISALLOW_USERNAMES'; +		$form_key = 'acp_disallow'; +		add_form_key($form_key); +  		$disallow = (isset($_POST['disallow'])) ? true : false;  		$allow = (isset($_POST['allow'])) ? true : false; +		if (($allow || $disallow) && !check_form_key($form_key)) +		{ +			trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING); +		} +  		if ($disallow)  		{  			$disallowed_user = str_replace('*', '%', utf8_normalize_nfc(request_var('disallowed_user', '', true))); diff --git a/phpBB/includes/acp/acp_email.php b/phpBB/includes/acp/acp_email.php index cc7c99c90b..7598b729c4 100644 --- a/phpBB/includes/acp/acp_email.php +++ b/phpBB/includes/acp/acp_email.php @@ -24,6 +24,9 @@ class acp_email  		$this->tpl_name = 'acp_email';  		$this->page_title = 'ACP_MASS_EMAIL'; +		$form_key = 'acp_email'; +		add_form_key($form_key); +  		// Set some vars  		$submit = (isset($_POST['submit'])) ? true : false;  		$error = array(); @@ -41,6 +44,11 @@ class acp_email  			$use_queue		= (isset($_POST['send_immediately'])) ? false : true;  			$priority		= request_var('mail_priority_flag', MAIL_NORMAL_PRIORITY); +			if (!check_form_key($form_key)) +			{ +				$error[] = $user->lang['FORM_INVALID']; +			} +  			if (!$subject)  			{  				$error[] = $user->lang['NO_EMAIL_SUBJECT']; diff --git a/phpBB/includes/acp/acp_forums.php b/phpBB/includes/acp/acp_forums.php index 446c67011d..521eafe437 100644 --- a/phpBB/includes/acp/acp_forums.php +++ b/phpBB/includes/acp/acp_forums.php @@ -25,6 +25,9 @@ class acp_forums  		$this->tpl_name = 'acp_forums';  		$this->page_title = 'ACP_MANAGE_FORUMS'; +		$form_key = 'acp_forums'; +		add_form_key($form_key); +  		$action		= request_var('action', '');  		$update		= (isset($_POST['update'])) ? true : false;  		$forum_id	= request_var('f', 0); @@ -33,6 +36,12 @@ class acp_forums  		$forum_data = $errors = array(); +		if ($update && !check_form_key($form_key)) +		{ +			$update = false; +			$error[] = $user->lang['FORM_INVALID']; +		} +  		// Check additional permissions  		switch ($action)  		{ diff --git a/phpBB/includes/acp/acp_groups.php b/phpBB/includes/acp/acp_groups.php index 6c8591818c..a024a55a81 100644 --- a/phpBB/includes/acp/acp_groups.php +++ b/phpBB/includes/acp/acp_groups.php @@ -24,6 +24,9 @@ class acp_groups  		$this->tpl_name = 'acp_groups';  		$this->page_title = 'ACP_GROUPS_MANAGE'; +		$form_key = 'acp_groups'; +		add_form_key($form_key); +  		include($phpbb_root_path . 'includes/functions_user.' . $phpEx);  		// Check and set some common vars @@ -36,6 +39,7 @@ class acp_groups  		$start		= request_var('start', 0);  		$update		= (isset($_POST['update'])) ? true : false; +  		// Clear some vars  		$can_upload = (file_exists($phpbb_root_path . $config['avatar_path']) && @is_writable($phpbb_root_path . $config['avatar_path']) && $file_uploads) ? true : false;  		$group_row = array(); @@ -251,13 +255,18 @@ class acp_groups  				$error = array();  				$user->add_lang('ucp'); -			 +  				$avatar_select = basename(request_var('avatar_select', ''));  				$category = basename(request_var('category', ''));  				// Did we submit?  				if ($update)  				{ +					if (!check_form_key($form_key)) +					{ +						trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING); +					} +  					$group_name	= utf8_normalize_nfc(request_var('group_name', '', true));  					$group_desc = utf8_normalize_nfc(request_var('group_desc', '', true));  					$group_type	= request_var('group_type', GROUP_FREE); diff --git a/phpBB/includes/acp/acp_inactive.php b/phpBB/includes/acp/acp_inactive.php index a3eefdfaba..59b5a3d6e2 100755 --- a/phpBB/includes/acp/acp_inactive.php +++ b/phpBB/includes/acp/acp_inactive.php @@ -33,14 +33,23 @@ class acp_inactive  		$action = request_var('action', '');  		$mark	= (isset($_REQUEST['mark'])) ? request_var('mark', array(0)) : array();  		$start	= request_var('start', 0); +		$submit = isset($_POST['submit']);  		// Sort keys  		$sort_days	= request_var('st', 0);  		$sort_key	= request_var('sk', 'i');  		$sort_dir	= request_var('sd', 'd'); -		if (sizeof($mark)) +		$form_key = 'acp_inactive'; +		add_form_key($form_key); + +		if ($submit && sizeof($mark))  		{ +			if (!check_form_key($form_key)) +			{ +				trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action), E_USER_WARNING); +			} +  			switch ($action)  			{  				case 'activate': diff --git a/phpBB/includes/acp/acp_jabber.php b/phpBB/includes/acp/acp_jabber.php index b1580a0736..0878a3cd40 100644 --- a/phpBB/includes/acp/acp_jabber.php +++ b/phpBB/includes/acp/acp_jabber.php @@ -44,8 +44,16 @@ class acp_jabber  		$jab_package_size	= request_var('jab_package_size', $config['jab_package_size']);  		$jab_use_ssl		= request_var('jab_use_ssl', $config['jab_use_ssl']); +		$form_name = 'acp_jabber'; +		add_form_key($form_name); +  		if ($submit)  		{ +			if(!check_form_key($form_name)) +			{ +				trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +			} +  			$error = array();  			$message = $user->lang['JAB_SETTINGS_CHANGED']; diff --git a/phpBB/includes/acp/acp_language.php b/phpBB/includes/acp/acp_language.php index 71def79433..4246cc5a63 100644 --- a/phpBB/includes/acp/acp_language.php +++ b/phpBB/includes/acp/acp_language.php @@ -32,14 +32,19 @@ class acp_language  		$this->default_variables();  		// Check and set some common vars -		$action		= request_var('action', ''); -		$action		= (isset($_POST['update_details'])) ? 'update_details' : $action; -		$action		= (isset($_POST['download_file'])) ? 'download_file' : $action; -		$action		= (isset($_POST['upload_file'])) ? 'upload_file' : $action; -		$action		= (isset($_POST['upload_data'])) ? 'upload_data' : $action; -		$action		= (isset($_POST['submit_file'])) ? 'submit_file' : $action; -		$action		= (isset($_POST['remove_store'])) ? 'details' : $action; +		$action		= (isset($_POST['update_details'])) ? 'update_details' : ''; +		$action		= (isset($_POST['download_file'])) ? 'download_file' : ''; +		$action		= (isset($_POST['upload_file'])) ? 'upload_file' : ''; +		$action		= (isset($_POST['upload_data'])) ? 'upload_data' : ''; +		$action		= (isset($_POST['submit_file'])) ? 'submit_file' : ''; +		$action		= (isset($_POST['remove_store'])) ? 'details' : ''; + +		$submit = (empty($action)) ? false : true; +		$action = (empty($action)) ? request_var('action', '') : $action; + +		$form_name = 'acp_lang'; +		add_form_key('acp_lang');  		$lang_id = request_var('id', 0);  		if (isset($_POST['missing_file'])) @@ -59,7 +64,7 @@ class acp_language  		$this->tpl_name = 'acp_language';  		$this->page_title = 'ACP_LANGUAGE_PACKS'; -		if ($action == 'upload_data' && request_var('test_connection', '')) +		if ($submit && $action == 'upload_data' && request_var('test_connection', ''))  		{  			$test_connection = false;  			$action = 'upload_file'; @@ -89,6 +94,7 @@ class acp_language  		switch ($action)  		{  			case 'upload_file': +  				include_once($phpbb_root_path . 'includes/functions_transfer.' . $phpEx);  				$method = request_var('method', ''); @@ -132,6 +138,11 @@ class acp_language  			case 'update_details': +				if(!$submit || !check_form_key($form_name)) +				{ +					trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +				} +  				if (!$lang_id)  				{  					trigger_error($user->lang['NO_LANG_ID'] . adm_back_link($this->u_action), E_USER_WARNING); @@ -162,6 +173,11 @@ class acp_language  			case 'submit_file':  			case 'download_file':  			case 'upload_data': +				 +				if(!$submit || !check_form_key($form_name)) +				{ +					trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +				}  				if (!$lang_id || empty($_POST['entry']))  				{ diff --git a/phpBB/includes/acp/acp_permission_roles.php b/phpBB/includes/acp/acp_permission_roles.php index 57fd4c1ea5..ea21f52da7 100644 --- a/phpBB/includes/acp/acp_permission_roles.php +++ b/phpBB/includes/acp/acp_permission_roles.php @@ -35,6 +35,9 @@ class acp_permission_roles  		$action = request_var('action', '');  		$action = (isset($_POST['add'])) ? 'add' : $action; +		$form_name = 'acp_permissions'; +		add_form_key($form_name); +  		switch ($mode)  		{  			case 'admin_roles': @@ -134,6 +137,11 @@ class acp_permission_roles  				case 'add': +					if(!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +					} +  					$role_name = utf8_normalize_nfc(request_var('role_name', '', true));  					$role_description = utf8_normalize_nfc(request_var('role_description', '', true));  					$auth_settings = request_var('setting', array('' => 0)); diff --git a/phpBB/includes/acp/acp_permissions.php b/phpBB/includes/acp/acp_permissions.php index 4b06d2edad..f171d43c39 100644 --- a/phpBB/includes/acp/acp_permissions.php +++ b/phpBB/includes/acp/acp_permissions.php @@ -46,7 +46,6 @@ class acp_permissions  				$this->permission_trace($user_id, $forum_id, $permission);  				return;  			} -			  			trigger_error('NO_MODE', E_USER_ERROR);  		} @@ -66,6 +65,9 @@ class acp_permissions  		$group_id = request_var('group_id', array(0));  		$select_all_groups = request_var('select_all_groups', 0); +		$form_name = 'acp_permissions'; +		add_form_key($form_name); +  		// If select all groups is set, we pre-build the group id array (this option is used for other screens to link to the permission settings screen)  		if ($select_all_groups)  		{ @@ -214,6 +216,11 @@ class acp_permissions  			switch ($action)  			{  				case 'delete': + +					if(!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +					}  					// All users/groups selected?  					$all_users = (isset($_POST['all_users'])) ? true : false;  					$all_groups = (isset($_POST['all_groups'])) ? true : false; @@ -247,6 +254,10 @@ class acp_permissions  					{  						trigger_error($user->lang['NO_AUTH_SETTING_FOUND'] . adm_back_link($this->u_action), E_USER_WARNING);  					} +					if(!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +					}  					$this->set_permissions($mode, $permission_type, $auth_admin, $user_id, $group_id);  				break; @@ -256,6 +267,10 @@ class acp_permissions  					{  						trigger_error($user->lang['NO_AUTH_SETTING_FOUND'] . adm_back_link($this->u_action), E_USER_WARNING);  					} +					if(!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +					}  					$this->set_all_permissions($mode, $permission_type, $auth_admin, $user_id, $group_id);  				break; diff --git a/phpBB/includes/acp/acp_ranks.php b/phpBB/includes/acp/acp_ranks.php index 950a645487..a01d30c7ab 100644 --- a/phpBB/includes/acp/acp_ranks.php +++ b/phpBB/includes/acp/acp_ranks.php @@ -31,10 +31,17 @@ class acp_ranks  		$this->tpl_name = 'acp_ranks';  		$this->page_title = 'ACP_MANAGE_RANKS'; +		$form_name = 'acp_prune'; +		add_form_key($form_name); +  		switch ($action)  		{  			case 'save': -				 + +				if(!check_form_key($form_name)) +				{ +					trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +				}  				$rank_title = utf8_normalize_nfc(request_var('title', '', true));  				$special_rank = request_var('special_rank', 0);  				$min_posts = ($special_rank) ? 0 : request_var('min_posts', 0); @@ -124,6 +131,11 @@ class acp_ranks  			case 'edit':  			case 'add': +				if(!check_form_key($form_name)) +				{ +					trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +				} +  				$data = $ranks = $existing_imgs = array();  				$sql = 'SELECT *  diff --git a/phpBB/includes/acp/acp_reasons.php b/phpBB/includes/acp/acp_reasons.php index ca9fbcb806..ec6fadcecf 100644 --- a/phpBB/includes/acp/acp_reasons.php +++ b/phpBB/includes/acp/acp_reasons.php @@ -30,6 +30,9 @@ class acp_reasons  		$this->tpl_name = 'acp_reasons';  		$this->page_title = 'ACP_REASONS'; +		$form_name = 'acp_reason'; +		add_form_key('acp_reason'); +  		$error = array();  		switch ($action) @@ -44,6 +47,10 @@ class acp_reasons  				if ($submit)  				{ +					if(!check_form_key($form_name)) +					{ +						$error[] = $user->lang['FORM_INVALID']; +					}  					// Reason specified?  					if (!$reason_row['reason_title'] || !$reason_row['reason_description'])  					{ diff --git a/phpBB/includes/acp/acp_users.php b/phpBB/includes/acp/acp_users.php index e854e64dad..a7764a5d6e 100644 --- a/phpBB/includes/acp/acp_users.php +++ b/phpBB/includes/acp/acp_users.php @@ -37,6 +37,9 @@ class acp_users  		$submit		= (isset($_POST['update'])) ? true : false; +		$form_name = 'acp_users'; +		add_form_key($form_name); +  		// Whois (special case)  		if ($action == 'whois')  		{ @@ -218,6 +221,11 @@ class acp_users  								trigger_error($user->lang['CANNOT_BAN_FOUNDER'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING);  							} +							if (!check_form_key($form_name)) +							{ +								trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +							} +  							$ban = array();  							switch ($action) @@ -270,6 +278,11 @@ class acp_users  								trigger_error($user->lang['CANNOT_FORCE_REACT_YOURSELF'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING);  							} +							if (!check_form_key($form_name)) +							{ +								trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +							} +  							if ($user_row['user_type'] == USER_FOUNDER)  							{  								trigger_error($user->lang['CANNOT_FORCE_REACT_FOUNDER'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); @@ -337,6 +350,11 @@ class acp_users  								trigger_error($user->lang['CANNOT_DEACTIVATE_YOURSELF'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING);  							} +							if (!check_form_key($form_name)) +							{ +								trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +							} +  							if ($user_row['user_type'] == USER_FOUNDER)  							{  								trigger_error($user->lang['CANNOT_DEACTIVATE_FOUNDER'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); @@ -361,6 +379,11 @@ class acp_users  						case 'delsig': +							if (!check_form_key($form_name)) +							{ +								trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +							} +  							$sql_ary = array(  								'user_sig'					=> '',  								'user_sig_bbcode_uid'		=> '', @@ -379,7 +402,12 @@ class acp_users  						break;  						case 'delavatar': -							 + +							if (!check_form_key($form_name)) +							{ +								trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +							} +  							$sql_ary = array(  								'user_avatar'			=> '',  								'user_avatar_type'		=> 0, @@ -451,6 +479,11 @@ class acp_users  						case 'moveposts': +							if (!check_form_key($form_name)) +							{ +								trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +							} +  							$user->add_lang('acp/forums');  							$new_forum_id = request_var('new_f', 0); @@ -654,6 +687,11 @@ class acp_users  						$error[] = 'NEW_EMAIL_ERROR';  					} +					if (!check_form_key($form_name)) +					{ +						$error[] = 'FORM_INVALID'; +					} +  					// Which updates do we need to do?  					$update_username = ($user_row['username'] != $data['username']) ? $data['username'] : false;  					$update_password = ($data['new_password'] && $user_row['user_password'] != md5($data['new_password'])) ? true : false; @@ -882,6 +920,11 @@ class acp_users  				// Delete entries if requested and able  				if (($deletemark || $deleteall) && $auth->acl_get('a_clearlogs'))  				{ +					if (!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +					} +  					$where_sql = '';  					if ($deletemark && $marked)  					{ @@ -907,6 +950,11 @@ class acp_users  				if ($submit && $message)  				{ +					if (!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +					} +  					add_log('admin', 'LOG_USER_FEEDBACK', $user_row['username']);  					add_log('mod', 0, 0, 'LOG_USER_FEEDBACK', $user_row['username']);  					add_log('user', $user_id, 'LOG_USER_GENERAL', $message); @@ -1027,6 +1075,10 @@ class acp_users  					{  						$error = array_merge($error, $cp_error);  					} +					if (!check_form_key($form_name)) +					{ +						$error[] = 'FORM_INVALID'; +					}  					if (!sizeof($error))  					{ @@ -1205,6 +1257,11 @@ class acp_users  						'post_sd'		=> array('string', false, 1, 1),  					)); +					if (!check_form_key($form_name)) +					{ +						$error[] = 'FORM_INVALID'; +					} +  					if (!sizeof($error))  					{  						$this->optionset($user_row, 'popuppm', $data['popuppm']); @@ -1368,6 +1425,12 @@ class acp_users  				if ($submit)  				{ + +					if (!check_form_key($form_name)) +					{ +							trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +					} +  					if (avatar_process_user($error, $user_row))  					{  						trigger_error($user->lang['USER_AVATAR_UPDATED'] . adm_back_link($this->u_action . '&u=' . $user_row['user_id'])); @@ -1410,6 +1473,11 @@ class acp_users  				if ($submit)  				{ +					if (!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +					} +  					$rank_id = request_var('user_rank', 0);  					$sql = 'UPDATE ' . USERS_TABLE . " @@ -1467,7 +1535,12 @@ class acp_users  					{  						$error[] = implode('<br />', $message_parser->warn_msg);  					} -						 + +					if (!check_form_key($form_name)) +					{ +						$error = 'FORM_INVALID'; +					} +  					if (!sizeof($error) && $submit)  					{  						$sql_ary = array( @@ -1733,6 +1806,12 @@ class acp_users  				// Add user to group?  				if ($submit)  				{ + +					if (!check_form_key($form_name)) +					{ +						trigger_error($user->lang['FORM_INVALID'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); +					} +  					if (!$group_id)  					{  						trigger_error($user->lang['NO_GROUP'] . adm_back_link($this->u_action . '&u=' . $user_id), E_USER_WARNING); diff --git a/phpBB/includes/acp/acp_words.php b/phpBB/includes/acp/acp_words.php index 7e971d8e0f..10a317cc50 100644 --- a/phpBB/includes/acp/acp_words.php +++ b/phpBB/includes/acp/acp_words.php @@ -33,6 +33,9 @@ class acp_words  		$this->tpl_name = 'acp_words';  		$this->page_title = 'ACP_WORDS'; +		$form_name = 'acp_words'; +		add_form_key($form_name); +  		switch ($action)  		{  			case 'edit': @@ -68,6 +71,11 @@ class acp_words  			break;  			case 'save': + +				if(!check_form_key($form_name)) +				{ +					trigger_error($user->lang['FORM_INVALID']. adm_back_link($this->u_action), E_USER_WARNING); +				}  				$word_id		= request_var('id', 0);  				$word			= utf8_normalize_nfc(request_var('word', '', true));  				$replacement	= utf8_normalize_nfc(request_var('replacement', '', true)); diff --git a/phpBB/includes/functions.php b/phpBB/includes/functions.php index cf7149afbf..682c3e7a86 100644 --- a/phpBB/includes/functions.php +++ b/phpBB/includes/functions.php @@ -1964,6 +1964,70 @@ function meta_refresh($time, $url)  	);  } +//Form validation + +/** +* Add a secret token to the form (requires the S_FORM_TOKEN template variable) +* @param string  $form_name The name of the form; has to match the name used in check_form_key, otherwise no restrictions apply +*/ +function add_form_key($form_name) +{ +	global $template, $user; +	$now = time(); +	$token = sha1($now . $user->data['user_form_salt'] . $form_name); + +	$s_fields = build_hidden_fields(array( +			'creation_time' => $now, +			'form_token'	=> $token, +	)); +	$template->assign_vars(array( +			'S_FORM_TOKEN'	=> $s_fields, +	)); +} + +/** +* Check the form key. Required for all altering actions not secured by confirm_box +* @param string  $form_name The name of the form; has to match the name used in add_form_key, otherwise no restrictions apply +* @param int $timespan The maximum acceptable age for a submitted form in seconds. Defaults to the config setting. +* @param string $return_page The address for the return link +* @param bool $trigger If true, the function will triger an error when encountering an invalid form +* @param int $minimum_time The minimum acceptable age for a submitted form in seconds +*/ +function check_form_key($form_name, $timespan = false, $return_page = '', $trigger = false, $miniumum_time = false) +{ +	global $user, $config; + +	if ($timespan === false)  +	{ +		$timespan = $config['form_token_lifetime']; +	} +	if ($miniumum_time === false) +	{ +		$miniumum_time = $config['form_token_mintime']; +	} +	if (isset($_POST['creation_time']) && isset($_POST['form_token'])) +	{ +		$creation_time	= abs(request_var('creation_time', 0)); +		$token = request_var('form_token', ''); + +		$diff = (time() - $creation_time); + +		if (($diff > $miniumum_time) && (($diff < $timespan) || $timespan == -1)) +		{ +			$key = sha1($creation_time . $user->data['user_form_salt'] . $form_name); +			if ($key === $token) +			{ +				return true; +			} +		} +	} +	if ($trigger) +	{ +		trigger_error($user->lang['FORM_INVALID'] . $return_page); +	} +	return false; +} +  // Message/Login boxes  /** diff --git a/phpBB/includes/functions_posting.php b/phpBB/includes/functions_posting.php index 23886e390c..69ab459224 100644 --- a/phpBB/includes/functions_posting.php +++ b/phpBB/includes/functions_posting.php @@ -1930,6 +1930,9 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  		}  		$sql_insert_ary = array(); +		$sql_delete_array = array(); +		 +		print_r($cur_poll_options);  		for ($i = 0, $size = sizeof($poll['poll_options']); $i < $size; $i++)  		{  			if (strlen(trim($poll['poll_options'][$i]))) @@ -1952,6 +1955,10 @@ function submit_post($mode, $subject, $username, $topic_type, &$poll, &$data, $u  					$db->sql_query($sql);  				}  			} +			else if (!empty($cur_poll_options[$i])) +			{ +				$sql_delete_array[] = $cur_poll_options[$i]['poll_option_id']; +			}  		}  		$db->sql_multi_insert(POLL_OPTIONS_TABLE, $sql_insert_ary); diff --git a/phpBB/includes/mcp/mcp_ban.php b/phpBB/includes/mcp/mcp_ban.php index 4b33af8b09..212116dfba 100644 --- a/phpBB/includes/mcp/mcp_ban.php +++ b/phpBB/includes/mcp/mcp_ban.php @@ -49,7 +49,6 @@ class mcp_ban  			$ban_exclude		= request_var('banexclude', 0);  			$ban_reason			= utf8_normalize_nfc(request_var('banreason', '', true));  			$ban_give_reason	= utf8_normalize_nfc(request_var('bangivereason', '', true)); -			  			if ($ban)  			{ diff --git a/phpBB/includes/mcp/mcp_notes.php b/phpBB/includes/mcp/mcp_notes.php index 6e6e1ffdd9..3519e86424 100755 --- a/phpBB/includes/mcp/mcp_notes.php +++ b/phpBB/includes/mcp/mcp_notes.php @@ -74,6 +74,8 @@ class mcp_notes  		$sk	= request_var('sk', 'b');  		$sd	= request_var('sd', 'd'); +		add_form_key('mcp_notes'); +  		$sql_where = ($user_id) ? "user_id = $user_id" : "username_clean = '" . $db->sql_escape(utf8_clean_string($username)) . "'";  		$sql = 'SELECT * @@ -121,15 +123,22 @@ class mcp_notes  			if ($where_sql || $deleteall)  			{ -				$sql = 'DELETE FROM ' . LOG_TABLE . ' -					WHERE log_type = ' . LOG_USERS . "  -						AND reportee_id = $user_id -						$where_sql"; -				$db->sql_query($sql); +				if (check_form_key('mcp_notes')) +				{ +					$sql = 'DELETE FROM ' . LOG_TABLE . ' +						WHERE log_type = ' . LOG_USERS . "  +							AND reportee_id = $user_id +							$where_sql"; +					$db->sql_query($sql); -				add_log('admin', 'LOG_CLEAR_USER', $userrow['username']); +					add_log('admin', 'LOG_CLEAR_USER', $userrow['username']); -				$msg = ($deletemark) ? 'MARKED_NOTES_DELETED' : 'ALL_NOTES_DELETED'; +					$msg = ($deletemark) ? 'MARKED_NOTES_DELETED' : 'ALL_NOTES_DELETED'; +				} +				else +				{ +					$msg = 'FORM_INVALID'; +				}  				$redirect = $this->u_action . '&u=' . $user_id;  				meta_refresh(3, $redirect);  				trigger_error($user->lang[$msg] . '<br /><br />' . sprintf($user->lang['RETURN_PAGE'], '<a href="' . $redirect . '">', '</a>')); @@ -138,15 +147,22 @@ class mcp_notes  		if ($usernote && $action == 'add_feedback')  		{ -			add_log('admin', 'LOG_USER_FEEDBACK', $userrow['username']); -			add_log('mod', 0, 0, 'LOG_USER_FEEDBACK', $userrow['username']); - -			add_log('user', $user_id, 'LOG_USER_GENERAL', $usernote); +			if(check_form_key('mcp_notes')) +			{ +				add_log('admin', 'LOG_USER_FEEDBACK', $userrow['username']); +				add_log('mod', 0, 0, 'LOG_USER_FEEDBACK', $userrow['username']); +				add_log('user', $user_id, 'LOG_USER_GENERAL', $usernote); +				$msg = $user->lang['USER_FEEDBACK_ADDED']; +			} +			else +			{ +				$msg = $user->lang['FORM_INVALID']; +			}  			$redirect = $this->u_action;  			meta_refresh(3, $redirect); -			trigger_error($user->lang['USER_FEEDBACK_ADDED'] . '<br /><br />' . sprintf($user->lang['RETURN_PAGE'], '<a href="' . $redirect . '">', '</a>')); +			trigger_error($msg .  '<br /><br />' . sprintf($user->lang['RETURN_PAGE'], '<a href="' . $redirect . '">', '</a>'));  		}  		// Generate the appropriate user information for the user we are looking at diff --git a/phpBB/includes/mcp/mcp_post.php b/phpBB/includes/mcp/mcp_post.php index 4a5bf77bca..2da4c1769a 100644 --- a/phpBB/includes/mcp/mcp_post.php +++ b/phpBB/includes/mcp/mcp_post.php @@ -24,6 +24,8 @@ function mcp_post_details($id, $mode, $action)  	// Get post data  	$post_info = get_post_data(array($post_id), false, true); +	add_form_key('mcp_post_details'); +  	if (!sizeof($post_info))  	{  		trigger_error('POST_NOT_EXIST'); @@ -82,7 +84,14 @@ function mcp_post_details($id, $mode, $action)  			if ($auth->acl_get('m_chgposter', $post_info['forum_id']))  			{ -				change_poster($post_info, $row); +				if (check_form_key('mcp_post_details')) +				{ +					change_poster($post_info, $row); +				} +				else +				{ +					trigger_error('FORM_INVALID'); +				}  			}  		break; diff --git a/phpBB/includes/mcp/mcp_topic.php b/phpBB/includes/mcp/mcp_topic.php index 4459c8e673..ef3dea55d2 100644 --- a/phpBB/includes/mcp/mcp_topic.php +++ b/phpBB/includes/mcp/mcp_topic.php @@ -40,7 +40,7 @@ function mcp_topic_view($id, $mode, $action)  	$to_forum_id	= request_var('to_forum_id', 0);  	$post_id_list	= request_var('post_id_list', array(0));  	$sort			= isset($_POST['sort']) ? true : false; -	 +  	// Split Topic?  	if ($action == 'split_all' || $action == 'split_beyond')  	{ @@ -98,8 +98,8 @@ function mcp_topic_view($id, $mode, $action)  	if ($total == -1)  	{  		$total = $topic_info['topic_replies'] + 1; -	}  -	 +	} +  	$posts_per_page = max(0, request_var('posts_per_page', intval($config['posts_per_page'])));  	if ($posts_per_page == 0)  	{ @@ -220,7 +220,7 @@ function mcp_topic_view($id, $mode, $action)  			'S_POST_UNAPPROVED'	=> ($row['post_approved']) ? false : true,  			'S_CHECKED'			=> ($post_id_list && in_array(intval($row['post_id']), $post_id_list)) ? true : false,  			'S_HAS_ATTACHMENTS'	=> (!empty($attachments[$row['post_id']])) ? true : false, -			 +  			'U_POST_DETAILS'	=> "$url&i=$id&p={$row['post_id']}&mode=post_details" . (($forum_id) ? "&f=$forum_id" : ''),  			'U_MCP_APPROVE'		=> ($auth->acl_get('m_approve', $topic_info['forum_id'])) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=queue&mode=approve_details&f=' . $topic_info['forum_id'] . '&p=' . $row['post_id']) : '',  			'U_MCP_REPORT'		=> ($auth->acl_get('m_report', $topic_info['forum_id'])) ? append_sid("{$phpbb_root_path}mcp.$phpEx", 'i=reports&mode=report_details&f=' . $topic_info['forum_id'] . '&p=' . $row['post_id']) : '') @@ -268,11 +268,11 @@ function mcp_topic_view($id, $mode, $action)  			}  		}  	} -	 +  	$s_hidden_fields = build_hidden_fields(array(  		'st_old'	=> $sort_days,  	)); -	 +  	$template->assign_vars(array(  		'TOPIC_TITLE'		=> $topic_info['topic_title'],  		'U_VIEW_TOPIC'		=> append_sid("{$phpbb_root_path}viewtopic.$phpEx", 'f=' . $topic_info['forum_id'] . '&t=' . $topic_info['topic_id']), @@ -298,7 +298,7 @@ function mcp_topic_view($id, $mode, $action)  		'S_REPORT_VIEW'		=> ($action == 'reports') ? true : false,  		'S_MERGE_VIEW'		=> ($action == 'merge') ? true : false,  		'S_SPLIT_VIEW'		=> ($action == 'split') ? true : false, -		 +  		'S_HIDDEN_FIELDS'	=> $s_hidden_fields,  		'S_SHOW_TOPIC_ICONS'	=> $s_topic_icons, diff --git a/phpBB/includes/mcp/mcp_warn.php b/phpBB/includes/mcp/mcp_warn.php index 3f61f6549a..a997d01ca5 100755 --- a/phpBB/includes/mcp/mcp_warn.php +++ b/phpBB/includes/mcp/mcp_warn.php @@ -37,6 +37,8 @@ class mcp_warn  		$this->page_title = 'MCP_WARN'; +		add_form_key('mcp_warn'); +  		switch ($mode)  		{  			case 'front': @@ -241,8 +243,15 @@ class mcp_warn  		if ($warning && $action == 'add_warning')  		{ -			add_warning($user_row, $warning, $notify, $post_id); - +			if (check_form_key('mcp_warn')) +			{ +				add_warning($user_row, $warning, $notify, $post_id); +				$msg = $user->lang['USER_WARNING_ADDED']; +			} +			else +			{ +				$msg = $user->lang['FORM_INVALID']; +			}  			$redirect = append_sid("{$phpbb_root_path}mcp.$phpEx", "i=notes&mode=user_notes&u=$user_id");  			meta_refresh(2, $redirect);  			trigger_error($user->lang['USER_WARNING_ADDED'] . '<br /><br />' . sprintf($user->lang['RETURN_PAGE'], '<a href="' . $redirect . '">', '</a>')); @@ -336,11 +345,18 @@ class mcp_warn  		if ($warning && $action == 'add_warning')  		{ -			add_warning($user_row, $warning, $notify); - +			if(check_form_key('mcp_warn')) +			{ +				add_warning($user_row, $warning, $notify); +				$msg = $user->lang['USER_WARNING_ADDED']; +			} +			else +			{ +				$msg = $user->lang['FORM_INVALID']; +			}  			$redirect = append_sid("{$phpbb_root_path}mcp.$phpEx", "i=notes&mode=user_notes&u=$user_id");  			meta_refresh(2, $redirect); -			trigger_error($user->lang['USER_WARNING_ADDED'] . '<br /><br />' . sprintf($user->lang['RETURN_PAGE'], '<a href="' . $redirect . '">', '</a>')); +			trigger_error($msg . '<br /><br />' . sprintf($user->lang['RETURN_PAGE'], '<a href="' . $redirect . '">', '</a>'));  		}  		// Generate the appropriate user information for the user we are looking at diff --git a/phpBB/includes/session.php b/phpBB/includes/session.php index cbb70e8601..b2399c74c5 100644 --- a/phpBB/includes/session.php +++ b/phpBB/includes/session.php @@ -641,6 +641,24 @@ class session  			$this->set_cookie('sid', $this->session_id, $cookie_expire);  			unset($cookie_expire); +			 +			$sql = 'SELECT COUNT(session_id) AS sessions +					FROM ' . SESSIONS_TABLE . ' +					WHERE session_user_id = ' . (int) $this->data['user_id'] . '  +					AND session_time >= ' . ($this->time_now - $config['form_token_lifetime']); +			$result = $db->sql_query($sql); +			$row = $db->sql_fetchrow($result); +			$db->sql_freeresult($result); + +			if ((int) $row['sessions'] <= 1 || empty($this->data['user_form_salt'])) +			{ +				$this->data['user_form_salt'] = unique_id(); +				// Update the form key +				$sql = 'UPDATE ' . USERS_TABLE . ' +					SET user_form_salt = \'' . $db->sql_escape($this->data['user_form_salt']) . '\' +					WHERE user_id = ' . (int) $this->data['user_id']; +				$db->sql_query($sql); +			}  		}  		else  		{ diff --git a/phpBB/includes/ucp/ucp_groups.php b/phpBB/includes/ucp/ucp_groups.php index 6e93f64acb..d8d4a285d4 100644 --- a/phpBB/includes/ucp/ucp_groups.php +++ b/phpBB/includes/ucp/ucp_groups.php @@ -393,6 +393,7 @@ class ucp_groups  				$this->page_title = 'UCP_USERGROUPS_MANAGE';  				$action		= (isset($_POST['addusers'])) ? 'addusers' : request_var('action', '');  				$group_id	= request_var('g', 0); +				add_form_key('ucp_groups');  				if ($group_id)  				{ @@ -552,6 +553,11 @@ class ucp_groups  								}  							} +							if (!check_form_key('ucp_groups')) +							{ +								$error[] = $user->lang['FORM_INVALID']; +							} +  							if (!sizeof($error))  							{  								// Only set the rank, colour, etc. if it's changed or if we're adding a new diff --git a/phpBB/includes/ucp/ucp_main.php b/phpBB/includes/ucp/ucp_main.php index ba40397a55..6f0db86bf6 100644 --- a/phpBB/includes/ucp/ucp_main.php +++ b/phpBB/includes/ucp/ucp_main.php @@ -194,41 +194,51 @@ class ucp_main  				$user->add_lang('viewforum'); +				add_form_key('ucp_front_subscribed'); +  				$unwatch = (isset($_POST['unwatch'])) ? true : false;  				if ($unwatch)  				{ -					$forums = array_keys(request_var('f', array(0 => 0))); -					$topics = array_keys(request_var('t', array(0 => 0))); - -					if (sizeof($forums) || sizeof($topics)) +					if(check_form_key('ucp_front_subscribed'))  					{ -						$l_unwatch = ''; -						if (sizeof($forums)) -						{ -							$sql = 'DELETE FROM ' . FORUMS_WATCH_TABLE . ' -								WHERE ' . $db->sql_in_set('forum_id', $forums) . ' -									AND user_id = ' . $user->data['user_id']; -							$db->sql_query($sql); +						$forums = array_keys(request_var('f', array(0 => 0))); +						$topics = array_keys(request_var('t', array(0 => 0))); +						$msg = ''; -							$l_unwatch .= '_FORUMS'; -						} - -						if (sizeof($topics)) +						if (sizeof($forums) || sizeof($topics))  						{ -							$sql = 'DELETE FROM ' . TOPICS_WATCH_TABLE . ' -								WHERE ' . $db->sql_in_set('topic_id', $topics) . ' -									AND user_id = ' . $user->data['user_id']; -							$db->sql_query($sql); +							$l_unwatch = ''; +							if (sizeof($forums)) +							{ +								$sql = 'DELETE FROM ' . FORUMS_WATCH_TABLE . ' +									WHERE ' . $db->sql_in_set('forum_id', $forums) . ' +										AND user_id = ' . $user->data['user_id']; +								$db->sql_query($sql); + +								$l_unwatch .= '_FORUMS'; +							} + +							if (sizeof($topics)) +							{ +								$sql = 'DELETE FROM ' . TOPICS_WATCH_TABLE . ' +									WHERE ' . $db->sql_in_set('topic_id', $topics) . ' +										AND user_id = ' . $user->data['user_id']; +								$db->sql_query($sql); + +								$l_unwatch .= '_TOPICS'; +							} +							$msg = $user->lang['UNWATCHED' . $l_unwatch]; -							$l_unwatch .= '_TOPICS';  						} - -						$message = $user->lang['UNWATCHED' . $l_unwatch] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . append_sid("{$phpbb_root_path}ucp.$phpEx", "i=$id&mode=subscribed") . '">', '</a>'); - -						meta_refresh(3, append_sid("{$phpbb_root_path}ucp.$phpEx", "i=$id&mode=subscribed")); -						trigger_error($message);  					} +					else +					{ +						$msg = $user->lang['FORM_INVALID']; +					} +					$message = $msg . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . append_sid("{$phpbb_root_path}ucp.$phpEx", "i=$id&mode=subscribed") . '">', '</a>'); +					meta_refresh(3, append_sid("{$phpbb_root_path}ucp.$phpEx", "i=$id&mode=subscribed")); +					trigger_error($message);  				}  				$forbidden_forums = array(); @@ -418,53 +428,65 @@ class ucp_main  				$s_hidden_fields = ($edit) ? '<input type="hidden" name="edit" value="' . $draft_id . '" />' : '';  				$draft_subject = $draft_message = ''; +				add_form_key('ucp_draft');  				if ($delete)  				{ -					$drafts = array_keys(request_var('d', array(0 => 0))); - -					if (sizeof($drafts)) +					if (check_form_key('ucp_draft'))  					{ -						$sql = 'DELETE FROM ' . DRAFTS_TABLE . ' -							WHERE ' . $db->sql_in_set('draft_id', $drafts) . ' -								AND user_id = ' . $user->data['user_id']; -						$db->sql_query($sql); +						$drafts = array_keys(request_var('d', array(0 => 0))); -						$message = $user->lang['DRAFTS_DELETED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); - -						meta_refresh(3, $this->u_action); -						trigger_error($message); +						if (sizeof($drafts)) +						{ +							$sql = 'DELETE FROM ' . DRAFTS_TABLE . ' +								WHERE ' . $db->sql_in_set('draft_id', $drafts) . ' +									AND user_id = ' . $user->data['user_id']; +							$db->sql_query($sql); +						} +						$msg = $user->lang['DRAFTS_DELETED']; +						unset($drafts);  					} - -					unset($drafts); +					else +					{ +						$msg = $user->lang['FORM_INVALID']; +					} +					$message = $msg . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); +					meta_refresh(3, $this->u_action); +					trigger_error($message);  				}  				if ($submit && $edit)  				{  					$draft_subject = utf8_normalize_nfc(request_var('subject', '', true));  					$draft_message = utf8_normalize_nfc(request_var('message', '', true)); -					 -					if ($draft_message && $draft_subject) +					if (check_form_key('ucp_draft'))  					{ -						$draft_row = array( -							'draft_subject' => $draft_subject, -							'draft_message' => $draft_message -						); - -						$sql = 'UPDATE ' . DRAFTS_TABLE . '  -							SET ' . $db->sql_build_array('UPDATE', $draft_row) . "  -							WHERE draft_id = $draft_id -								AND user_id = " . $user->data['user_id']; -						$db->sql_query($sql); +						if ($draft_message && $draft_subject) +						{ +							$draft_row = array( +								'draft_subject' => $draft_subject, +								'draft_message' => $draft_message +							); + +							$sql = 'UPDATE ' . DRAFTS_TABLE . '  +								SET ' . $db->sql_build_array('UPDATE', $draft_row) . "  +								WHERE draft_id = $draft_id +									AND user_id = " . $user->data['user_id']; +							$db->sql_query($sql); -						$message = $user->lang['DRAFT_UPDATED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); +							$message = $user->lang['DRAFT_UPDATED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); -						meta_refresh(3, $this->u_action); -						trigger_error($message); +							meta_refresh(3, $this->u_action); +							trigger_error($message); +						} +						else +						{ +							$template->assign_var('ERROR', ($draft_message == '') ? $user->lang['EMPTY_DRAFT'] : (($draft_subject == '') ? $user->lang['EMPTY_DRAFT_TITLE'] : '')); +						}  					}  					else  					{ -						$template->assign_var('ERROR', ($draft_message == '') ? $user->lang['EMPTY_DRAFT'] : (($draft_subject == '') ? $user->lang['EMPTY_DRAFT_TITLE'] : '')); +						$template->assign_var('ERROR', $user->lang['FORM_INVALID']);  					}  				} diff --git a/phpBB/includes/ucp/ucp_pm_compose.php b/phpBB/includes/ucp/ucp_pm_compose.php index ae2e367795..a22fc57761 100644 --- a/phpBB/includes/ucp/ucp_pm_compose.php +++ b/phpBB/includes/ucp/ucp_pm_compose.php @@ -25,6 +25,7 @@ function compose_pm($id, $mode, $action)  	{  		$action = 'post';  	} +	add_form_key('ucp_pm_compose');  	// Grab only parameters needed here  	$to_user_id		= request_var('u', 0); @@ -532,6 +533,10 @@ function compose_pm($id, $mode, $action)  	if ($submit || $preview || $refresh)  	{ +		if (!check_form_key('ucp_pm_compose')) +		{ +			$error[] = $user->lang['FORM_INVALID']; +		}  		$subject = utf8_normalize_nfc(request_var('subject', '', true));  		$message_parser->message = utf8_normalize_nfc(request_var('message', '', true)); diff --git a/phpBB/includes/ucp/ucp_pm_options.php b/phpBB/includes/ucp/ucp_pm_options.php index e4d067115d..429c9e0caa 100644 --- a/phpBB/includes/ucp/ucp_pm_options.php +++ b/phpBB/includes/ucp/ucp_pm_options.php @@ -17,9 +17,11 @@ function message_options($id, $mode, $global_privmsgs_rules, $global_rule_condit  	$redirect_url = append_sid("{$phpbb_root_path}ucp.$phpEx", "i=pm&mode=options"); +	add_form_key('ucp_pm_options');  	// Change "full folder" setting - what to do if folder is full  	if (isset($_POST['fullfolder']))  	{ +		check_form_key('ucp_pm_options', $config['form_token_lifetime'], $redirect_url);  		$full_action = request_var('full_action', 0);  		$set_folder_id = 0; @@ -60,79 +62,94 @@ function message_options($id, $mode, $global_privmsgs_rules, $global_rule_condit  	// Add Folder  	if (isset($_POST['addfolder']))  	{ -		$folder_name = utf8_normalize_nfc(request_var('foldername', '', true)); -		 -		if ($folder_name) +		if (check_form_key('ucp_pm_options'))  		{ -			$sql = 'SELECT folder_name  -				FROM ' . PRIVMSGS_FOLDER_TABLE . " -				WHERE folder_name = '" . $db->sql_escape($folder_name) . "' -					AND user_id = " . $user->data['user_id']; -			$result = $db->sql_query_limit($sql, 1); -			$row = $db->sql_fetchrow($result); -			$db->sql_freeresult($result); +			$folder_name = utf8_normalize_nfc(request_var('foldername', '', true)); +			$msg = ''; -			if ($row) +			if ($folder_name)  			{ -				trigger_error(sprintf($user->lang['FOLDER_NAME_EXIST'], $folder_name)); -			} +				$sql = 'SELECT folder_name  +					FROM ' . PRIVMSGS_FOLDER_TABLE . " +					WHERE folder_name = '" . $db->sql_escape($folder_name) . "' +						AND user_id = " . $user->data['user_id']; +				$result = $db->sql_query_limit($sql, 1); +				$row = $db->sql_fetchrow($result); +				$db->sql_freeresult($result); -			$sql = 'SELECT COUNT(folder_id) as num_folder -				FROM ' . PRIVMSGS_FOLDER_TABLE . ' -					WHERE user_id = ' . $user->data['user_id']; -			$result = $db->sql_query($sql); -			$num_folder = (int) $db->sql_fetchfield('num_folder'); -			$db->sql_freeresult($result); +				if ($row) +				{ +					trigger_error(sprintf($user->lang['FOLDER_NAME_EXIST'], $folder_name)); +				} -			if ($num_folder >= $config['pm_max_boxes']) -			{ -				trigger_error('MAX_FOLDER_REACHED'); -			} +				$sql = 'SELECT COUNT(folder_id) as num_folder +					FROM ' . PRIVMSGS_FOLDER_TABLE . ' +						WHERE user_id = ' . $user->data['user_id']; +				$result = $db->sql_query($sql); +				$num_folder = (int) $db->sql_fetchfield('num_folder'); +				$db->sql_freeresult($result); -			$sql = 'INSERT INTO ' . PRIVMSGS_FOLDER_TABLE . ' ' . $db->sql_build_array('INSERT', array( -				'user_id'		=> (int) $user->data['user_id'], -				'folder_name'	=> $folder_name) -			); -			$db->sql_query($sql); +				if ($num_folder >= $config['pm_max_boxes']) +				{ +					trigger_error('MAX_FOLDER_REACHED'); +				} -			$message = $user->lang['FOLDER_ADDED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $redirect_url . '">', '</a>'); -			meta_refresh(3, $redirect_url); -			trigger_error($message); +				$sql = 'INSERT INTO ' . PRIVMSGS_FOLDER_TABLE . ' ' . $db->sql_build_array('INSERT', array( +					'user_id'		=> (int) $user->data['user_id'], +					'folder_name'	=> $folder_name) +				); +				$db->sql_query($sql); +				$msg = $user->lang['FOLDER_ADDED']; +			} +		} +		else +		{ +			$msg = $user->lang['FORM_INVALID'];  		} +		$message = $msg . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $redirect_url . '">', '</a>'); +		meta_refresh(3, $redirect_url); +		trigger_error($message);  	}  	// Rename folder  	if (isset($_POST['rename_folder']))  	{ -		$new_folder_name = utf8_normalize_nfc(request_var('new_folder_name', '', true)); -		$rename_folder_id= request_var('rename_folder_id', 0); - -		if (!$new_folder_name) +		if (check_form_key('ucp_pm_options'))  		{ -			trigger_error('NO_NEW_FOLDER_NAME'); -		} +			$new_folder_name = utf8_normalize_nfc(request_var('new_folder_name', '', true)); +			$rename_folder_id= request_var('rename_folder_id', 0); -		// Select custom folder -		$sql = 'SELECT folder_name, pm_count -			FROM ' . PRIVMSGS_FOLDER_TABLE . " -			WHERE user_id = {$user->data['user_id']} -				AND folder_id = $rename_folder_id"; -		$result = $db->sql_query_limit($sql, 1); -		$folder_row = $db->sql_fetchrow($result); -		$db->sql_freeresult($result); +			if (!$new_folder_name) +			{ +				trigger_error('NO_NEW_FOLDER_NAME'); +			} -		if (!$folder_row) -		{ -			trigger_error('CANNOT_RENAME_FOLDER'); -		} +			// Select custom folder +			$sql = 'SELECT folder_name, pm_count +				FROM ' . PRIVMSGS_FOLDER_TABLE . " +				WHERE user_id = {$user->data['user_id']} +					AND folder_id = $rename_folder_id"; +			$result = $db->sql_query_limit($sql, 1); +			$folder_row = $db->sql_fetchrow($result); +			$db->sql_freeresult($result); -		$sql = 'UPDATE ' . PRIVMSGS_FOLDER_TABLE . "  -			SET folder_name = '" . $db->sql_escape($new_folder_name) . "' -			WHERE folder_id = $rename_folder_id -				AND user_id = {$user->data['user_id']}"; -		$db->sql_query($sql); +			if (!$folder_row) +			{ +				trigger_error('CANNOT_RENAME_FOLDER'); +			} -		$message = $user->lang['FOLDER_RENAMED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $redirect_url . '">', '</a>'); +			$sql = 'UPDATE ' . PRIVMSGS_FOLDER_TABLE . "  +				SET folder_name = '" . $db->sql_escape($new_folder_name) . "' +				WHERE folder_id = $rename_folder_id +					AND user_id = {$user->data['user_id']}"; +			$db->sql_query($sql); +			$msg = $user->lang['FOLDER_RENAMED']; +		} +		else +		{ +			$msg = $user->lang['FORM_INVALID']; +		} +		$message = $msg . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $redirect_url . '">', '</a>');  		meta_refresh(3, $redirect_url);  		trigger_error($message);  	} @@ -251,60 +268,68 @@ function message_options($id, $mode, $global_privmsgs_rules, $global_rule_condit  	// Add Rule  	if (isset($_POST['add_rule']))  	{ -		$check_option	= request_var('check_option', 0); -		$rule_option	= request_var('rule_option', 0); -		$cond_option	= request_var('cond_option', ''); -		$action_option	= explode('|', request_var('action_option', '')); -		$rule_string	= ($cond_option != 'none') ? utf8_normalize_nfc(request_var('rule_string', '', true)) : ''; -		$rule_user_id	= ($cond_option != 'none') ? request_var('rule_user_id', 0) : 0; -		$rule_group_id	= ($cond_option != 'none') ? request_var('rule_group_id', 0) : 0; -		 -		$action = (int) $action_option[0]; -		$folder_id = (int) $action_option[1]; - -		if (!$action || !$check_option || !$rule_option || !$cond_option || ($cond_option != 'none' && !$rule_string)) +		if(check_form_key('ucp_pm_options'))  		{ -			trigger_error('RULE_NOT_DEFINED'); -		} +			$check_option	= request_var('check_option', 0); +			$rule_option	= request_var('rule_option', 0); +			$cond_option	= request_var('cond_option', ''); +			$action_option	= explode('|', request_var('action_option', '')); +			$rule_string	= ($cond_option != 'none') ? utf8_normalize_nfc(request_var('rule_string', '', true)) : ''; +			$rule_user_id	= ($cond_option != 'none') ? request_var('rule_user_id', 0) : 0; +			$rule_group_id	= ($cond_option != 'none') ? request_var('rule_group_id', 0) : 0; + +			$action = (int) $action_option[0]; +			$folder_id = (int) $action_option[1]; + +			if (!$action || !$check_option || !$rule_option || !$cond_option || ($cond_option != 'none' && !$rule_string)) +			{ +				trigger_error('RULE_NOT_DEFINED'); +			} -		if (($cond_option == 'user' && !$rule_user_id) || ($cond_option == 'group' && !$rule_group_id)) -		{ -			trigger_error('RULE_NOT_DEFINED'); -		} +			if (($cond_option == 'user' && !$rule_user_id) || ($cond_option == 'group' && !$rule_group_id)) +			{ +				trigger_error('RULE_NOT_DEFINED'); +			} -		$rule_ary = array( -			'user_id'			=> $user->data['user_id'], -			'rule_check'		=> $check_option, -			'rule_connection'	=> $rule_option, -			'rule_string'		=> $rule_string, -			'rule_user_id'		=> $rule_user_id, -			'rule_group_id'		=> $rule_group_id, -			'rule_action'		=> $action, -			'rule_folder_id'	=> $folder_id -		); +			$rule_ary = array( +				'user_id'			=> $user->data['user_id'], +				'rule_check'		=> $check_option, +				'rule_connection'	=> $rule_option, +				'rule_string'		=> $rule_string, +				'rule_user_id'		=> $rule_user_id, +				'rule_group_id'		=> $rule_group_id, +				'rule_action'		=> $action, +				'rule_folder_id'	=> $folder_id +			); -		$sql = 'SELECT rule_id  -			FROM ' . PRIVMSGS_RULES_TABLE . ' -			WHERE ' . $db->sql_build_array('SELECT', $rule_ary); -		$result = $db->sql_query($sql); -		$row = $db->sql_fetchrow($result); -		$db->sql_freeresult($result); +			$sql = 'SELECT rule_id  +				FROM ' . PRIVMSGS_RULES_TABLE . ' +				WHERE ' . $db->sql_build_array('SELECT', $rule_ary); +			$result = $db->sql_query($sql); +			$row = $db->sql_fetchrow($result); +			$db->sql_freeresult($result); -		if ($row) -		{ -			trigger_error('RULE_ALREADY_DEFINED'); -		} +			if ($row) +			{ +				trigger_error('RULE_ALREADY_DEFINED'); +			} -		$sql = 'INSERT INTO ' . PRIVMSGS_RULES_TABLE . ' ' . $db->sql_build_array('INSERT', $rule_ary); -		$db->sql_query($sql); +			$sql = 'INSERT INTO ' . PRIVMSGS_RULES_TABLE . ' ' . $db->sql_build_array('INSERT', $rule_ary); +			$db->sql_query($sql); -		// Update users message rules -		$sql = 'UPDATE ' . USERS_TABLE . ' -			SET user_message_rules = 1 -			WHERE user_id = ' . $user->data['user_id']; -		$db->sql_query($sql); +			// Update users message rules +			$sql = 'UPDATE ' . USERS_TABLE . ' +				SET user_message_rules = 1 +				WHERE user_id = ' . $user->data['user_id']; +			$db->sql_query($sql); -		$message = $user->lang['RULE_ADDED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $redirect_url . '">', '</a>'); +			$msg = $user->lang['RULE_ADDED']; +		} +		else +		{ +			$msg = $user->lang['FORM_INVALID']; +		} +		$message = $msg . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $redirect_url . '">', '</a>');  		meta_refresh(3, $redirect_url);  		trigger_error($message);  	} diff --git a/phpBB/includes/ucp/ucp_prefs.php b/phpBB/includes/ucp/ucp_prefs.php index b0e8f098c2..445000b4dc 100644 --- a/phpBB/includes/ucp/ucp_prefs.php +++ b/phpBB/includes/ucp/ucp_prefs.php @@ -28,7 +28,7 @@ class ucp_prefs  		switch ($mode)  		{  			case 'personal': - +				add_form_key('ucp_prefs_personal');  				$data = array(  					'notifymethod'	=> request_var('notifymethod', $user->data['user_notify_type']),  					'dateformat'	=> request_var('dateformat', $user->data['user_dateformat'], true), @@ -55,6 +55,11 @@ class ucp_prefs  						'tz'			=> array('num', false, -14, 14),  					)); +					if (!check_form_key('ucp_prefs_personal')) +					{ +						$error[] = 'FORM_INVALID'; +					} +  					if (!sizeof($error))  					{  						$user->optionset('popuppm', $data['popuppm']); @@ -140,6 +145,8 @@ class ucp_prefs  			case 'view': +				add_form_key('ucp_prefs_view'); +  				$data = array(  					'topic_sk'		=> request_var('topic_sk', (!empty($user->data['user_topic_sortby_type'])) ? $user->data['user_topic_sortby_type'] : 't'),  					'topic_sd'		=> request_var('topic_sd', (!empty($user->data['user_topic_sortby_dir'])) ? $user->data['user_topic_sortby_dir'] : 'd'), @@ -166,6 +173,11 @@ class ucp_prefs  						'post_sd'	=> array('string', false, 1, 1),  					)); +					if (!check_form_key('ucp_prefs_view')) +					{ +						$error[] = 'FORM_INVALID'; +					} +  					if (!sizeof($error))  					{  						$user->optionset('viewimg', $data['images']); @@ -276,25 +288,34 @@ class ucp_prefs  					'sig'		=> request_var('sig', $user->optionget('attachsig')),  					'notify'	=> request_var('notify', $user->data['user_notify']),  				); +				add_form_key('ucp_prefs_post');  				if ($submit)  				{ -					$user->optionset('bbcode', $data['bbcode']); -					$user->optionset('smilies', $data['smilies']); -					$user->optionset('attachsig', $data['sig']); +					if (check_form_key('ucp_prefs_post')) +					{ +						$user->optionset('bbcode', $data['bbcode']); +						$user->optionset('smilies', $data['smilies']); +						$user->optionset('attachsig', $data['sig']); -					$sql_ary = array( -						'user_options'	=> $user->data['user_options'], -						'user_notify'	=> $data['notify'], -					); +						$sql_ary = array( +							'user_options'	=> $user->data['user_options'], +							'user_notify'	=> $data['notify'], +						); -					$sql = 'UPDATE ' . USERS_TABLE . ' -						SET ' . $db->sql_build_array('UPDATE', $sql_ary) . ' -						WHERE user_id = ' . $user->data['user_id']; -					$db->sql_query($sql); +						$sql = 'UPDATE ' . USERS_TABLE . ' +							SET ' . $db->sql_build_array('UPDATE', $sql_ary) . ' +							WHERE user_id = ' . $user->data['user_id']; +						$db->sql_query($sql); +						$msg = $user->lang['PREFERENCES_UPDATED']; +					} +					else +					{ +						$msg = $user->lang['FORM_INVALID']; +					}  					meta_refresh(3, $this->u_action); -					$message = $user->lang['PREFERENCES_UPDATED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); +					$message = $msg . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>');  					trigger_error($message);  				} diff --git a/phpBB/includes/ucp/ucp_profile.php b/phpBB/includes/ucp/ucp_profile.php index 269c3aad44..45461a56d0 100644 --- a/phpBB/includes/ucp/ucp_profile.php +++ b/phpBB/includes/ucp/ucp_profile.php @@ -44,6 +44,8 @@ class ucp_profile  					'password_confirm'	=> request_var('password_confirm', '', true),  				); +				add_form_key('ucp_reg_details'); +  				if ($submit)  				{  					// Do not check cur_password, it is the old one. @@ -89,6 +91,11 @@ class ucp_profile  						$error[] = 'NEW_EMAIL_ERROR';  					} +					if (!check_form_key('ucp_reg_details')) +					{ +						$error[] = 'FORM_INVALID'; +					} +  					if (!sizeof($error))  					{  						$sql_ary = array( @@ -224,7 +231,7 @@ class ucp_profile  						trigger_error($message);  					} -	 +  					// Replace "error" strings with their real, localised form  					$error = preg_replace('#^([A-Z_]+)$#e', "(!empty(\$user->lang['\\1'])) ? \$user->lang['\\1'] : '\\1'", $error);  				} @@ -282,6 +289,8 @@ class ucp_profile  					$data['bday_year'] = request_var('bday_year', $data['bday_year']);  				} +				add_form_key('ucp_profile_info'); +  				if ($submit)  				{  					$validate_array = array( @@ -321,6 +330,11 @@ class ucp_profile  						$error = array_merge($error, $cp_error);  					} +					if (!check_form_key('ucp_profile_info')) +					{ +						$error[] = 'FORM_INVALID'; +					} +  					if (!sizeof($error))  					{  						$sql_ary = array( @@ -446,6 +460,8 @@ class ucp_profile  				$signature		= utf8_normalize_nfc(request_var('signature', (string) $user->data['user_sig'], true)); +				add_form_key('ucp_sig'); +  				if ($submit || $preview)  				{  					include($phpbb_root_path . 'includes/message_parser.' . $phpEx); @@ -462,6 +478,11 @@ class ucp_profile  							$error[] = implode('<br />', $message_parser->warn_msg);  						} +						if (!check_form_key('ucp_sig')) +						{ +							$error[] = 'FORM_INVALID'; +						} +  						if (!sizeof($error) && $submit)  						{  							$sql_ary = array( @@ -517,7 +538,7 @@ class ucp_profile  					'S_BBCODE_FLASH'		=> ($config['allow_sig_flash']) ? true : false,  					'S_LINKS_ALLOWED'		=> ($config['allow_sig_links']) ? true : false)  				); -			 +  				// Build custom bbcodes array  				display_custom_bbcodes(); @@ -533,15 +554,23 @@ class ucp_profile  				$can_upload = ($config['allow_avatar_upload'] && file_exists($phpbb_root_path . $config['avatar_path']) && @is_writable($phpbb_root_path . $config['avatar_path']) && $auth->acl_get('u_chgavatar') && (@ini_get('file_uploads') || strtolower(@ini_get('file_uploads')) == 'on')) ? true : false; +				add_form_key('ucp_avatar'); +  				if ($submit)  				{ -					if (avatar_process_user($error)) +					if (check_form_key('ucp_avatar'))  					{ -						meta_refresh(3, $this->u_action); -						$message = $user->lang['PROFILE_UPDATED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); -						trigger_error($message); +						if (avatar_process_user($error)) +						{ +							meta_refresh(3, $this->u_action); +							$message = $user->lang['PROFILE_UPDATED'] . '<br /><br />' . sprintf($user->lang['RETURN_UCP'], '<a href="' . $this->u_action . '">', '</a>'); +							trigger_error($message); +						} +					} +					else +					{ +						$error[] = 'FORM_INVALID';  					} -  					// Replace "error" strings with their real, localised form  					$error = preg_replace('#^([A-Z_]+)$#e', "(!empty(\$user->lang['\\1'])) ? \$user->lang['\\1'] : '\\1'", $error);  				} diff --git a/phpBB/includes/ucp/ucp_register.php b/phpBB/includes/ucp/ucp_register.php index 6f133a9ed4..f321eb5b25 100644 --- a/phpBB/includes/ucp/ucp_register.php +++ b/phpBB/includes/ucp/ucp_register.php @@ -36,6 +36,16 @@ class ucp_register  		$change_lang	= request_var('change_lang', '');  		$user_lang		= request_var('lang', $user->lang_name); +		add_form_key('ucp_register'); + +		// not so fast, buddy +		if (($submit && !check_form_key('ucp_register', false, '', false, 5)) +			|| (!$submit && !check_form_key('ucp_register', false, '', false, 1))) +		{ +			$agreed = false; +		} + +  		if ($change_lang || $user_lang != $config['default_lang'])  		{  			$use_lang = ($change_lang) ? basename($change_lang) : basename($user_lang); @@ -122,6 +132,7 @@ class ucp_register  			return;  		} +  		// Try to manually determine the timezone and adjust the dst if the server date/time complies with the default setting +/- 1  		$timezone = date('Z') / 3600;  		$is_dst = date('I'); diff --git a/phpBB/includes/ucp/ucp_resend.php b/phpBB/includes/ucp/ucp_resend.php index 1e424fb7cc..edd372333e 100644 --- a/phpBB/includes/ucp/ucp_resend.php +++ b/phpBB/includes/ucp/ucp_resend.php @@ -26,8 +26,15 @@ class ucp_resend  		$email		= strtolower(request_var('email', ''));  		$submit		= (isset($_POST['submit'])) ? true : false; +		add_form_key('ucp_resend'); +  		if ($submit)  		{ +			if (!check_form_key('ucp_resend')) +			{ +				trigger_error('FORM_INVALID'); +			} +  			$sql = 'SELECT user_id, group_id, username, user_email, user_type, user_lang, user_actkey, user_inactive_reason  				FROM ' . USERS_TABLE . "  				WHERE user_email = '" . $db->sql_escape($email) . "' diff --git a/phpBB/install/database_update.php b/phpBB/install/database_update.php index bf2d3a1c70..b28879de4d 100644 --- a/phpBB/install/database_update.php +++ b/phpBB/install/database_update.php @@ -424,6 +424,15 @@ $database_update_info = array(  			),  		),  	), +	// Changes from 3.0.RC5 to the next version +	'3.0.RC5'			=> array( +		// Add the following columns +		'add_columns'		=> array( +			USER_TABLE	=> array( +				'user_form_salt'	=> array('VCHAR_UNI:32', ''), +			), +		), +	),  );  // Determine mapping database type @@ -1510,6 +1519,9 @@ if (version_compare($current_version, '3.0.RC5', '<='))  		WHERE bot_agent = '" . $db->sql_escape('Mediapartners-Google/') . "'";  	_sql($sql, $errored, $error_ary); +	set_config('form_token_lifetime', '7200'); +	set_config('form_token_mintime', '0'); +  	$no_updates = false;  } diff --git a/phpBB/install/schemas/firebird_schema.sql b/phpBB/install/schemas/firebird_schema.sql index 38ef13c412..37e14af4e5 100644 --- a/phpBB/install/schemas/firebird_schema.sql +++ b/phpBB/install/schemas/firebird_schema.sql @@ -1354,7 +1354,8 @@ CREATE TABLE phpbb_users (  	user_occ BLOB SUB_TYPE TEXT CHARACTER SET UTF8 DEFAULT '' NOT NULL,  	user_interests BLOB SUB_TYPE TEXT CHARACTER SET UTF8 DEFAULT '' NOT NULL,  	user_actkey VARCHAR(32) CHARACTER SET NONE DEFAULT '' NOT NULL, -	user_newpasswd VARCHAR(32) CHARACTER SET UTF8 DEFAULT '' NOT NULL COLLATE UNICODE +	user_newpasswd VARCHAR(32) CHARACTER SET UTF8 DEFAULT '' NOT NULL COLLATE UNICODE, +	user_form_salt VARCHAR(32) CHARACTER SET UTF8 DEFAULT '' NOT NULL COLLATE UNICODE  );;  ALTER TABLE phpbb_users ADD PRIMARY KEY (user_id);; diff --git a/phpBB/install/schemas/mssql_schema.sql b/phpBB/install/schemas/mssql_schema.sql index 37e8f66b2a..54b3a1fa08 100644 --- a/phpBB/install/schemas/mssql_schema.sql +++ b/phpBB/install/schemas/mssql_schema.sql @@ -1621,7 +1621,8 @@ CREATE TABLE [phpbb_users] (  	[user_occ] [varchar] (4000) DEFAULT ('') NOT NULL ,  	[user_interests] [varchar] (4000) DEFAULT ('') NOT NULL ,  	[user_actkey] [varchar] (32) DEFAULT ('') NOT NULL , -	[user_newpasswd] [varchar] (32) DEFAULT ('') NOT NULL  +	[user_newpasswd] [varchar] (32) DEFAULT ('') NOT NULL , +	[user_form_salt] [varchar] (32) DEFAULT ('') NOT NULL   ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]  GO diff --git a/phpBB/install/schemas/mysql_40_schema.sql b/phpBB/install/schemas/mysql_40_schema.sql index a1450cacee..478963e541 100644 --- a/phpBB/install/schemas/mysql_40_schema.sql +++ b/phpBB/install/schemas/mysql_40_schema.sql @@ -955,6 +955,7 @@ CREATE TABLE phpbb_users (  	user_interests blob NOT NULL,  	user_actkey varbinary(32) DEFAULT '' NOT NULL,  	user_newpasswd varbinary(96) DEFAULT '' NOT NULL, +	user_form_salt varbinary(96) DEFAULT '' NOT NULL,  	PRIMARY KEY (user_id),  	KEY user_birthday (user_birthday),  	KEY user_email_hash (user_email_hash), diff --git a/phpBB/install/schemas/mysql_41_schema.sql b/phpBB/install/schemas/mysql_41_schema.sql index 4cee662be6..88657aa4ac 100644 --- a/phpBB/install/schemas/mysql_41_schema.sql +++ b/phpBB/install/schemas/mysql_41_schema.sql @@ -955,6 +955,7 @@ CREATE TABLE phpbb_users (  	user_interests text NOT NULL,  	user_actkey varchar(32) DEFAULT '' NOT NULL,  	user_newpasswd varchar(32) DEFAULT '' NOT NULL, +	user_form_salt varchar(32) DEFAULT '' NOT NULL,  	PRIMARY KEY (user_id),  	KEY user_birthday (user_birthday),  	KEY user_email_hash (user_email_hash), diff --git a/phpBB/install/schemas/oracle_schema.sql b/phpBB/install/schemas/oracle_schema.sql index aabc00f0e2..a91f4d07ba 100644 --- a/phpBB/install/schemas/oracle_schema.sql +++ b/phpBB/install/schemas/oracle_schema.sql @@ -1772,6 +1772,7 @@ CREATE TABLE phpbb_users (  	user_interests clob DEFAULT '' ,  	user_actkey varchar2(32) DEFAULT '' ,  	user_newpasswd varchar2(96) DEFAULT '' , +	user_form_salt varchar2(96) DEFAULT '' ,  	CONSTRAINT pk_phpbb_users PRIMARY KEY (user_id),  	CONSTRAINT u_phpbb_username_clean UNIQUE (username_clean)  ) diff --git a/phpBB/install/schemas/postgres_schema.sql b/phpBB/install/schemas/postgres_schema.sql index 5d4c6f477b..9b439d9fb2 100644 --- a/phpBB/install/schemas/postgres_schema.sql +++ b/phpBB/install/schemas/postgres_schema.sql @@ -1218,6 +1218,7 @@ CREATE TABLE phpbb_users (  	user_interests varchar(4000) DEFAULT '' NOT NULL,  	user_actkey varchar(32) DEFAULT '' NOT NULL,  	user_newpasswd varchar(32) DEFAULT '' NOT NULL, +	user_form_salt varchar(32) DEFAULT '' NOT NULL,  	PRIMARY KEY (user_id)  ); diff --git a/phpBB/install/schemas/schema_data.sql b/phpBB/install/schemas/schema_data.sql index b80dc5583f..b155cd5d95 100644 --- a/phpBB/install/schemas/schema_data.sql +++ b/phpBB/install/schemas/schema_data.sql @@ -88,6 +88,8 @@ INSERT INTO phpbb_config (config_name, config_value) VALUES ('enable_pm_icons',  INSERT INTO phpbb_config (config_name, config_value) VALUES ('enable_post_confirm', '1');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('flood_interval', '15');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('force_server_vars', '0'); +INSERT INTO phpbb_config (config_name, config_value) VALUES ('form_token_lifetime', '7200'); +INSERT INTO phpbb_config (config_name, config_value) VALUES ('form_token_mintime', '0');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('forward_pm', '1');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('forwarded_for_check', '0');  INSERT INTO phpbb_config (config_name, config_value) VALUES ('full_folder_action', '2'); diff --git a/phpBB/install/schemas/sqlite_schema.sql b/phpBB/install/schemas/sqlite_schema.sql index 546cfb0321..f5156144e2 100644 --- a/phpBB/install/schemas/sqlite_schema.sql +++ b/phpBB/install/schemas/sqlite_schema.sql @@ -924,7 +924,8 @@ CREATE TABLE phpbb_users (  	user_occ text(65535) NOT NULL DEFAULT '',  	user_interests text(65535) NOT NULL DEFAULT '',  	user_actkey varchar(32) NOT NULL DEFAULT '', -	user_newpasswd varchar(32) NOT NULL DEFAULT '' +	user_newpasswd varchar(32) NOT NULL DEFAULT '', +	user_form_salt varchar(32) NOT NULL DEFAULT ''  );  CREATE INDEX phpbb_users_user_birthday ON phpbb_users (user_birthday); diff --git a/phpBB/language/en/acp/board.php b/phpBB/language/en/acp/board.php index 1918b6eacf..f52d53f58f 100644 --- a/phpBB/language/en/acp/board.php +++ b/phpBB/language/en/acp/board.php @@ -364,6 +364,8 @@ $lang = array_merge($lang, array(  	'EMAIL_CHECK_MX_EXPLAIN'		=> 'If enabled, the e-mail domain provided on registration and profile changes is checked for a valid MX record.',  	'FORCE_PASS_CHANGE'				=> 'Force password change',  	'FORCE_PASS_CHANGE_EXPLAIN'		=> 'Require user to change their password after a set number of days. Setting this value to 0 disables this behaviour.', +	'FORM_TIME_MAX'					=> 'Maximum time to submit forms', +	'FORM_TIME_MAX_EXPLAIN'			=> 'The time a user has to submit a form. Use -1 to disable. Note that a form might become invalid if the session expires, regardless of this setting.',  	'FORWARDED_FOR_VALID'			=> 'Validated <var>X_FORWARDED_FOR</var> header',  	'FORWARDED_FOR_VALID_EXPLAIN'	=> 'Sessions will only be continued if the sent <var>X_FORWARDED_FOR</var> header equals the one sent with the previous request. Bans will be checked against IPs in <var>X_FORWARDED_FOR</var> too.',  	'IP_VALID'						=> 'Session IP validation', diff --git a/phpBB/language/en/common.php b/phpBB/language/en/common.php index f83fa46244..33ffab19cb 100644 --- a/phpBB/language/en/common.php +++ b/phpBB/language/en/common.php @@ -178,6 +178,7 @@ $lang = array_merge($lang, array(  	'FIND_USERNAME'			=> 'Find a member',  	'FOLDER'				=> 'Folder',  	'FORGOT_PASS'			=> 'I forgot my password', +	'FORM_INVALID'			=> 'The submitted form was invalid. Try submitting again.',  	'FORUM'					=> 'Forum',  	'FORUMS'				=> 'Forums',  	'FORUMS_MARKED'			=> 'All forums have been marked read.', diff --git a/phpBB/memberlist.php b/phpBB/memberlist.php index 417ba5e100..0d1a9576ac 100644 --- a/phpBB/memberlist.php +++ b/phpBB/memberlist.php @@ -73,7 +73,7 @@ switch ($mode)  	case 'leaders':  		// Display a listing of board admins, moderators  		include($phpbb_root_path . 'includes/functions_user.' . $phpEx); -	 +  		$page_title = $user->lang['THE_TEAM'];  		$template_html = 'memberlist_leaders.html'; @@ -127,7 +127,7 @@ switch ($mode)  		// Get group memberships for the admin id ary...  		$admin_memberships = group_memberships($admin_group_id, $admin_id_ary); -		 +  		$admin_user_ids = array();  		if (!empty($admin_memberships)) @@ -268,6 +268,7 @@ switch ($mode)  	break;  	case 'contact': +  		$page_title = $user->lang['IM_USER'];  		$template_html = 'memberlist_im.html'; @@ -327,36 +328,46 @@ switch ($mode)  		switch ($action)  		{  			case 'jabber': +				add_form_key('memberlist_messaging'); +  				if ($submit && @extension_loaded('xml') && $config['jab_enable'])  				{ -					include_once($phpbb_root_path . 'includes/functions_messenger.' . $phpEx); +					if (check_form_key('memberlist_messaging')) +					{ -					$subject = sprintf($user->lang['IM_JABBER_SUBJECT'], $user->data['username'], $config['server_name']); -					$message = utf8_normalize_nfc(request_var('message', '', true)); +						include_once($phpbb_root_path . 'includes/functions_messenger.' . $phpEx); -					if (empty($message)) -					{ -						trigger_error('EMPTY_MESSAGE_IM'); -					} +						$subject = sprintf($user->lang['IM_JABBER_SUBJECT'], $user->data['username'], $config['server_name']); +						$message = utf8_normalize_nfc(request_var('message', '', true)); -					$messenger = new messenger(false); +						if (empty($message)) +						{ +							trigger_error('EMPTY_MESSAGE_IM'); +						} -					$messenger->template('profile_send_im', $row['user_lang']); -					$messenger->subject(htmlspecialchars_decode($subject)); +						$messenger = new messenger(false); -					$messenger->replyto($user->data['user_email']); -					$messenger->im($row['user_jabber'], $row['username']); +						$messenger->template('profile_send_im', $row['user_lang']); +						$messenger->subject(htmlspecialchars_decode($subject)); -					$messenger->assign_vars(array( -						'BOARD_CONTACT'	=> $config['board_contact'], -						'FROM_USERNAME'	=> htmlspecialchars_decode($user->data['username']), -						'TO_USERNAME'	=> htmlspecialchars_decode($row['username']), -						'MESSAGE'		=> htmlspecialchars_decode($message)) -					); +						$messenger->replyto($user->data['user_email']); +						$messenger->im($row['user_jabber'], $row['username']); -					$messenger->send(NOTIFY_IM); +						$messenger->assign_vars(array( +							'BOARD_CONTACT'	=> $config['board_contact'], +							'FROM_USERNAME'	=> htmlspecialchars_decode($user->data['username']), +							'TO_USERNAME'	=> htmlspecialchars_decode($row['username']), +							'MESSAGE'		=> htmlspecialchars_decode($message)) +						); -					$s_select = 'S_SENT_JABBER'; +						$messenger->send(NOTIFY_IM); + +						$s_select = 'S_SENT_JABBER'; +					} +					else +					{ +						trigger_error('FORM_INVALID'); +					}  				}  			break;  		} @@ -588,7 +599,7 @@ switch ($mode)  					$inactive_reason = $user->lang['INACTIVE_REASON_REMIND'];  				break;  			} -	 +  			$template->assign_vars(array(  				'S_USER_INACTIVE'		=> true,  				'USER_INACTIVE_REASON'	=> $inactive_reason) @@ -607,6 +618,8 @@ switch ($mode)  		$page_title = $user->lang['SEND_EMAIL'];  		$template_html = 'memberlist_email.html'; +		add_form_key('memberlist_email'); +  		if (!$config['email_enable'])  		{  			trigger_error('EMAIL_DISABLED'); @@ -713,6 +726,10 @@ switch ($mode)  		if ($submit)  		{ +			if (!check_form_key('memberlist_email')) +			{ +				$error[] = 'FORM_INVALID'; +			}  			if ($user_id)  			{  				if (!$subject) @@ -834,7 +851,7 @@ switch ($mode)  			$template->assign_vars(array(  				'S_SEND_USER'	=> true,  				'USERNAME'		=> $row['username'], -	 +  				'L_EMAIL_BODY_EXPLAIN'	=> $user->lang['EMAIL_BODY_EXPLAIN'],  				'S_POST_ACTION'			=> append_sid("{$phpbb_root_path}memberlist.$phpEx", 'mode=email&u=' . $user_id))  			); @@ -900,6 +917,7 @@ switch ($mode)  		// then only admins can make use of this (for ACP functionality)  		$sql_select = $sql_where_data = $sql_from = $sql_where = $order_by = ''; +  		$form			= request_var('form', '');  		$field			= request_var('field', '');  		$select_single 	= request_var('select_single', false); @@ -907,7 +925,6 @@ switch ($mode)  		// We validate form and field here, only id/class allowed  		$form = (!preg_match('/^[a-z0-9_-]+$/i', $form)) ? '' : $form;  		$field = (!preg_match('/^[a-z0-9_-]+$/i', $field)) ? '' : $field; -  		if ($mode == 'searchuser' && ($config['load_search'] || $auth->acl_get('a_')))  		{  			$username	= request_var('username', '', true); @@ -1338,7 +1355,7 @@ switch ($mode)  				$id_cache[$row['user_id']] = $row;  			}  			$db->sql_freeresult($result); -				 +  			// Load custom profile fields  			if ($config['load_cpf_memberlist'])  			{ @@ -1394,7 +1411,7 @@ switch ($mode)  				unset($id_cache[$user_id]);  			}  		} -	 +  		// Generate page  		$template->assign_vars(array(  			'PAGINATION'	=> generate_pagination($pagination_url, $total_users, $config['topics_per_page'], $start), diff --git a/phpBB/posting.php b/phpBB/posting.php index 2204b872f2..fc401b865d 100644 --- a/phpBB/posting.php +++ b/phpBB/posting.php @@ -45,6 +45,7 @@ $mode		= ($delete && !$preview && !$refresh && $submit) ? 'delete' : request_var  $error = $post_data = array();  $current_time = time(); +  // Was cancel pressed? If so then redirect to the appropriate page  if ($cancel || ($current_time - $lastclick < 2 && $submit))  { @@ -611,7 +612,7 @@ if ($submit || $preview || $refresh)  	if ($poll_delete && $mode == 'edit' && sizeof($post_data['poll_options']) &&   		((!$post_data['poll_last_vote'] && $post_data['poster_id'] == $user->data['user_id'] && $auth->acl_get('f_delete', $forum_id)) || $auth->acl_get('m_delete', $forum_id)))  	{ -		if ($submit) +		if ($submit && 	check_form_key('posting'))  		{  			$sql = 'DELETE FROM ' . POLL_OPTIONS_TABLE . "  				WHERE topic_id = $topic_id"; @@ -762,6 +763,12 @@ if ($submit || $preview || $refresh)  		}  	} +	// check form +	if (!check_form_key('posting', false, '', false, 2)) +	{ +		$error[] = $user->lang['FORM_INVALID']; +	} +  	// Parse subject  	if (!$preview && !$refresh && !utf8_clean_string($post_data['post_subject']) && ($mode == 'post' || ($mode == 'edit' && $post_data['topic_first_post_id'] == $post_id)))  	{ @@ -1262,6 +1269,8 @@ if ($solved_captcha !== false)  }  $form_enctype = (@ini_get('file_uploads') == '0' || strtolower(@ini_get('file_uploads')) == 'off' || @ini_get('file_uploads') == '0' || !$config['allow_attachments'] || !$auth->acl_get('u_attach') || !$auth->acl_get('f_attach', $forum_id)) ? '' : ' enctype="multipart/form-data"'; +add_form_key('posting'); +  // Start assigning vars for main posting page ...  $template->assign_vars(array( diff --git a/phpBB/styles/prosilver/template/confirm_body.html b/phpBB/styles/prosilver/template/confirm_body.html index 5b783915a4..bc61b0a392 100644 --- a/phpBB/styles/prosilver/template/confirm_body.html +++ b/phpBB/styles/prosilver/template/confirm_body.html @@ -1,6 +1,7 @@  <!-- INCLUDE overall_header.html -->  <form id="confirm" action="{S_CONFIRM_ACTION}" method="post"> +{S_FORM_TOKEN}  <div class="panel">  	<div class="inner"><span class="corners-top"><span></span></span> diff --git a/phpBB/styles/prosilver/template/index_body.html b/phpBB/styles/prosilver/template/index_body.html index 1214ebb946..95e9304943 100644 --- a/phpBB/styles/prosilver/template/index_body.html +++ b/phpBB/styles/prosilver/template/index_body.html @@ -16,7 +16,8 @@  <!-- IF not S_USER_LOGGED_IN and not S_IS_BOT -->  	<form method="post" action="{S_LOGIN_ACTION}" class="headerspace"> -		<h3><a href="{U_LOGIN_LOGOUT}">{L_LOGIN_LOGOUT}</a>  •  <a href="{U_REGISTER}">{L_REGISTER}</a></h3> +	{S_FORM_TOKEN} +	<h3><a href="{U_LOGIN_LOGOUT}">{L_LOGIN_LOGOUT}</a>  •  <a href="{U_REGISTER}">{L_REGISTER}</a></h3>  		<fieldset class="quick-login">  			<label for="username">{L_USERNAME}:</label> <input type="text" name="username" id="username" size="10" class="inputbox" title="{L_USERNAME}" />    			<label for="password">{L_PASSWORD}:</label> <input type="password" name="password" id="password" size="10" class="inputbox" title="{L_PASSWORD}" /> diff --git a/phpBB/styles/prosilver/template/login_body.html b/phpBB/styles/prosilver/template/login_body.html index 90e53975d2..f928f24fd1 100644 --- a/phpBB/styles/prosilver/template/login_body.html +++ b/phpBB/styles/prosilver/template/login_body.html @@ -1,6 +1,7 @@  <!-- INCLUDE overall_header.html -->  <form action="{S_LOGIN_ACTION}" method="post" id="login"> +{S_FORM_TOKEN}  <div class="panel">  	<div class="inner"><span class="corners-top"><span></span></span> diff --git a/phpBB/styles/prosilver/template/login_forum.html b/phpBB/styles/prosilver/template/login_forum.html index 6d388da120..1278a2e9a8 100644 --- a/phpBB/styles/prosilver/template/login_forum.html +++ b/phpBB/styles/prosilver/template/login_forum.html @@ -3,7 +3,7 @@  <h2 class="solo">{L_LOGIN} {FORUM_NAME}</h2>  <form id="login_forum" method="post" action="{S_LOGIN_ACTION}"> - +{S_FORM_TOKEN}  <div class="panel">  	<div class="inner"><span class="corners-top"><span></span></span> diff --git a/phpBB/styles/prosilver/template/mcp_approve.html b/phpBB/styles/prosilver/template/mcp_approve.html index 64f9f0542f..ddc0080125 100644 --- a/phpBB/styles/prosilver/template/mcp_approve.html +++ b/phpBB/styles/prosilver/template/mcp_approve.html @@ -1,7 +1,7 @@  <!-- INCLUDE overall_header.html -->  <form id="confirm" action="{S_CONFIRM_ACTION}" method="post"> - +{S_FORM_TOKEN}  <div class="panel">  	<div class="inner"><span class="corners-top"><span></span></span> diff --git a/phpBB/styles/prosilver/template/mcp_ban.html b/phpBB/styles/prosilver/template/mcp_ban.html index 3bfc7b41d1..2b0c1df9e7 100644 --- a/phpBB/styles/prosilver/template/mcp_ban.html +++ b/phpBB/styles/prosilver/template/mcp_ban.html @@ -122,7 +122,7 @@  	</div>  	<!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_forum.html b/phpBB/styles/prosilver/template/mcp_forum.html index 1f07777530..c612f72ad2 100644 --- a/phpBB/styles/prosilver/template/mcp_forum.html +++ b/phpBB/styles/prosilver/template/mcp_forum.html @@ -101,7 +101,7 @@  	<input class="button2" type="submit" value="{L_SUBMIT}" />  	<div><a href="#" onclick="marklist('mcp', 'topic_id_list', true); return false;">{L_MARK_ALL}</a> :: <a href="#" onclick="marklist('mcp', 'topic_id_list', false); return false;">{L_UNMARK_ALL}</a></div>  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_front.html b/phpBB/styles/prosilver/template/mcp_front.html index 71126aab01..3431d4f925 100644 --- a/phpBB/styles/prosilver/template/mcp_front.html +++ b/phpBB/styles/prosilver/template/mcp_front.html @@ -55,7 +55,7 @@  		<div><a href="#" onclick="marklist('mcp_queue', 'post_id_list', true); return false;">{L_MARK_ALL}</a> :: <a href="#" onclick="marklist('mcp_queue', 'post_id_list', false); return false;">{L_UNMARK_ALL}</a></div>  	</fieldset>  	<!-- ENDIF --> - +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/styles/prosilver/template/mcp_logs.html b/phpBB/styles/prosilver/template/mcp_logs.html index fb82e4168c..415cee547d 100644 --- a/phpBB/styles/prosilver/template/mcp_logs.html +++ b/phpBB/styles/prosilver/template/mcp_logs.html @@ -79,6 +79,7 @@  			<span class="corners-bottom"><span></span></span></div>  		</div>  	<!-- ENDIF --> +	{S_FORM_TOKEN}  </form>  <br /> diff --git a/phpBB/styles/prosilver/template/mcp_move.html b/phpBB/styles/prosilver/template/mcp_move.html index cde4f95257..59c69795d1 100644 --- a/phpBB/styles/prosilver/template/mcp_move.html +++ b/phpBB/styles/prosilver/template/mcp_move.html @@ -30,7 +30,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_notes_front.html b/phpBB/styles/prosilver/template/mcp_notes_front.html index b54115f7e8..dda7ff90d3 100644 --- a/phpBB/styles/prosilver/template/mcp_notes_front.html +++ b/phpBB/styles/prosilver/template/mcp_notes_front.html @@ -22,7 +22,7 @@  	<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submituser" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_notes_user.html b/phpBB/styles/prosilver/template/mcp_notes_user.html index 480ec47b3a..19f2faacbe 100644 --- a/phpBB/styles/prosilver/template/mcp_notes_user.html +++ b/phpBB/styles/prosilver/template/mcp_notes_user.html @@ -116,7 +116,7 @@  	<div><a href="#" onclick="marklist('mcp', 'marknote', true); return false;">{L_MARK_ALL}</a> • <a href="#" onclick="marklist('mcp', 'marknote', false); return false;">{L_UNMARK_ALL}</a></div>		  </fieldset>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_post.html b/phpBB/styles/prosilver/template/mcp_post.html index 7ccec8f7e8..5a3ba7f24c 100644 --- a/phpBB/styles/prosilver/template/mcp_post.html +++ b/phpBB/styles/prosilver/template/mcp_post.html @@ -33,7 +33,7 @@  		<input class="button2" type="submit" value="{L_DELETE_REPORT}" name="action[delete]" />  		<input type="hidden" name="report_id_list[]" value="{REPORT_ID}" />  	</fieldset> - +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> @@ -61,7 +61,7 @@  				<input class="button2" type="submit" value="{L_DISAPPROVE}" name="action[disapprove]" />  				<input type="hidden" name="post_id_list[]" value="{POST_ID}" />  			</p> - +		{S_FORM_TOKEN}  			</form>  		<!-- ENDIF --> @@ -122,7 +122,7 @@  				</dd>  			</dl>  			</fieldset> - +			{S_FORM_TOKEN}  			</form>  		<!-- ENDIF --> @@ -139,7 +139,7 @@  				</dd>  			</dl>  			</fieldset> - +			{S_FORM_TOKEN}  			</form>  		<!-- ENDIF --> @@ -197,7 +197,7 @@  				<input class="button1" type="submit" name="action[add_feedback]" value="{L_SUBMIT}" />    				<input class="button2" type="reset" value="{L_RESET}" />  			</fieldset> - +			{S_FORM_TOKEN}  			</form>  			<span class="corners-bottom"><span></span></span></div> diff --git a/phpBB/styles/prosilver/template/mcp_queue.html b/phpBB/styles/prosilver/template/mcp_queue.html index 744b46e380..805d7d7e09 100644 --- a/phpBB/styles/prosilver/template/mcp_queue.html +++ b/phpBB/styles/prosilver/template/mcp_queue.html @@ -90,7 +90,7 @@  		<div><a href="#" onclick="marklist('mcp', 'post_id_list', true); return false;">{L_MARK_ALL}</a> :: <a href="#" onclick="marklist('mcp', 'post_id_list', false); return false;">{L_UNMARK_ALL}</a></div>  	</fieldset>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_reports.html b/phpBB/styles/prosilver/template/mcp_reports.html index 89c9276f3d..a515c4f7ed 100644 --- a/phpBB/styles/prosilver/template/mcp_reports.html +++ b/phpBB/styles/prosilver/template/mcp_reports.html @@ -79,7 +79,7 @@  		<div><a href="#" onclick="marklist('mcp', 'report_id_list', true); return false;">{L_MARK_ALL}</a> :: <a href="#" onclick="marklist('mcp', 'report_id_list', false); return false;">{L_UNMARK_ALL}</a></div>  	</fieldset>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_topic.html b/phpBB/styles/prosilver/template/mcp_topic.html index acbe140ebf..111030914d 100644 --- a/phpBB/styles/prosilver/template/mcp_topic.html +++ b/phpBB/styles/prosilver/template/mcp_topic.html @@ -164,6 +164,7 @@ onload_functions.push('subPanels()');  </fieldset>  {S_HIDDEN_FIELDS} +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_viewlogs.html b/phpBB/styles/prosilver/template/mcp_viewlogs.html index 862fad9df7..fb02c4e9de 100644 --- a/phpBB/styles/prosilver/template/mcp_viewlogs.html +++ b/phpBB/styles/prosilver/template/mcp_viewlogs.html @@ -38,7 +38,7 @@  	</tr>  <!-- END log -->  </table> - +{S_FORM_TOKEN}  </form>  <table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/prosilver/template/mcp_warn_front.html b/phpBB/styles/prosilver/template/mcp_warn_front.html index d6b81c685d..e861136463 100644 --- a/phpBB/styles/prosilver/template/mcp_warn_front.html +++ b/phpBB/styles/prosilver/template/mcp_warn_front.html @@ -24,7 +24,7 @@  	<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submituser" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <div class="panel"> diff --git a/phpBB/styles/prosilver/template/mcp_warn_list.html b/phpBB/styles/prosilver/template/mcp_warn_list.html index df922c015e..250d542808 100644 --- a/phpBB/styles/prosilver/template/mcp_warn_list.html +++ b/phpBB/styles/prosilver/template/mcp_warn_list.html @@ -60,7 +60,7 @@  </div> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_warn_post.html b/phpBB/styles/prosilver/template/mcp_warn_post.html index f420a10bf6..1fb0ea0a0a 100644 --- a/phpBB/styles/prosilver/template/mcp_warn_post.html +++ b/phpBB/styles/prosilver/template/mcp_warn_post.html @@ -66,7 +66,7 @@  	<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="action[add_warning]" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/mcp_warn_user.html b/phpBB/styles/prosilver/template/mcp_warn_user.html index 2dcb75fbe2..64ed5b0085 100644 --- a/phpBB/styles/prosilver/template/mcp_warn_user.html +++ b/phpBB/styles/prosilver/template/mcp_warn_user.html @@ -50,7 +50,7 @@  	<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="action[add_warning]" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/memberlist_email.html b/phpBB/styles/prosilver/template/memberlist_email.html index 0d1babd1b7..ce4eec9ad8 100644 --- a/phpBB/styles/prosilver/template/memberlist_email.html +++ b/phpBB/styles/prosilver/template/memberlist_email.html @@ -58,7 +58,7 @@  	</div>  	<span class="corners-bottom"><span></span></span></div>  </div> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/memberlist_im.html b/phpBB/styles/prosilver/template/memberlist_im.html index 667f68f2c0..e6174510b7 100644 --- a/phpBB/styles/prosilver/template/memberlist_im.html +++ b/phpBB/styles/prosilver/template/memberlist_im.html @@ -81,7 +81,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div>  <a  href="#" onclick="window.close(); return false;">{L_CLOSE_WINDOW}</a> - +{S_FORM_TOKEN}  </form>  <script type="text/javascript"> diff --git a/phpBB/styles/prosilver/template/memberlist_search.html b/phpBB/styles/prosilver/template/memberlist_search.html index 72f96e7988..f79f192983 100644 --- a/phpBB/styles/prosilver/template/memberlist_search.html +++ b/phpBB/styles/prosilver/template/memberlist_search.html @@ -117,5 +117,5 @@ function insert_single(user)  	<span class="corners-bottom"><span></span></span></div>  </div> - +{S_FORM_TOKEN}  </form> diff --git a/phpBB/styles/prosilver/template/posting_layout.html b/phpBB/styles/prosilver/template/posting_layout.html index f858c3818b..754d8a5218 100644 --- a/phpBB/styles/prosilver/template/posting_layout.html +++ b/phpBB/styles/prosilver/template/posting_layout.html @@ -77,7 +77,7 @@  <!-- IF S_SHOW_POLL_BOX or S_POLL_DELETE --><!-- INCLUDE posting_poll_body.html --><!-- ENDIF -->  <!-- IF S_DISPLAY_REVIEW --><!-- INCLUDE posting_topic_review.html --><!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- IF not S_PRIVMSGS -->  <script type="text/javascript"> diff --git a/phpBB/styles/prosilver/template/report_body.html b/phpBB/styles/prosilver/template/report_body.html index d67fe90b98..7046df36d3 100644 --- a/phpBB/styles/prosilver/template/report_body.html +++ b/phpBB/styles/prosilver/template/report_body.html @@ -45,6 +45,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div> +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_agreement.html b/phpBB/styles/prosilver/template/ucp_agreement.html index e2b7312e33..99ca73ec2f 100644 --- a/phpBB/styles/prosilver/template/ucp_agreement.html +++ b/phpBB/styles/prosilver/template/ucp_agreement.html @@ -27,6 +27,7 @@  	</div>  	{S_HIDDEN_FIELDS} +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_AGREEMENT --> diff --git a/phpBB/styles/prosilver/template/ucp_attachments.html b/phpBB/styles/prosilver/template/ucp_attachments.html index c2866c28e2..36c02c25da 100644 --- a/phpBB/styles/prosilver/template/ucp_attachments.html +++ b/phpBB/styles/prosilver/template/ucp_attachments.html @@ -73,7 +73,7 @@  		<div><a href="#" onclick="marklist('ucp', 'attachment', true); return false;">{L_MARK_ALL}</a> • <a href="#" onclick="marklist('ucp', 'attachment', false); return false;">{L_UNMARK_ALL}</a></div>  	</fieldset>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_footer.html b/phpBB/styles/prosilver/template/ucp_footer.html index ce28ae7c4e..9b5821671a 100644 --- a/phpBB/styles/prosilver/template/ucp_footer.html +++ b/phpBB/styles/prosilver/template/ucp_footer.html @@ -6,6 +6,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div>  <!-- IF S_COMPOSE_PM --> +{S_FORM_TOKEN}  </form>  <!-- ENDIF --> diff --git a/phpBB/styles/prosilver/template/ucp_groups_manage.html b/phpBB/styles/prosilver/template/ucp_groups_manage.html index 2af1a0317a..e9c67a0f10 100644 --- a/phpBB/styles/prosilver/template/ucp_groups_manage.html +++ b/phpBB/styles/prosilver/template/ucp_groups_manage.html @@ -221,7 +221,7 @@  </div>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_groups_membership.html b/phpBB/styles/prosilver/template/ucp_groups_membership.html index b40f6d6b18..b6327a9324 100644 --- a/phpBB/styles/prosilver/template/ucp_groups_membership.html +++ b/phpBB/styles/prosilver/template/ucp_groups_membership.html @@ -158,7 +158,7 @@  	<!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_main_bookmarks.html b/phpBB/styles/prosilver/template/ucp_main_bookmarks.html index 0011e48c92..8613921907 100644 --- a/phpBB/styles/prosilver/template/ucp_main_bookmarks.html +++ b/phpBB/styles/prosilver/template/ucp_main_bookmarks.html @@ -69,7 +69,7 @@  		<div><a href="#" onclick="marklist('ucp', '', true); return false;">{L_MARK_ALL}</a> • <a href="#" onclick="marklist('ucp', '', false); return false;">{L_UNMARK_ALL}</a></div>  	</fieldset>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_main_drafts.html b/phpBB/styles/prosilver/template/ucp_main_drafts.html index a7a952fa02..a012df0095 100644 --- a/phpBB/styles/prosilver/template/ucp_main_drafts.html +++ b/phpBB/styles/prosilver/template/ucp_main_drafts.html @@ -65,6 +65,7 @@  	<!-- ENDIF -->  <!-- ENDIF --> +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_main_subscribed.html b/phpBB/styles/prosilver/template/ucp_main_subscribed.html index a6fae14507..f2d7ddc6f1 100644 --- a/phpBB/styles/prosilver/template/ucp_main_subscribed.html +++ b/phpBB/styles/prosilver/template/ucp_main_subscribed.html @@ -84,7 +84,7 @@  		<div><a href="#" onclick="marklist('ucp', '', true); return false;">{L_MARK_ALL}</a> • <a href="#" onclick="marklist('ucp', '', false); return false;">{L_UNMARK_ALL}</a></div>  	</fieldset>  <!-- ENDIF --> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_pm_message_footer.html b/phpBB/styles/prosilver/template/ucp_pm_message_footer.html index 18ba5216bf..1063d15857 100644 --- a/phpBB/styles/prosilver/template/ucp_pm_message_footer.html +++ b/phpBB/styles/prosilver/template/ucp_pm_message_footer.html @@ -1,2 +1,2 @@ - +{S_FORM_TOKEN}  </form> diff --git a/phpBB/styles/prosilver/template/ucp_pm_options.html b/phpBB/styles/prosilver/template/ucp_pm_options.html index f383b08768..3fe24f04ee 100644 --- a/phpBB/styles/prosilver/template/ucp_pm_options.html +++ b/phpBB/styles/prosilver/template/ucp_pm_options.html @@ -125,7 +125,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html b/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html index b3d161421c..76608ee8cf 100644 --- a/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html +++ b/phpBB/styles/prosilver/template/ucp_pm_viewfolder.html @@ -28,6 +28,7 @@  		<input class="button1" type="submit" name="submit_export" value="{L_EXPORT_FOLDER}" />   		<input class="button2" type="reset" value="Reset" name="reset" />   	</fieldset> +	{S_FORM_TOKEN}  	</form>  <!-- ELSE --> diff --git a/phpBB/styles/prosilver/template/ucp_prefs_personal.html b/phpBB/styles/prosilver/template/ucp_prefs_personal.html index fe277cd373..a95bd19260 100644 --- a/phpBB/styles/prosilver/template/ucp_prefs_personal.html +++ b/phpBB/styles/prosilver/template/ucp_prefs_personal.html @@ -102,7 +102,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <script type="text/javascript"> diff --git a/phpBB/styles/prosilver/template/ucp_prefs_post.html b/phpBB/styles/prosilver/template/ucp_prefs_post.html index 87f906d245..cc505f9100 100644 --- a/phpBB/styles/prosilver/template/ucp_prefs_post.html +++ b/phpBB/styles/prosilver/template/ucp_prefs_post.html @@ -45,7 +45,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_prefs_view.html b/phpBB/styles/prosilver/template/ucp_prefs_view.html index b33d6f748b..2df8713971 100644 --- a/phpBB/styles/prosilver/template/ucp_prefs_view.html +++ b/phpBB/styles/prosilver/template/ucp_prefs_view.html @@ -88,7 +88,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_profile_avatar.html b/phpBB/styles/prosilver/template/ucp_profile_avatar.html index e5a8d59677..ae010a6f28 100644 --- a/phpBB/styles/prosilver/template/ucp_profile_avatar.html +++ b/phpBB/styles/prosilver/template/ucp_profile_avatar.html @@ -13,7 +13,7 @@  	<input type="reset" value="{L_RESET}" name="reset" class="button2" />  <!-- ENDIF -->  	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_profile_profile_info.html b/phpBB/styles/prosilver/template/ucp_profile_profile_info.html index 2a40bcd53e..0266e22881 100644 --- a/phpBB/styles/prosilver/template/ucp_profile_profile_info.html +++ b/phpBB/styles/prosilver/template/ucp_profile_profile_info.html @@ -73,7 +73,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_profile_reg_details.html b/phpBB/styles/prosilver/template/ucp_profile_reg_details.html index a7009ecf23..de41b9c440 100644 --- a/phpBB/styles/prosilver/template/ucp_profile_reg_details.html +++ b/phpBB/styles/prosilver/template/ucp_profile_reg_details.html @@ -57,7 +57,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_profile_signature.html b/phpBB/styles/prosilver/template/ucp_profile_signature.html index f1015cc820..c3dc11cd0d 100644 --- a/phpBB/styles/prosilver/template/ucp_profile_signature.html +++ b/phpBB/styles/prosilver/template/ucp_profile_signature.html @@ -45,7 +45,7 @@  	<input type="submit" name="preview" value="{L_PREVIEW}" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_register.html b/phpBB/styles/prosilver/template/ucp_register.html index 723aeff517..dad72c5aa6 100644 --- a/phpBB/styles/prosilver/template/ucp_register.html +++ b/phpBB/styles/prosilver/template/ucp_register.html @@ -117,7 +117,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_remind.html b/phpBB/styles/prosilver/template/ucp_remind.html index 5114e4dec8..e90d8e5f06 100644 --- a/phpBB/styles/prosilver/template/ucp_remind.html +++ b/phpBB/styles/prosilver/template/ucp_remind.html @@ -26,6 +26,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div> +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_resend.html b/phpBB/styles/prosilver/template/ucp_resend.html index a1d3d5c193..fa73fafabe 100644 --- a/phpBB/styles/prosilver/template/ucp_resend.html +++ b/phpBB/styles/prosilver/template/ucp_resend.html @@ -27,6 +27,7 @@  	<span class="corners-bottom"><span></span></span></div>  </div> +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_zebra_foes.html b/phpBB/styles/prosilver/template/ucp_zebra_foes.html index b1d448fd11..e1e3cd05c7 100644 --- a/phpBB/styles/prosilver/template/ucp_zebra_foes.html +++ b/phpBB/styles/prosilver/template/ucp_zebra_foes.html @@ -35,7 +35,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/ucp_zebra_friends.html b/phpBB/styles/prosilver/template/ucp_zebra_friends.html index fd5bcba07c..30af33df1a 100644 --- a/phpBB/styles/prosilver/template/ucp_zebra_friends.html +++ b/phpBB/styles/prosilver/template/ucp_zebra_friends.html @@ -35,7 +35,7 @@  	{S_HIDDEN_FIELDS}<input type="reset" value="{L_RESET}" name="reset" class="button2" />    	<input type="submit" name="submit" value="{L_SUBMIT}" class="button1" />  </fieldset> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/prosilver/template/viewtopic_body.html b/phpBB/styles/prosilver/template/viewtopic_body.html index 814546f46e..0fbaecaf43 100644 --- a/phpBB/styles/prosilver/template/viewtopic_body.html +++ b/phpBB/styles/prosilver/template/viewtopic_body.html @@ -104,7 +104,7 @@  		<span class="corners-bottom"><span></span></span></div>  	</div> - +	{S_FORM_TOKEN}  	{S_HIDDEN_FIELDS}  	</form> @@ -258,6 +258,7 @@  	<fieldset class="quickmod">  		<label>{L_QUICK_MOD}:</label> {S_TOPIC_MOD} <input type="submit" value="{L_GO}" class="button2" />  	</fieldset> +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/styles/subsilver2/template/index_body.html b/phpBB/styles/subsilver2/template/index_body.html index 3ec8bac1fb..3958743229 100644 --- a/phpBB/styles/subsilver2/template/index_body.html +++ b/phpBB/styles/subsilver2/template/index_body.html @@ -78,7 +78,7 @@  		<td class="row1" align="center"><span class="genmed">{L_USERNAME}:</span> <input class="post" type="text" name="username" size="10" />  <span class="genmed">{L_PASSWORD}:</span> <input class="post" type="password" name="password" size="10" />  <!-- IF S_AUTOLOGIN_ENABLED --> <span class="gensmall">{L_LOG_ME_IN}</span> <input type="checkbox" class="radio" name="autologin" /><!-- ENDIF -->  <input type="submit" class="btnmain" name="login" value="{L_LOGIN}" /></td>  	</tr>  	</table> -	 +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> diff --git a/phpBB/styles/subsilver2/template/login_body.html b/phpBB/styles/subsilver2/template/login_body.html index 2462914756..bc66ece6d4 100644 --- a/phpBB/styles/subsilver2/template/login_body.html +++ b/phpBB/styles/subsilver2/template/login_body.html @@ -89,6 +89,7 @@  	<td class="cat" <!-- IF not S_ADMIN_AUTH or S_CONFIRM_CODE -->colspan="2"<!-- ENDIF --> align="center">{S_HIDDEN_FIELDS}<input type="submit" name="login" class="btnmain" value="{L_LOGIN}" tabindex="5" /></td>  </tr>  </table> +{S_FORM_TOKEN}  </form> diff --git a/phpBB/styles/subsilver2/template/login_forum.html b/phpBB/styles/subsilver2/template/login_forum.html index 0ede67154e..c3d57085df 100644 --- a/phpBB/styles/subsilver2/template/login_forum.html +++ b/phpBB/styles/subsilver2/template/login_forum.html @@ -31,7 +31,7 @@  		<td class="cat" colspan="2" align="center">{S_HIDDEN_FIELDS}<input type="submit" name="login" class="btnmain" value="{L_LOGIN}" tabindex="3" /></td>  	</tr>  	</table> -	 +	{S_FORM_TOKEN}  	</form>  </div> diff --git a/phpBB/styles/subsilver2/template/mcp_approve.html b/phpBB/styles/subsilver2/template/mcp_approve.html index 22b89cff47..2d2013f05c 100644 --- a/phpBB/styles/subsilver2/template/mcp_approve.html +++ b/phpBB/styles/subsilver2/template/mcp_approve.html @@ -35,6 +35,7 @@  		</td>  	</tr>  	</table> +	{S_FORM_TOKEN}  	</form>  </div> diff --git a/phpBB/styles/subsilver2/template/mcp_ban.html b/phpBB/styles/subsilver2/template/mcp_ban.html index 442b6ee4db..04f90530c9 100644 --- a/phpBB/styles/subsilver2/template/mcp_ban.html +++ b/phpBB/styles/subsilver2/template/mcp_ban.html @@ -103,7 +103,7 @@  	</tr>  <!-- ENDIF -->  </table> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE mcp_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/subsilver2/template/mcp_forum.html b/phpBB/styles/subsilver2/template/mcp_forum.html index cf7fe7fee3..956d253aa6 100644 --- a/phpBB/styles/subsilver2/template/mcp_forum.html +++ b/phpBB/styles/subsilver2/template/mcp_forum.html @@ -73,7 +73,7 @@  	</td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/subsilver2/template/mcp_front.html b/phpBB/styles/subsilver2/template/mcp_front.html index e42c29471a..122f5283ae 100644 --- a/phpBB/styles/subsilver2/template/mcp_front.html +++ b/phpBB/styles/subsilver2/template/mcp_front.html @@ -38,7 +38,7 @@  		<td class="cat" colspan="6" align="center"><input class="btnmain" type="submit" name="action[approve]" value="{L_APPROVE}" />  <input class="btnlite" type="submit" name="action[disapprove]" value="{L_DISAPPROVE}" /></td>  	</tr>  	</table> -	 +	{S_FORM_TOKEN}  	</form>  	<table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/subsilver2/template/mcp_logs.html b/phpBB/styles/subsilver2/template/mcp_logs.html index e163cf35d0..f7c4a99fc1 100644 --- a/phpBB/styles/subsilver2/template/mcp_logs.html +++ b/phpBB/styles/subsilver2/template/mcp_logs.html @@ -35,7 +35,7 @@  	</tr>  <!-- ENDIF -->  </table> - +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/mcp_move.html b/phpBB/styles/subsilver2/template/mcp_move.html index 6e2356044f..db7a6e7241 100644 --- a/phpBB/styles/subsilver2/template/mcp_move.html +++ b/phpBB/styles/subsilver2/template/mcp_move.html @@ -29,7 +29,7 @@  		</td>  	</tr>  	</table> -	 +	{S_FORM_TOKEN}	  	</form>  </div> diff --git a/phpBB/styles/subsilver2/template/mcp_notes_front.html b/phpBB/styles/subsilver2/template/mcp_notes_front.html index a805be6749..17f389f7f3 100644 --- a/phpBB/styles/subsilver2/template/mcp_notes_front.html +++ b/phpBB/styles/subsilver2/template/mcp_notes_front.html @@ -14,7 +14,7 @@  	<td class="cat" colspan="2" align="center"><input type="submit" name="submituser" value="{L_SUBMIT}" class="btnmain" /></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/mcp_notes_user.html b/phpBB/styles/subsilver2/template/mcp_notes_user.html index 895c0d35e6..80ac96edf2 100644 --- a/phpBB/styles/subsilver2/template/mcp_notes_user.html +++ b/phpBB/styles/subsilver2/template/mcp_notes_user.html @@ -114,7 +114,7 @@  	<td align="{S_CONTENT_FLOW_END}"><span class="pagination"><!-- INCLUDE pagination.html --></span></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/mcp_post.html b/phpBB/styles/subsilver2/template/mcp_post.html index ad3e0df07c..36f7eefe04 100644 --- a/phpBB/styles/subsilver2/template/mcp_post.html +++ b/phpBB/styles/subsilver2/template/mcp_post.html @@ -33,6 +33,7 @@  	</table>  	<input type="hidden" name="report_id_list[]" value="{REPORT_ID}" /> +	{S_FORM_TOKEN}  	</form>  	<br clear="all"/> @@ -104,7 +105,7 @@  	<input type="hidden" name="post_id_list[]" value="{POST_ID}" />  <!-- ENDIF -->  </table> - +{S_FORM_TOKEN}  </form>  <!-- IF S_MCP_QUEUE --> @@ -132,7 +133,7 @@  		<!-- IF S_CAN_LOCK_POST or S_CAN_DELETE_POST -->  			<tr>  				<td class="row1" valign="top"><b class="gen">{L_MOD_OPTIONS}</b></td> -				<td class="row2"><form method="post" name="mcp" action="{U_MCP_ACTION}"><select name="action"><!-- IF S_CAN_LOCK_POST --><!-- IF S_POST_LOCKED --><option value="unlock_post">{L_UNLOCK_POST} [{L_UNLOCK_POST_EXPLAIN}]</option><!-- ELSE --><option value="lock_post">{L_LOCK_POST} [{L_LOCK_POST_EXPLAIN}]</option><!-- ENDIF --><!-- ENDIF --><!-- IF S_CAN_DELETE_POST --><option value="delete_post">{L_DELETE_POST}</option><!-- ENDIF --></select> <input class="btnmain" type="submit" value="{L_SUBMIT}" /></form></td> +				<td class="row2"><form method="post" name="mcp" action="{U_MCP_ACTION}"><select name="action"><!-- IF S_CAN_LOCK_POST --><!-- IF S_POST_LOCKED --><option value="unlock_post">{L_UNLOCK_POST} [{L_UNLOCK_POST_EXPLAIN}]</option><!-- ELSE --><option value="lock_post">{L_LOCK_POST} [{L_LOCK_POST_EXPLAIN}]</option><!-- ENDIF --><!-- ENDIF --><!-- IF S_CAN_DELETE_POST --><option value="delete_post">{L_DELETE_POST}</option><!-- ENDIF --></select> <input class="btnmain" type="submit" value="{L_SUBMIT}" />	{S_FORM_TOKEN}</form></td>  			</tr>  		<!-- ENDIF -->  		</table> diff --git a/phpBB/styles/subsilver2/template/mcp_queue.html b/phpBB/styles/subsilver2/template/mcp_queue.html index 65c8adbbc8..4def047e51 100644 --- a/phpBB/styles/subsilver2/template/mcp_queue.html +++ b/phpBB/styles/subsilver2/template/mcp_queue.html @@ -34,7 +34,7 @@  	<td class="cat" colspan="4" align="center"><input class="btnmain" type="submit" name="action[approve]" value="{L_APPROVE}" />  <input class="btnlite" type="submit" name="action[disapprove]" value="{L_DISAPPROVE}" /></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/subsilver2/template/mcp_reports.html b/phpBB/styles/subsilver2/template/mcp_reports.html index 3b746c9932..72b26e8751 100644 --- a/phpBB/styles/subsilver2/template/mcp_reports.html +++ b/phpBB/styles/subsilver2/template/mcp_reports.html @@ -43,7 +43,7 @@  	</td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/subsilver2/template/mcp_topic.html b/phpBB/styles/subsilver2/template/mcp_topic.html index 456b1679e0..2b66c8702a 100644 --- a/phpBB/styles/subsilver2/template/mcp_topic.html +++ b/phpBB/styles/subsilver2/template/mcp_topic.html @@ -147,6 +147,7 @@  </tr>  </table>  {S_HIDDEN_FIELDS} +{S_FORM_TOKEN}  </form>  <table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/subsilver2/template/mcp_viewlogs.html b/phpBB/styles/subsilver2/template/mcp_viewlogs.html index 8f5a0753fb..b6431e4d51 100644 --- a/phpBB/styles/subsilver2/template/mcp_viewlogs.html +++ b/phpBB/styles/subsilver2/template/mcp_viewlogs.html @@ -39,7 +39,7 @@  	</tr>  <!-- END log -->  </table> - +{S_FORM_TOKEN}  </form>  <table width="100%" cellspacing="2" cellpadding="2" border="0" align="center"> diff --git a/phpBB/styles/subsilver2/template/mcp_warn_front.html b/phpBB/styles/subsilver2/template/mcp_warn_front.html index fc127bc25c..78673b690e 100644 --- a/phpBB/styles/subsilver2/template/mcp_warn_front.html +++ b/phpBB/styles/subsilver2/template/mcp_warn_front.html @@ -14,7 +14,7 @@  	<td class="cat" colspan="2" align="center"><input type="submit" name="submituser" value="{L_SUBMIT}" class="btnmain" /></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/mcp_warn_list.html b/phpBB/styles/subsilver2/template/mcp_warn_list.html index 9b1d6c13ac..078bbc0b34 100644 --- a/phpBB/styles/subsilver2/template/mcp_warn_list.html +++ b/phpBB/styles/subsilver2/template/mcp_warn_list.html @@ -35,7 +35,7 @@  	<td align="{S_CONTENT_FLOW_END}"><span class="pagination"><!-- INCLUDE pagination.html --></span></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/mcp_warn_post.html b/phpBB/styles/subsilver2/template/mcp_warn_post.html index 957e9416d8..f12b1a4ba8 100644 --- a/phpBB/styles/subsilver2/template/mcp_warn_post.html +++ b/phpBB/styles/subsilver2/template/mcp_warn_post.html @@ -51,6 +51,7 @@  	<td class="cat" align="center"><input class="btnmain" type="submit" name="action[add_warning]" value="{L_SUBMIT}" />  <input class="btnlite" type="reset" value="{L_RESET}" /></td>  </tr>  </table> +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/mcp_warn_user.html b/phpBB/styles/subsilver2/template/mcp_warn_user.html index 96ad4fb1a6..5e8c350935 100644 --- a/phpBB/styles/subsilver2/template/mcp_warn_user.html +++ b/phpBB/styles/subsilver2/template/mcp_warn_user.html @@ -65,6 +65,7 @@  	<td class="cat" align="center"><input class="btnmain" type="submit" name="action[add_warning]" value="{L_SUBMIT}" />  <input class="btnlite" type="reset" value="{L_RESET}" /></td>  </tr>  </table> +{S_FORM_TOKEN}  </form>  <br clear="all" /><br /> diff --git a/phpBB/styles/subsilver2/template/memberlist_body.html b/phpBB/styles/subsilver2/template/memberlist_body.html index 836d0ce5df..cb7a7b20c7 100644 --- a/phpBB/styles/subsilver2/template/memberlist_body.html +++ b/phpBB/styles/subsilver2/template/memberlist_body.html @@ -22,6 +22,7 @@  	<!-- ENDIF -->  		</tr>  		</table> +		{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> @@ -88,6 +89,7 @@  	<td class="cat" colspan="<!-- IF S_IN_SEARCH_POPUP -->9<!-- ELSE -->8<!-- ENDIF -->" align="center"><!-- IF S_IN_SEARCH_POPUP and not S_SELECT_SINGLE --><input class="btnlite" type="submit" value="{L_SELECT_MARKED}" /><!-- ELSE --><span class="gensmall">{L_SELECT_SORT_METHOD}:</span> <select name="sk">{S_MODE_SELECT}</select>  <span class="gensmall">{L_ORDER}</span> <select name="sd">{S_ORDER_SELECT}</select>  <input type="submit" name="submit" value="{L_SUBMIT}" class="btnlite" /><!-- ENDIF --></td>  </tr>  </table> +{S_FORM_TOKEN}  </form> diff --git a/phpBB/styles/subsilver2/template/memberlist_email.html b/phpBB/styles/subsilver2/template/memberlist_email.html index ba6c194fc9..976ac1ad89 100644 --- a/phpBB/styles/subsilver2/template/memberlist_email.html +++ b/phpBB/styles/subsilver2/template/memberlist_email.html @@ -55,6 +55,8 @@  		<td class="cat" colspan="2" align="center"><input type="submit" tabindex="6" name="submit" class="btnmain" value="{L_SEND_EMAIL}" /></td>  	</tr>  	</table> + +	{S_FORM_TOKEN}  	</form> diff --git a/phpBB/styles/subsilver2/template/memberlist_im.html b/phpBB/styles/subsilver2/template/memberlist_im.html index 05c53808c6..acbe1fec2f 100644 --- a/phpBB/styles/subsilver2/template/memberlist_im.html +++ b/phpBB/styles/subsilver2/template/memberlist_im.html @@ -132,6 +132,7 @@  	</table>  	<a class="nav" href="#" onclick="window.close(); return false;">{L_CLOSE_WINDOW}</a> +{S_FORM_TOKEN}  </form> diff --git a/phpBB/styles/subsilver2/template/memberlist_search.html b/phpBB/styles/subsilver2/template/memberlist_search.html index c6e08dc815..f718c568ca 100644 --- a/phpBB/styles/subsilver2/template/memberlist_search.html +++ b/phpBB/styles/subsilver2/template/memberlist_search.html @@ -133,7 +133,7 @@  	<td class="cat" colspan="4" align="center"><input class="btnlite" type="submit" name="submit" value="{L_SEARCH}" />  <input class="btnlite" type="reset" value="{L_RESET}" /></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <br clear="all" /> diff --git a/phpBB/styles/subsilver2/template/posting_body.html b/phpBB/styles/subsilver2/template/posting_body.html index b94c972773..a1cd573768 100644 --- a/phpBB/styles/subsilver2/template/posting_body.html +++ b/phpBB/styles/subsilver2/template/posting_body.html @@ -397,7 +397,7 @@  <!-- ELSE -->  	<!-- INCLUDE breadcrumbs.html --> - +	{S_FORM_TOKEN}  	</form>  	<!-- IF S_DISPLAY_ONLINE_LIST --> diff --git a/phpBB/styles/subsilver2/template/report_body.html b/phpBB/styles/subsilver2/template/report_body.html index 83e33b4761..6861d28ce1 100644 --- a/phpBB/styles/subsilver2/template/report_body.html +++ b/phpBB/styles/subsilver2/template/report_body.html @@ -29,6 +29,7 @@  	<td class="cat" colspan="2" align="center"><input type="submit" name="submit" class="btnmain" value="{L_SUBMIT}" /> <input type="submit" name="cancel" class="btnlite" value="{L_CANCEL}" /></td>  </tr>  </table> +{S_FORM_TOKEN}  </form>  <br clear="all" /> diff --git a/phpBB/styles/subsilver2/template/ucp_agreement.html b/phpBB/styles/subsilver2/template/ucp_agreement.html index d01a040a7a..f695228d00 100644 --- a/phpBB/styles/subsilver2/template/ucp_agreement.html +++ b/phpBB/styles/subsilver2/template/ucp_agreement.html @@ -29,6 +29,7 @@  	</tr>  	</table>  	{S_HIDDEN_FIELDS} +	{S_FORM_TOKEN}  	</form>  <!-- ELSEIF S_AGREEMENT --> diff --git a/phpBB/styles/subsilver2/template/ucp_footer.html b/phpBB/styles/subsilver2/template/ucp_footer.html index a6d1dec7a7..e7b84390c7 100644 --- a/phpBB/styles/subsilver2/template/ucp_footer.html +++ b/phpBB/styles/subsilver2/template/ucp_footer.html @@ -1,8 +1,8 @@ -	<!-- IF not S_PRIVMSGS or S_SHOW_DRAFTS --></form><!-- ENDIF --></td> +	<!-- IF not S_PRIVMSGS or S_SHOW_DRAFTS -->	{S_FORM_TOKEN}</form><!-- ENDIF --></td>  </tr>  </table> -<!-- IF S_SHOW_PM_BOX and S_POST_ACTION --></form><!-- ENDIF --> +<!-- IF S_SHOW_PM_BOX and S_POST_ACTION -->{S_FORM_TOKEN}</form><!-- ENDIF -->  <br clear="all" /> diff --git a/phpBB/styles/subsilver2/template/ucp_pm_message_footer.html b/phpBB/styles/subsilver2/template/ucp_pm_message_footer.html index b65ab40129..36965bff5f 100644 --- a/phpBB/styles/subsilver2/template/ucp_pm_message_footer.html +++ b/phpBB/styles/subsilver2/template/ucp_pm_message_footer.html @@ -1,5 +1,6 @@  <!-- IF not S_VIEW_MESSAGE --> +	{S_FORM_TOKEN}  	</form>  <!-- ENDIF --> @@ -24,11 +25,14 @@  							<input type="hidden" name="cur_folder_id" value="{CUR_FOLDER_ID}" />  							<input type="hidden" name="p" value="{MSG_ID}" />  							<select name="dest_folder">{S_TO_FOLDER_OPTIONS}</select> <input class="btnlite" type="submit" name="move_pm" value="{L_MOVE_TO_FOLDER}" /> +						{S_FORM_TOKEN} +						{S_FORM_TOKEN}  						</form>  					<!-- ENDIF -->  				<!-- ELSE -->  					<form name="sortmsg" method="post" action="{S_PM_ACTION}" style="margin:0px">  						<span class="gensmall">{L_DISPLAY_MESSAGES}:</span> {S_SELECT_SORT_DAYS} <span class="gensmall">{L_SORT_BY}</span> {S_SELECT_SORT_KEY} {S_SELECT_SORT_DIR} <input class="btnlite" type="submit" name="sort" value="{L_GO}" /> +					{S_FORM_TOKEN}  					</form>  				<!-- ENDIF -->  			</td> diff --git a/phpBB/styles/subsilver2/template/ucp_pm_options.html b/phpBB/styles/subsilver2/template/ucp_pm_options.html index 111dcc9e3c..3ff18d8c15 100644 --- a/phpBB/styles/subsilver2/template/ucp_pm_options.html +++ b/phpBB/styles/subsilver2/template/ucp_pm_options.html @@ -187,5 +187,6 @@  	<td class="row1" colspan="2" align="{S_CONTENT_FLOW_END}"><input class="btnlite" style="width:150px" type="submit" name="fullfolder" value="{L_CHANGE}" /></td>  </tr>  </table> +{S_FORM_TOKEN}  </form>  <!-- INCLUDE ucp_footer.html --> diff --git a/phpBB/styles/subsilver2/template/ucp_pm_viewfolder.html b/phpBB/styles/subsilver2/template/ucp_pm_viewfolder.html index 57c05afcc7..36998f18c1 100644 --- a/phpBB/styles/subsilver2/template/ucp_pm_viewfolder.html +++ b/phpBB/styles/subsilver2/template/ucp_pm_viewfolder.html @@ -33,6 +33,7 @@  		<td class="cat" colspan="2" align="center"><input type="hidden" name="export_option" value="CSV" /><input class="btnmain" type="submit" name="submit_export" value="{L_EXPORT_FOLDER}" />  <input class="btnlite" type="reset" value="Reset" name="reset" /></td>  	</tr>  	</table> +	{S_FORM_TOKEN}  </form>  <!-- ELSE --> diff --git a/phpBB/styles/subsilver2/template/ucp_register.html b/phpBB/styles/subsilver2/template/ucp_register.html index b465be7570..37f9924e2e 100644 --- a/phpBB/styles/subsilver2/template/ucp_register.html +++ b/phpBB/styles/subsilver2/template/ucp_register.html @@ -105,7 +105,7 @@  	<td class="cat" colspan="2" align="center">{S_HIDDEN_FIELDS}<input class="btnmain" type="submit" name="submit" value="{L_SUBMIT}" />  <input class="btnlite" type="reset" value="{L_RESET}" name="reset" /></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  <!-- INCLUDE overall_footer.html -->
\ No newline at end of file diff --git a/phpBB/styles/subsilver2/template/ucp_remind.html b/phpBB/styles/subsilver2/template/ucp_remind.html index cf724c3f42..b14fbe8305 100644 --- a/phpBB/styles/subsilver2/template/ucp_remind.html +++ b/phpBB/styles/subsilver2/template/ucp_remind.html @@ -20,7 +20,7 @@  	<td class="cat" colspan="2" align="center">{S_HIDDEN_FIELDS}<input type="submit" name="submit" value="{L_SUBMIT}" class="btnmain" />  <input type="reset" value="{L_RESET}" name="reset" class="btnlite" /></td>  </tr>  </table> - +{S_FORM_TOKEN}  </form>  </div> diff --git a/phpBB/styles/subsilver2/template/ucp_resend.html b/phpBB/styles/subsilver2/template/ucp_resend.html index 08b6c6c22a..d9881ce679 100644 --- a/phpBB/styles/subsilver2/template/ucp_resend.html +++ b/phpBB/styles/subsilver2/template/ucp_resend.html @@ -20,6 +20,7 @@  	<td class="cat" colspan="2" align="center">{S_HIDDEN_FIELDS}<input type="submit" name="submit" value="{L_SUBMIT}" class="btnmain" />  <input type="reset" value="{L_RESET}" name="reset" class="btnlite" /></td>  </tr>  </table> +{S_FORM_TOKEN}  </form> diff --git a/phpBB/viewonline.php b/phpBB/viewonline.php index 8690739d91..27f512abc5 100644 --- a/phpBB/viewonline.php +++ b/phpBB/viewonline.php @@ -243,7 +243,7 @@ while ($row = $db->sql_fetchrow($result))  					case 'viewtopic':  						$location = sprintf($user->lang['READING_TOPIC'], $forum_data[$forum_id]['forum_name']);  					break; -	 +  					case 'viewforum':  						$location = sprintf($user->lang['READING_FORUM'], $forum_data[$forum_id]['forum_name']);  					break; | 
