DiskCommon.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380
  1. Namespace.register("U.MD.DK.C"); //网盘功能使用区域
  2. /**
  3. * 获取目录树的一条线上的所有祖先
  4. * @param {string} 操作的目录id
  5. * @param {array} 用户的网盘信息
  6. * @param {object} 在该目录下操作的文件
  7. * @return {array} 得到操作权限数组
  8. */
  9. U.MD.DK.C.getAncestors = function (fileinfo, diskinfo) {
  10. var _dirinfo = fileinfo, //目录数据
  11. _ancestors = [] //这里是需要返回的祖先
  12. ;
  13. //不断的循环寻找自己的祖先
  14. while (_dirinfo) {
  15. _ancestors.push(_dirinfo); //找到后追加
  16. _dirinfo = U.Json.select(diskinfo.directoryOrFiles, { "UserDirectoryID": _dirinfo.UserDirectoryParentID }, 1)[0]; //设置搜索的目录id为上级的id不断的向上搜索祖先
  17. }
  18. return _ancestors; //返回自己的祖先元素
  19. }
  20. /**
  21. * 判断是否具有添加网盘的操作权限 判断是否有添加的权限 和 获取的权限
  22. * @param {string} 操作的目录id
  23. * @param {array} 用户的网盘信息
  24. * @return {array} 文件的权限信息
  25. * 0 目录id
  26. * 1-n 所有涉及到权限信息 (1只允许上传 2只允许下载)
  27. **/
  28. U.MD.DK.C.readWritePermission = function (dirid, diskinfo) {
  29. var i,
  30. _permi,
  31. _dirs = [],
  32. _returns = [],
  33. _fileinfo = U.Json.select(diskinfo.directoryOrFiles, { "UserDirectoryID": dirid }, 1)[0] //获取当前操作目录的目录信息
  34. ;
  35. //该目录未加载或者该目录id加载的不是目录,如我的协同、最近文件等
  36. if (_fileinfo) {
  37. //获取当前操作的目录所有的祖先文件夹
  38. _dirs = U.MD.DK.C.getAncestors(_fileinfo, diskinfo);
  39. _returns.push(_dirs);
  40. //循环所有的祖先集,找出读写权限
  41. for (i = 0; i < _dirs.length; i++) {
  42. _permi = _dirs[i].UserDirectoryEncrypt; //获取该目录的操作权限的方式
  43. if (_permi == "1" || _permi == "2") { //判断是否有上传下载权限
  44. _returns.push(_permi); break;
  45. }
  46. } //获取权限
  47. }
  48. return _returns;
  49. }
  50. /**
  51. * 判断是否具有添加网盘的操作权限 判断是否有添加的权限 和 获取的权限
  52. * @param {string} 操作的目录id
  53. * @param {array} 用户的网盘信息
  54. * @param {object} 在该目录下操作的文件
  55. * @return {array} 得到操作权限数组
  56. * 0 判断该目录是否允许上传 1、自己建立的目录是可以下载的 2、没有限制只允许上传的可以下载
  57. * 1 判断该目录是否允许下载 1、自己建立的目录是可以上传的 2、ftp中没有限制只允许上传的是可以下载
  58. * 2 判断是否具有添加网盘的操作权限 判断是否有添加的权限 和 获取的权限
  59. * 3 获取上传的目录用户对应的临时目录
  60. * 4 判断操作的文件是否有本人有关 包含是本人创建、本人网盘里、在本人创建的群里
  61. */
  62. U.MD.DK.C.getDirectoryPermissions = function (fileordirid, diskinfo) {
  63. diskinfo = diskinfo || US.disk.UserDisk; //需要操作的当前用户的网盘信息
  64. var _isftp, //是否操作ftp
  65. _ismyself, //是否操作本人网盘内容
  66. _isuserdisk, //是否在自己的网盘中
  67. _isgroup, //是否在群里
  68. _isgroupmain,
  69. _permissions = { //所有的权限
  70. "isopen": true, //是否允许打开, 现在所有的文件都有打开权限
  71. "isupadte": true, //是否允许修改, 只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  72. "isdelete": true, //是否允许删除, 只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  73. "iscopy": true, //是否允许复制,现在所有的文件都有复制权限
  74. "isshear": true, //是否允许剪切,只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  75. "isencryption": false, //是否允许加密,展示取消这个功能。
  76. "isreply": true, //是否允许加密,展示取消这个功能。
  77. "isdownload": true, //是否允许下载,只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  78. "isnew": true, //是否允许新建, 只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  79. "ispaste": true, //是否允许粘贴,只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  80. "isrefresh": true, //是否允许刷新, 现在所有的文件都有刷新权限
  81. "isupload": true, //是否允许上传,文件夹设置了不允许下载的文件夹和文件夹下的所有文件都不允许下载,其他都有权限
  82. "isview": true, //是否允许视图切换,所有的文件夹都支持
  83. "isedit": true //是否允许编辑,只有拥有可修改权限的文本文件才能修改
  84. },
  85. _permissioninfo = U.MD.DK.C.readWritePermission(fileordirid, diskinfo), //获取权限
  86. _dirinfo = _permissioninfo[0][_permissioninfo[0].length - 1], //所操作的文件或者是文件夹所操作的目录
  87. _currentfileordir = _permissioninfo[0][0], //当前操作的文件或者文件夹
  88. _readwrite = _permissioninfo.splice(1) //得到文件的读写权限和祖先元素
  89. ;
  90. //如果是群、最新文档,协同文档,则没有权限操作
  91. if (!US.userInfo.userid || _currentfileordir.UserDirectoryID == diskinfo.directoryOrFiles[0].UserDirectoryID || _currentfileordir.UserDirectoryID == diskinfo.directoryOrFiles[1].UserDirectoryID || _currentfileordir.UserDirectoryID == diskinfo.directoryOrFiles[2].UserDirectoryID) {
  92. _permissions = { //所有的权限
  93. "isopen": false, //是否允许打开, 现在所有的文件都有打开权限
  94. "isupadte": false, //是否允许修改, 只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  95. "isdelete": false, //是否允许删除, 只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  96. "iscopy": false, //是否允许复制,现在所有的文件都有复制权限
  97. "isshear": false, //是否允许剪切,只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  98. "isencryption": false, //是否允许加密,展示取消这个功能。
  99. "isreply": false, //是否允许加密,展示取消这个功能。
  100. "isdownload": false, //是否允许上传,只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  101. "isnew": false, //是否允许新建, 只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  102. "ispaste": false, //是否允许粘贴,只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  103. "isrefresh": false, //是否允许刷新, 现在所有的文件都有刷新权限
  104. "isupload": false, //是否允许下载,文件夹设置了不允许下载的文件夹和文件夹下的所有文件都不允许下载,其他都有权限
  105. "isview": false, //是否允许视图切换,所有的文件夹都支持
  106. "isedit": false //是否允许编辑,只有拥有可修改权限的文本文件才能修改
  107. }
  108. }
  109. else if (_currentfileordir.UserDirectoryID == _currentfileordir.GroupID) {
  110. _permissions = { //所有的权限
  111. "isopen": false, //是否允许打开, 现在所有的文件都有打开权限
  112. "isupadte": false, //是否允许修改, 只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  113. "isdelete": false, //是否允许删除, 只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  114. "iscopy": false, //是否允许复制,现在所有的文件都有复制权限
  115. "isshear": false, //是否允许剪切,只有自己的文件,他人添加文件或者文件夹到我的ftp中,或者是我作为群主的群文件
  116. "isencryption": false, //是否允许加密,展示取消这个功能。
  117. "isreply": true, //是否允许加密,展示取消这个功能。
  118. "isdownload": false, //是否允许上传,只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  119. "isnew": true, //是否允许新建, 只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  120. "ispaste": true, //是否允许粘贴,只有自己的文件夹,或者是任何人的ftp文件夹下及下的文件夹,或者是群里
  121. "isrefresh": true, //是否允许刷新, 现在所有的文件都有刷新权限
  122. "isupload": true, //是否允许下载,文件夹设置了不允许下载的文件夹和文件夹下的所有文件都不允许下载,其他都有权限
  123. "isview": true, //是否允许视图切换,所有的文件夹都支持
  124. "isedit": true //是否允许编辑,只有拥有可修改权限的文本文件才能修改
  125. }
  126. }
  127. else {
  128. //在我的ftp中,我可以操作所有人的东西,我具备所有的权限
  129. _isgroup = _dirinfo.GroupID; //是否是群文件
  130. _isftp = diskinfo.directoryid == US.FTPFOLDERID; //判断是否为ftp目录下的文件
  131. _isuserdisk = (diskinfo.userInfo.UserId == diskinfo.operator); //是否是属于自己的网盘
  132. _isgroupmain = U.Json.select(diskinfo.groups, { "UserDirectoryID": _dirinfo.GroupID, "UserId": diskinfo.operator }).length > 0; //判断自己是否是群主
  133. _ismyself = _currentfileordir.UserId == diskinfo.operator; //判断是否是操作本人的文件,群里的文件非本人创建的或者不是自己的群都不为自己的文件
  134. //不是自己的文件,同时不是在ftp,或者不是群主的处理
  135. if (!_ismyself && !_isftp && !_isgroupmain) {
  136. _permissions.isupadte = false; //不允许修改
  137. _permissions.isdelete = false; //不允许删除
  138. _permissions.isshear = false; //不允许剪切
  139. _permissions.isencryption = false; //不允许加密
  140. _permissions.ispaste = false; //不允许粘贴
  141. _permissions.isedit = false; //不允许编辑
  142. //如果不是ftp连新建的权限也取消
  143. if (!_isftp) {
  144. _permissions.isnew = false; //不允许新建
  145. }
  146. }
  147. //1只允许上传
  148. if (!_ismyself && _readwrite.indexOf("1") > -1) {
  149. _permissions.isdownload = false; //不允许下载
  150. _permissions.copy = false; //不允许复制
  151. _permissions.isshear = false; //不允许剪切
  152. }
  153. //2只允许下载
  154. if (!_ismyself && _readwrite.indexOf("2") > -1) {
  155. _permissions.isnew = false; //不允许新建
  156. _permissions.isupload = false; //不允许上传
  157. _permissions.ispaste = false; //不允许粘贴
  158. }
  159. //如果是文件的话就没有视图模式
  160. if (fileordirid && fileordirid.filetype == 1) {
  161. _permissions.isview = false;
  162. }
  163. else {
  164. _permissions.isreply = false;
  165. }
  166. if (!diskinfo.pasteDirOrFile) {
  167. _permissions.ispaste = false; //不允许粘贴
  168. }
  169. }
  170. //选择了多目录的处理
  171. if (diskinfo.selectElement && diskinfo.selectElement.length > 1) {
  172. _permissions.isopen = false; //取消同时打开的功能
  173. _permissions.isupadte = false; //取消修改的功能
  174. }
  175. diskinfo.permissions = _permissions; //设置权限
  176. return _permissions;
  177. }
  178. /**
  179. * 弹出选择网盘还是上传
  180. *
  181. * @param {string} 文件的后缀
  182. * @return {object}
  183. */
  184. U.MD.DK.C.getIcon = function (extendtype) {
  185. var i,
  186. _application = US.disk.applicationTypes //获取所有打开应用的信息
  187. ;
  188. //循环信息中找到指定的应用的信息
  189. for (i in _application) {
  190. //找到后缀名对应的程序信息
  191. if (_application[i].types.indexOf(extendtype.toLowerCase()) > -1) {
  192. return _application[i]; //返回应用的信息
  193. }
  194. }
  195. return _application["unknownfile"]; //如果是本站未知的后缀直接归属于文件
  196. }
  197. /**
  198. * 网盘上传的处理
  199. * @param {object} 获取服务器返回值
  200. * @param {string} 上传文件的唯一识别id
  201. */
  202. U.MD.DK.C.upload = function (diskinfo) {
  203. //判断该目录是否允许上传的处理
  204. if (diskinfo.permissions.isupload) {
  205. var _groupid,
  206. _ancestors,
  207. _directoryid = diskinfo.directoryid,
  208. _dirinfo = U.Json.select(diskinfo.directoryOrFiles, { "UserDirectoryID": _directoryid })[0]
  209. ;
  210. //获取粘贴到制定目录的群id
  211. _ancestors = U.MD.DK.C.getAncestors(_dirinfo, diskinfo); //获取所有的祖先
  212. //如果是ftp目录,那么groupid就是用户id
  213. if (_ancestors[_ancestors.length - 1].UserDirectoryID == US.FTPFOLDERID) {
  214. _groupid = diskinfo.userInfo.UserId;
  215. }
  216. //否则就是对应的群id,如果不存在那么就是""
  217. else {
  218. _groupid = _ancestors[_ancestors.length - 1].GroupID || "";
  219. }
  220. //调用上传处理
  221. U.MD.UI.upload(
  222. "http://main.1473.cn/USUpfile.ashx?typename=UploadFlashfile&DirectoryId=" + _directoryid + "&Encrypt=" + _groupid + "&UserId=" + US.userInfo.userid + "&IsF=true", //上传的地址
  223. //上传成功的回调函数
  224. function (r, fileinfo) {
  225. var _data = r.data //获取服务器返回值
  226. ; //根据文件的唯一识别id获取文件的信息
  227. //获取从服务器获取的值,这里加一个错误处理,因为如果后台出现了错误,那么eval的过程就会失败
  228. try {
  229. _data = eval("0," + _data);
  230. }
  231. catch (e) { }
  232. //文件上传成功
  233. if (_data) {
  234. U.MD.DK.C.success({
  235. "UserFilesServerName": _data[0], //上传成功后存在fs.1473.cn的地址
  236. "UseFilesServerThumbnailName": _data[1], //如果是图片上传,那么这里有缩略图的地址
  237. "UserFilesID": _data[2], //文件在数据的id
  238. "size": _data[3], //文件的大小
  239. "UserDirectoryEncrypt": _data[4], //文件的加密情况,这里和分组id是一样的
  240. "UserDirectoryID": _data[5], //文件归属的目录id
  241. "UserDirectoryName": fileinfo.name
  242. }, _dirinfo, diskinfo);
  243. }
  244. },
  245. //得到md5的回调函数
  246. function (md5, fileinfo, cb) {
  247. //根据用户的md5值判断用户是否需要上传,如果需要上传则需要执行上传处理,如果已经存在后台直接给用户生成文件路径等录入数据库
  248. U.A.Request(US.DISK, ["IfFileExistInsertDB", US.userInfo.userid, _directoryid, _groupid, fileinfo.size, md5, U.UF.UP.getFileNameAndExtension(fileinfo.name)[1], fileinfo.name],
  249. //判断上传文件是否存在
  250. function (r) {
  251. var _userid = US.userInfo.userid; //当前登录用户的id
  252. r = r.value;
  253. //获取服务器返回的值,如果服务器响应出问题了,eval的时候就会报错。
  254. try {
  255. r = eval(r)[0];
  256. }
  257. catch (e) { }
  258. //当用户想上传的文件已经在数据库里存在了,那么后台会执行复制数据的操作。
  259. if (r) {
  260. U.MD.DK.C.success({
  261. "UserFilesServerName": r.UserFilesServerName, //上传成功后存在fs.1473.cn的地址
  262. "UseFilesServerThumbnailName": r.UserDirectoryUrl, //如果是图片上传,那么这里有缩略图的地址
  263. "UserFilesID": r.UserDirectoryID, //文件在数据的id
  264. "size": r.UserDirectorySize, //文件的大小
  265. "UserDirectoryEncrypt": r.UserDirectoryEncrypt, //文件的加密情况,这里和分组id是一样的
  266. "UserDirectoryID": r.UserDirectoryParentID, //文件归属的目录id
  267. "UserDirectoryName": r.UserDirectoryName
  268. }, _dirinfo, diskinfo);
  269. cb(false);
  270. }
  271. //否则调用flash里面的函数执行用户的上传操作。
  272. else {
  273. cb(true);
  274. }
  275. });
  276. });
  277. }
  278. }
  279. /**
  280. * 上传成功直接添加
  281. * @param {object} 获取服务器返回值
  282. * @param {string} 上传文件的唯一识别id
  283. */
  284. U.MD.DK.C.success = function (uploadinfo, dirinfo, diskinfo) {
  285. var _userinfo = US.userInfo, //上传用户的信息
  286. _extendtype = U.UF.UP.getFileNameAndExtension(uploadinfo.UserDirectoryName)[1], //上传文件的后缀名
  287. _img = uploadinfo.UseFilesServerThumbnailName, //上传文件展示到网盘的图片
  288. _groupid = uploadinfo.GroupID,
  289. //上传文件成功后,由前端的数据结构生成一个数据实体,实际传参请参考函数里面的数据结构
  290. _fileinfo = new U.MD.DK.M.entity(
  291. uploadinfo.UserFilesID, //上传文件的id
  292. uploadinfo.size, //上传文件的大小
  293. uploadinfo.UserDirectoryID, //上传文件对应的目录id
  294. uploadinfo.UserDirectoryName.addEllipsis(20), //上传文件的简写名
  295. uploadinfo.UserDirectoryName, //上传文件的名字
  296. _extendtype, //上传文件的后缀
  297. uploadinfo.UserFilesServerName, //上传文件的服务器地址
  298. U.UF.D.toTimeStamp(new Date()), //上传文件成功的时间
  299. _img ? _img : U.MD.DK.C.getIcon(_extendtype)[1], //上传文件展示到网盘的图片
  300. 9999, //上传文件的层次,这里文件是没有层次的,所以以9999区表达
  301. null, //文件的修改时间
  302. uploadinfo.UserDirectoryEncrypt, //上传文件的加密或者是限制
  303. 1, //标识该文件在网盘中识别为文件
  304. "", //上传文件的描述
  305. _groupid, //归属的群id
  306. "", //uw office内容
  307. _userinfo.UserId, //归属用户的id
  308. _userinfo.UserNickName, //归属用户的名字
  309. _userinfo.UserName, //归属用户的用户名
  310. _userinfo.UserThumbnailImageHead //归属用户的头像
  311. );
  312. //如果是上传到网盘的处理
  313. if (_fileinfo) {
  314. U.MD.DK.RE.addFileOrFolder([_fileinfo], diskinfo, dirinfo); //添加值
  315. diskinfo && U.Alert("文件: " + _fileinfo.UserDirectoryName + " 已上传至" + dirinfo.UserallDirectoryName + "目录下");
  316. }
  317. return _fileinfo;
  318. }
  319. /**
  320. * 拖动选择多个元素的处理
  321. * @param {element} 拖动的区域元素
  322. */
  323. U.MD.DK.C.selectElement = function (el, diskinfo) {
  324. var i, classname, hoverclass,
  325. _viewtype = diskinfo.viewtype || "Normal",
  326. _child = $(el).Child();
  327. diskinfo.selectElement = []; //清空所有的选择元素
  328. //如果是在他人邀请 最新文档 我的协同里 则没有拖选按钮
  329. if (U.Json.select(diskinfo.directoryOrFiles, { "UserDirectoryID": diskinfo.directoryid })[0].GroupID !== true) {
  330. //普通视图的处理
  331. if (_viewtype == "Normal") {
  332. classname = "U_MD_DK_RZO";
  333. hoverclass = "U_MD_DK_RZO U_MD_DK_RZOI";
  334. }
  335. //详细视图的处理
  336. else {
  337. classname = "U_MD_DK_RZS U_MD_DK_RZXO";
  338. hoverclass = "U_MD_DK_RZS U_MD_DK_RZXO U_MD_DK_RZXOO";
  339. }
  340. //如果不是空文件状态下的处理
  341. if (_child[0].className != "U_MD_DK_RZF") {
  342. //点击的时候循环清空所有元素选择状态
  343. for (i = 0; i < _child.length; i++) {
  344. //如果元素状态是选中状态的处理
  345. if (_child[i].className == hoverclass) {
  346. _child[i].className = classname;
  347. }
  348. }
  349. //拖动选择处理
  350. U.UF.F.dragSelect(el, function (arr) {
  351. var i,
  352. _isclass;
  353. //循环元素的处理
  354. for (i = 0; i < _child.length; i++) {
  355. _isclass = arr.indexOf(_child[i]);
  356. //判断元素是否
  357. if (_isclass == -1 && _child[i].className == hoverclass) {
  358. _child[i].className = classname;
  359. }
  360. //判断
  361. else if (_isclass > -1) {
  362. _child[i].className = hoverclass;
  363. }
  364. }
  365. diskinfo.selectElement = arr; //得到所有的选择元素
  366. });
  367. }
  368. }
  369. }