View Single Post
  #31  
Old 05-01-2002, 08:51 PM
snakes1100 snakes1100 is offline
 
Join Date: Dec 2001
Location: Michigan
Posts: 3,733
Благодарил(а): 0 раз(а)
Поблагодарили: 0 раз(а) в 0 сообщениях
Default

the affected block code you asked for.

this is from my functions.php, this also has the member must have a certain amount of posts to upload hack in it(in bold).

PHP Code:
 ###################### Start acceptupload #######################
function acceptupload($moderate=0) {
  global 
$DB_site,$attachment,$attachment_size,$attachment_name;
  global 
$attachextensions,$maxattachsize,$bbuserinfo,$maxattachwidth$maxattachheight;
  global 
$safeupload,$tmppath$allowduplicates$allowimgsizefailure;

  
$attachment_name strtolower($attachment_name);
  
$extension=getextension($attachment_name);

  if (
strpos("  $attachextensions  ",$extension ")==0) {
    
// invalid extension
    
eval("standarderror(\"".gettemplate("error_attachbadtype")."\");");
    exit;
  }


  if (
is_uploaded_file($attachment)) {
    if (
$safeupload) {
      
$path "$tmppath/$attachment_name";
      
move_uploaded_file($attachment"$path");
      
$attachment $path;
    }

    
$filesize=filesize($attachment);
    if (
$maxattachsize!=and $filesize>$maxattachsize and $bbuserinfo[usergroupid]!=5) {
      
// too big!
      
eval("standarderror(\"".gettemplate("error_attachtoobig")."\");");
      exit;
    }
    if (
$filesize!=$attachment_size and $bbuserinfo[usergroupid]!=5) {
      
// security error
      
eval("standarderror(\"".gettemplate("error_attacherror")."\");");
      exit;
    }
    if (
strstr($attachment,"..")!="") {
      
//security error
      
eval("standarderror(\"".gettemplate("error_attacherror")."\");");
      exit;
    }
    if (
$bbuserinfo["posts"] < 200) {
      
//No Posting Attachments
      
eval("standarderror(\"You don't have enough posts to post attachments.\");");
      exit;
    }
    if (
$extension=="gif" or $extension=="jpg" or $extension=="jpeg" or $extension=="jpe" or $extension=="png" or $extension=="swf") { // Picture file
      
if ($imginfo=@getimagesize($attachment)) {
        if ((
$maxattachwidth>and $imginfo[0]>$maxattachwidth) or ($maxattachheight>and $imginfo[1]>$maxattachheight)) {
          eval(
"standarderror(\"".gettemplate("error_attachbaddimensions")."\");");
        }
        if (!
$imginfo[2]) {
           eval(
"standarderror(\"".gettemplate("error_avatarnotimage")."\");");
        }
      } elseif (!
$allowimgsizefailure) {
          eval(
"standarderror(\"".gettemplate("error_avatarnotimage")."\");");
      }
    }

    
// read file
    
$filenum fopen($attachment,"rb");
    
$filestuff fread($filenum,$filesize);
    
fclose($filenum);
    
unlink($attachment);
    
$visible iif($moderate,0,1);
    
// add to db
    
if (!$allowduplicates) {
      if (
$result=$DB_site->query_first("SELECT attachmentid
                                         FROM attachment
                                         WHERE userid = '
$bbuserinfo[userid]'
                                           AND filedata = '"
.addslashes($filestuff)."'")) {
         
$threadresult=$DB_site->query_first("SELECT post.threadid as threadid,thread.title as title FROM post
                                             LEFT JOIN thread ON (thread.threadid = post.threadid)
                                             WHERE post.attachmentid=
$result[attachmentid]");
        
$threadresult['title'] = htmlspecialchars($threadresult['title']);
        eval(
"standarderror(\"".gettemplate("error_attachexists")."\");");
        exit;
      }
    }
    
$DB_site->query("INSERT INTO attachment (attachmentid,userid,dateline,filename,filedata,visible) VALUES (NULL,$bbuserinfo[userid],".time().",'".addslashes($attachment_name)."','".addslashes($filestuff)."','$visible')");
    
$attachmentid=$DB_site->insert_id();
  }
  return 
$attachmentid;

Reply With Quote
 
X vBulletin 3.8.12 by vBS Debug Information
  • Page Generation 0.01164 seconds
  • Memory Usage 1,841KB
  • Queries Executed 11 (?)
More Information
Template Usage:
  • (1)SHOWTHREAD_SHOWPOST
  • (1)ad_footer_end
  • (1)ad_footer_start
  • (1)ad_header_end
  • (1)ad_header_logo
  • (1)ad_navbar_below
  • (1)bbcode_php
  • (1)footer
  • (1)gobutton
  • (1)header
  • (1)headinclude
  • (6)option
  • (1)post_thanks_box
  • (1)post_thanks_button
  • (1)post_thanks_javascript
  • (1)post_thanks_navbar_search
  • (1)post_thanks_postbit_info
  • (1)postbit
  • (1)postbit_onlinestatus
  • (1)postbit_wrapper
  • (1)spacer_close
  • (1)spacer_open 

Phrase Groups Available:
  • global
  • postbit
  • reputationlevel
  • showthread
Included Files:
  • ./showpost.php
  • ./global.php
  • ./includes/init.php
  • ./includes/class_core.php
  • ./includes/config.php
  • ./includes/functions.php
  • ./includes/class_hook.php
  • ./includes/modsystem_functions.php
  • ./includes/functions_bigthree.php
  • ./includes/class_postbit.php
  • ./includes/class_bbcode.php
  • ./includes/functions_reputation.php
  • ./includes/functions_post_thanks.php 

Hooks Called:
  • init_startup
  • init_startup_session_setup_start
  • init_startup_session_setup_complete
  • cache_permissions
  • fetch_postinfo_query
  • fetch_postinfo
  • fetch_threadinfo_query
  • fetch_threadinfo
  • fetch_foruminfo
  • style_fetch
  • cache_templates
  • global_start
  • parse_templates
  • global_setup_complete
  • showpost_start
  • bbcode_fetch_tags
  • bbcode_create
  • postbit_factory
  • showpost_post
  • postbit_display_start
  • post_thanks_function_post_thanks_off_start
  • post_thanks_function_post_thanks_off_end
  • post_thanks_function_fetch_thanks_start
  • post_thanks_function_fetch_thanks_end
  • post_thanks_function_thanked_already_start
  • post_thanks_function_thanked_already_end
  • fetch_musername
  • postbit_imicons
  • bbcode_parse_start
  • bbcode_parse_complete_precache
  • bbcode_parse_complete
  • postbit_display_complete
  • post_thanks_function_can_thank_this_post_start
  • showpost_complete