| The Arcive of vBulletin Modifications Site. | |
| 
			 
			#1  
			
			
			
			
			
		 | |||
| 
 | |||
|  Security flaw with a function 
			
			So I was using this function earlier today and noticed something function pm_api($pmfromuserid, $pmfromusername, $pmtitle, $pmmessage, $username) { global $vbulletin, $botpermissions; $pmdm =& datamanager_init('PM', $vbulletin, ERRTYPE_ARRAY); $pmdm->set('fromuserid', $pmfromuserid); $pmdm->set('fromusername', $pmfromusername); $pmdm->set('title', $pmtitle); $pmdm->set('message', $pmmessage); $pmdm->set_recipients($username, $botpermissions); $pmdm->set('dateline', TIMENOW); $pmdm->save(); unset($pmdm); return $pmdm; } If the $username doesn't exist, it will print out the whole database with all passwords and the password of the database in an error similar to this: Fatal error: The following users were not found: - Unable to proceed with save while $errors array is not empty in class vB_DataManager_PM in [path]/includes/class_dm.php on line 810 #0 vb_error_handler(256, The following users were not found: - *prints database* So anyway I can prevent it from revealing all this info if it can't find the username? | 
| 
			 
			#2  
			
			
			
			
			
		 | |||
| 
 | |||
|   
			
			I was looking at the code trying to figure out why all that info would be in the error message, but I can't. In any case, if you're not planning to use the error messages, you could try using ERRTYPE_SILENT instead of ERRTYPE_ARRAY (ETA: although now I'm not sure it will actually stop that message from printing). Also, you should change the code to check $pmdm->errors, and don't call $pmdm->save() if errors is set.
		 | 
| 
			 
			#3  
			
			
			
			
			
		 | |||
| 
 | |||
|   
			
			ERRTYPE_SILENT did the job thanks, and I don't know why all that info was put out it was seriously everything in my DB + the db pass and user
		 | 
| 
			 
			#4  
			
			
			
			
			
		 | |||
| 
 | |||
|   
			
			You really should be doing the second part of that (checking errors before calling save()), because it's the call to save() that's triggering an exception and showing all that info.
		 | 
| 
			 
			#5  
			
			
			
			
			
		 | |||
| 
 | |||
|   Quote: 
 function pm_api($pmfromuserid, $pmfromusername, $pmtitle, $pmmessage, $username) { global $vbulletin, $botpermissions; $pmdm =& datamanager_init('PM', $vbulletin, ERRTYPE_ARRAY); $pmdm->set('fromuserid', $pmfromuserid); $pmdm->set('fromusername', $pmfromusername); $pmdm->set('title', $pmtitle); $pmdm->set('message', $pmmessage); $pmdm->set_recipients($username, $botpermissions); $pmdm->set('dateline', TIMENOW); if (!isset($pmdm->errors())) { $pmdm->save(); } unset($pmdm); return $pmdm; } Or simply replacing ->save() with errors() ? | 
| 
			 
			#6  
			
			
			
			
			
		 | |||
| 
 | |||
|   
			
			errors isn't a function, so you can't put the parens after it. Also, the vb code uses empty() instead of !isset() (but I can't remember offhand what the difference is if any - probably either will work).  Oh, and in the vb code it looks like they call pre_save() before checking the errors. Anyway, in the vb code they use: Code: $pmdm->pre_save();
if (empty($pmdm->errors))
{
$pmdm->save();
} | 
| Благодарность от: | ||
| SwalyAaron | ||
| 
			 
			#7  
			
			
			
			
			
		 | ||||
| 
 | ||||
|   Quote: 
 | 
|  | 
| 
 | 
 | 
| X vBulletin 3.8.12 by vBS Debug Information | |
|---|---|
| 
 | |
|  More Information | |
| Template Usage: 
 Phrase Groups Available: 
 | Included Files: 
 Hooks Called: 
 |