NEW FEATURE: Add url upload
This commit is contained in:
		
							parent
							
								
									616cad9768
								
							
						
					
					
						commit
						f004673ea5
					
				
					 5 changed files with 95 additions and 13 deletions
				
			
		| 
						 | 
				
			
			@ -54,19 +54,20 @@ export default [
 | 
			
		|||
	{ name: 'notifications/mark_as_read',     shouldBeSignin: true, kind: 'notification-write' },
 | 
			
		||||
	{ name: 'notifications/mark_as_read_all', shouldBeSignin: true, kind: 'notification-write' },
 | 
			
		||||
 | 
			
		||||
	{ name: 'drive',                shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/stream',         shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files',          shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files/create',   shouldBeSignin: true, limitDuration: hour, limitMax: 100, withFile: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/files/show',     shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files/find',     shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files/delete',   shouldBeSignin: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/files/update',   shouldBeSignin: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/folders',        shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/folders/create', shouldBeSignin: true, limitDuration: hour, limitMax: 50, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/folders/show',   shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/folders/find',   shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/folders/update', shouldBeSignin: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive',                       shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/stream',                shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files',                 shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files/create',          shouldBeSignin: true, limitDuration: hour, limitMax: 100, withFile: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/files/upload_from_url', shouldBeSignin: true, limitDuration: hour, limitMax: 10, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/files/show',            shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files/find',            shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/files/delete',          shouldBeSignin: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/files/update',          shouldBeSignin: true, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/folders',               shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/folders/create',        shouldBeSignin: true, limitDuration: hour, limitMax: 50, kind: 'drive-write' },
 | 
			
		||||
	{ name: 'drive/folders/show',          shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/folders/find',          shouldBeSignin: true, kind: 'drive-read' },
 | 
			
		||||
	{ name: 'drive/folders/update',        shouldBeSignin: true, kind: 'drive-write' },
 | 
			
		||||
 | 
			
		||||
	{ name: 'users',                    shouldBeSignin: false },
 | 
			
		||||
	{ name: 'users/show',               shouldBeSignin: false },
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										55
									
								
								src/api/endpoints/drive/files/upload_from_url.js
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										55
									
								
								src/api/endpoints/drive/files/upload_from_url.js
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,55 @@
 | 
			
		|||
'use strict';
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Module dependencies
 | 
			
		||||
 */
 | 
			
		||||
import * as URL from 'url';
 | 
			
		||||
const download = require('download');
 | 
			
		||||
import * as mongo from 'mongodb';
 | 
			
		||||
import File from '../../../models/drive-file';
 | 
			
		||||
import { validateFileName } from '../../../models/drive-file';
 | 
			
		||||
import User from '../../../models/user';
 | 
			
		||||
import serialize from '../../../serializers/drive-file';
 | 
			
		||||
import create from '../../../common/add-file-to-drive';
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Create a file from a URL
 | 
			
		||||
 *
 | 
			
		||||
 * @param {Object} params
 | 
			
		||||
 * @param {Object} user
 | 
			
		||||
 * @return {Promise<object>}
 | 
			
		||||
 */
 | 
			
		||||
module.exports = (params, user) =>
 | 
			
		||||
	new Promise(async (res, rej) =>
 | 
			
		||||
{
 | 
			
		||||
	// Get 'url' parameter
 | 
			
		||||
	const url = params.url;
 | 
			
		||||
	if (url == null) {
 | 
			
		||||
		return rej('url is required');
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	let name = URL.parse(url).pathname.split('/').pop();
 | 
			
		||||
	if (!validateFileName(name)) {
 | 
			
		||||
		name = null;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Get 'folder_id' parameter
 | 
			
		||||
	let folder = params.folder_id;
 | 
			
		||||
	if (folder === undefined || folder === null) {
 | 
			
		||||
		folder = null;
 | 
			
		||||
	} else {
 | 
			
		||||
		folder = new mongo.ObjectID(folder);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// Download file
 | 
			
		||||
	const data = await download(url);
 | 
			
		||||
 | 
			
		||||
	// Create file
 | 
			
		||||
	const driveFile = await create(user, data, name, null, folder);
 | 
			
		||||
 | 
			
		||||
	// Serialize
 | 
			
		||||
	const fileObj = await serialize(driveFile);
 | 
			
		||||
 | 
			
		||||
	// Response
 | 
			
		||||
	res(fileObj);
 | 
			
		||||
});
 | 
			
		||||
| 
						 | 
				
			
			@ -7,6 +7,9 @@
 | 
			
		|||
			<li onclick={ parent.upload }>
 | 
			
		||||
				<p><i class="fa fa-upload"></i>ファイルをアップロード</p>
 | 
			
		||||
			</li>
 | 
			
		||||
			<li onclick={ parent.urlUpload }>
 | 
			
		||||
				<p><i class="fa fa-cloud-upload"></i>URLからアップロード</p>
 | 
			
		||||
			</li>
 | 
			
		||||
		</ul>
 | 
			
		||||
	</mk-contextmenu>
 | 
			
		||||
	<script>
 | 
			
		||||
| 
						 | 
				
			
			@ -27,5 +30,9 @@
 | 
			
		|||
		@upload = ~>
 | 
			
		||||
			@browser.select-local-file!
 | 
			
		||||
			@refs.ctx.close!
 | 
			
		||||
 | 
			
		||||
		@url-upload = ~>
 | 
			
		||||
			@browser.url-upload!
 | 
			
		||||
			@refs.ctx.close!
 | 
			
		||||
	</script>
 | 
			
		||||
</mk-drive-browser-base-contextmenu>
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -455,6 +455,24 @@
 | 
			
		|||
		@select-local-file = ~>
 | 
			
		||||
			@refs.file-input.click!
 | 
			
		||||
 | 
			
		||||
		@url-upload = ~>
 | 
			
		||||
			url <~ @input-dialog do
 | 
			
		||||
				'URLアップロード'
 | 
			
		||||
				'アップロードしたいファイルのURL'
 | 
			
		||||
				null
 | 
			
		||||
 | 
			
		||||
			if url? and url != ''
 | 
			
		||||
				@api \drive/files/upload_from_url do
 | 
			
		||||
					url: url
 | 
			
		||||
					folder_id: if @folder? then @folder.id else undefined
 | 
			
		||||
 | 
			
		||||
				@dialog do
 | 
			
		||||
					'<i class="fa fa-check"></i>アップロードをリクエストしました'
 | 
			
		||||
					'アップロードが完了するまで時間がかかる場合があります。'
 | 
			
		||||
					[
 | 
			
		||||
						text: \OK
 | 
			
		||||
					]
 | 
			
		||||
 | 
			
		||||
		@create-folder = ~>
 | 
			
		||||
			name <~ @input-dialog do
 | 
			
		||||
				'フォルダー作成'
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue