Greasy Fork

Greasy Fork is available in English.

度盘文件列表、分享页面显示MD5

百度网盘文件列表、分享页面显示分享文件的MD5值。

当前为 2018-02-04 提交的版本,查看 最新版本

// ==UserScript==
// @name        度盘文件列表、分享页面显示MD5
// @author      Crab
// @namespace   [email protected]
// @description 百度网盘文件列表、分享页面显示分享文件的MD5值。
// @include     /^https?://(yun|pan)\.baidu\.com\/(s(hare)?|disk)\/*/
// @compatible  firefox 34+
// @compatible  Chrome 45+
// @version     0.3.1
// @grant       none
// ==/UserScript==

(function(){
	'use strict';

	const {cache, yunData} = window;

	//单文件分享页MD5
	if(yunData && yunData.FILEINFO && yunData.FILEINFO.length === 1 &&
		yunData.FILEINFO[0].isdir !== 1 && yunData.FILEINFO[0].md5
	){
		let fTitle = document.querySelector('h2.file-name');
		if(fTitle){
			fTitle.parentNode.insertAdjacentHTML('beforeend',
			`<dl style="color:#aaa;font-size: 12px;">
					<dt style="float:left;">MD5:</dt>
					<dd style="padding-left: 3em; 
					text-transform: uppercase;">${yunData.FILEINFO[0].md5}</dd>
			</dl>`);
		}
	}

	//文件列表MD5
	if(!cache || Object.keys(cache).length < 1){
		return;
	}

	document.head.appendChild(document.createElement('style')).textContent = `
		@keyframes bdFileMd5 {from{opacity:.9}to{opacity:1}}
		:not(.dir-small):not(.dir-large) 
			+ .file-name .text>a:not([data-md5]){animation:bdFileMd5 1ms}
		.file-name .text>a[data-md5]{position:relative; top: -6px;}
		[class*=fileicon] + .file-name .text>a[data-md5]::after, 
		.default-small + .file-name .text>a[data-md5]::after{
			content:'MD5: 'attr(data-md5); text-transform: uppercase;
			position:absolute; left: -80px; top: 2px; font-size: 95%; color: #aaa;
		}
	`;
	let timeout, dir;
	const getPath = () => {
		let m = location.hash.match(/^#([^/]+)\/(?:[^\/]+?(?![^\/&]).)?(?:path|type)=([^&\?#]+)/);
		if(m){
			m = Array.from(m, decodeURIComponent);
			return {list: m[1], path: m[2]};
		}
		return null;
	}, onAnimationstart = e => {
		if(e.animationName !== 'bdFileMd5')
			return;
		clearTimeout(timeout);
		timeout = setTimeout(() => {dir = null}, 500);

		if(!dir){
			if(!(dir = getPath())){
				return removeEventListener('animationstart', onAnimationstart);
			}
		}

		const {path, list} = dir;
		if(!cache[list].data[path] || !cache[list].data[path].list)
			return;
		const targetName = e.target.textContent,
			fileInfo = cache[list].data[path].list.find(file => {
			tempDiv.innerHTML = file.path.split('/').pop();
			return tempDiv.textContent === targetName;
		});
		if(fileInfo){
			e.target.dataset.md5 = fileInfo.md5;
		}
	}, tempDiv = document.createElement('div');

	addEventListener('animationstart', onAnimationstart);
})();