修改 Chevereto 使其 API 支持相册、描述

这是一篇存档

文件路径:app/app/routes/overrides/route.api.php

<?php

/* --------------------------------------------------------------------

  Chevereto
  http://chevereto.com/

  @author	Rodolfo Berrios A. <http://rodolfoberrios.com/>
			<[email protected]>

  Copyright (C) Rodolfo Berrios A. All rights reserved.
  
  BY USING THIS SOFTWARE YOU DECLARE TO ACCEPT THE CHEVERETO EULA
  http://chevereto.com/license

  --------------------------------------------------------------------- */

  /* API v1 : PLEASE NOTE
	 
	 This API v1 is currently just a bridge to port to Chevereto 3 the API from Chevereto 2.
	 From now on Chevereto 2 API will be named API v1
	 
	 In future releases there will be an API v2 which will add methods like create user, create albums, etc.
	 
  */
  
$route = function($handler) {
	try {
		$version = $handler->request[0];
		$action = $handler->request[1];
		
		if(is_null(CHV\getSetting('api_v1_key')) or CHV\getSetting('api_v1_key') == '') {
			throw new Exception("API v1 key can't be null. Go to your dashboard and set the API v1 key.", 0);
		}
		
		// Change CHV\getSetting('api_v1_key') to 'something' if you want to use 'something' as key
		if(!G\timing_safe_compare(CHV\getSetting('api_v1_key'), $_REQUEST['key'])) {
			throw new Exception("Invalid API v1 key.", 100);
		}
		
		if(!in_array($version, [1])) {
			throw new Exception('Invalid API version.', 110);
		}
		
		$version_to_actions = [
			1 => ['upload']
		];
		
		if(!in_array($action, $version_to_actions[$version])) {
			throw new Exception('Invalid API action.', 120);
		}
		
		// API V1 upload
		$source = isset($_FILES['source']) ? $_FILES['source'] : $_REQUEST['source'];
		
		if(is_null($source)) {
			throw new Exception('Empty upload source.', 130);
		}

		if($_FILES['source']['tmp_name']) { // File?
			$source = $_FILES['source'];
			$type = 'file';
		} else {
			if(!G\is_image_url($source) && !G\is_url($source)) {
			
				// Base64 comes from POST?
				if($_SERVER['REQUEST_METHOD'] !== 'POST') {
					throw new Exception('Upload using base64 source must be done using POST method.', 130);
				}
				
				// Fix the $source base64 string
				$source = trim(preg_replace('/\s+/', '', $source));
				
				// From _GET source should be urlencoded base64
				if(!G\timing_safe_compare(base64_encode(base64_decode($source)), $source)){
					throw new Exception('Invalid base64 string.', 120);
				}
				
				// Set the API temp file		
				$api_temp_file = @tempnam(sys_get_temp_dir(), 'chvtemp');
				
				if(!$api_temp_file or !@is_writable($api_temp_file)) {
					throw new UploadException("Can't get a tempnam.", 200);
				}
					
				$fh = fopen($api_temp_file, 'w');
				stream_filter_append($fh, 'convert.base64-decode', STREAM_FILTER_WRITE);
				if(!@fwrite($fh, $source)) {
					throw new Exception('Invalid base64 string.', 130);
				} else {
					// Since all the validations works with $_FILES, we're going to emulate it.
					$source = array(
						'name'		=> G\random_string(12).'.jpg',
						'type'		=> 'image/jpeg',
						'tmp_name'	=> $api_temp_file,
						'error'		=> 'UPLOAD_ERR_OK',
						'size'		=> '1'
					);
				}
				fclose($fh);
			}
		}
		
		// CHV\Image::uploadToWebsite($source, 'username', [params]) to inject API uploads to a given username
		// 上传到用户 telegrambot 的相册 Telegram
		// 修改 class.image.php isDuplicatedUpload 函数,将 SQL 查询中的 IP、日期条件删除
		// 使用 ID 访问图片,在 route.image.php 33L 后添加:if(((int)$handler->request[0]) > 10) $id = $handler->request[0];
		$album_id = 21;
		if(isset($_REQUEST["album_id"])) {
			$album_id = (int)$_REQUEST["album_id"];
			if($album_id < 0) $album_id = 21;
        }
		$uploaded_id = CHV\Image::uploadToWebsite($source, 'telegrambot', ['album_id' => $album_id, 'description' => (string)urldecode($_REQUEST['description'])]);
		$json_array['status_code'] = 200;
		$json_array['success'] = array('message' => 'image uploaded', 'code' => 200);
		$json_array['image'] = CHV\Image::formatArray(CHV\Image::getSingle($uploaded_id, false, false), true);

		// print_r($source);
		// G\Render\json_output($source['tmp_name']);
		// die();
		// $api_temp_file
		// G\Render\json_output(Image::isDuplicatedUpload(md5_file($api_temp_file)));
		//

		
		if($version == 1) {
			switch($_REQUEST['format']) {
				default:
				case 'json':
					G\Render\json_output($json_array);
				break;
				case 'txt':
					echo $json_array['image']['url'];
				break;
				case 'redirect':
					if($json_array['status_code'] == 200) {
						$redirect_url = $json_array['image']['url_viewer'];
						header("Location: $redirect_url");
					} else {
						die($json_array['status_code']);
					}
				break;
			}
			die();
		} else {
			G\Render\json_output($json_array);
		}
		
	} catch(Exception $e) {
		$json_array = G\json_error($e);
		if($version == 1) {
			switch($_REQUEST['format']) {
				default:
				case 'json':
					G\Render\json_output($json_array);
					break;
				case 'txt':
				case 'redirect':
					die($json_array['error']['message']);
					break;
			}
		} else {
			G\Render\json_output($json_array);
		}
		
	}
};

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据