FileTableService.cs 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286
  1. using System.Data.SqlClient;
  2. using System.Linq;
  3. using Dapper;
  4. using System.IO;
  5. using System;
  6. using log4net;
  7. using Agent.Models;
  8. using System.Configuration;
  9. namespace Agent.Services
  10. {
  11. class FileTableService
  12. {
  13. private static readonly ILog log = LogManager.GetLogger(typeof(FileTableService));
  14. /// <summary>
  15. /// 디렉토리 조회
  16. /// </summary>
  17. public string GetDirectory(SqlConnection con, string name)
  18. {
  19. try
  20. {
  21. var sql = $@"
  22. SELECT TOP 1 path_locator.ToString()
  23. FROM DI_FILE.[dbo].[di_backup_file]
  24. WHERE 1=1
  25. AND name = @DirectoryName
  26. AND is_directory = 1
  27. ";
  28. return con.Query<string>(sql, new { DirectoryName = name }).SingleOrDefault();
  29. }
  30. catch (Exception)
  31. {
  32. throw;
  33. }
  34. }
  35. /// <summary>
  36. /// 디렉토리 생성
  37. /// </summary>
  38. public string CreateDirectory(SqlConnection con, SqlTransaction transaction, string name, string parentId)
  39. {
  40. try
  41. {
  42. var sql = @"
  43. DECLARE @parent_node hierarchyid, @node hierarchyid
  44. SET @parent_node = CAST(@ParentId AS hierarchyid)
  45. SELECT @node = MAX(path_locator) FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.GetAncestor(1) = @parent_node
  46. INSERT INTO DI_FILE.[dbo].[di_backup_file] ([name], is_directory, path_locator)
  47. OUTPUT
  48. INSERTED.path_locator.ToString()
  49. VALUES (@Name, 1, @parent_node.GetDescendant(@node, NULL))
  50. ";
  51. return con.Query<string>(sql, new { @Name = name, @ParentId = parentId }, transaction).SingleOrDefault();
  52. }
  53. catch (Exception)
  54. {
  55. throw;
  56. }
  57. }
  58. public string CreateDirectory(string name, string parentId)
  59. {
  60. try
  61. {
  62. var sql = @"
  63. DECLARE @parent_node hierarchyid, @node hierarchyid
  64. SET @parent_node = CAST(@ParentId AS hierarchyid)
  65. SELECT @node = MAX(path_locator) FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.GetAncestor(1) = @parent_node
  66. INSERT INTO DI_FILE.[dbo].[di_backup_file] ([name], is_directory, path_locator)
  67. OUTPUT
  68. INSERTED.path_locator.ToString()
  69. VALUES (@Name, 1, @parent_node.GetDescendant(@node, NULL))
  70. ";
  71. using (var con = new SqlConnection(App._myConnection))
  72. {
  73. con.Open();
  74. return con.Query<string>(sql, new { @Name = name, @ParentId = parentId }).SingleOrDefault();
  75. }
  76. }
  77. catch (Exception)
  78. {
  79. return null;
  80. }
  81. }
  82. /// <summary>
  83. /// 디렉토리 생성(시간으로 이름지정)
  84. /// </summary>
  85. /// <param name="con"></param>
  86. /// <param name="transaction"></param>
  87. /// <param name="parentId"></param>
  88. /// <returns></returns>
  89. public string CreateDirectory(SqlConnection con, SqlTransaction transaction, string parentId)
  90. {
  91. try
  92. {
  93. var sql = @"
  94. DECLARE @name nvarchar(100), @parent_node hierarchyid, @node hierarchyid
  95. SET @parent_node = CAST(@ParentId AS hierarchyid)
  96. SELECT @node = MAX(path_locator) FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.GetAncestor(1) = @parent_node
  97. SELECT @name = Convert(varchar(10),Getdate(),112) + Replace(Convert(varchar(8),Getdate(),108),':','')
  98. INSERT INTO DI_FILE.[dbo].[di_backup_file] ([name], is_directory, path_locator)
  99. OUTPUT
  100. INSERTED.path_locator.ToString()
  101. VALUES (@name, 1, @parent_node.GetDescendant(@node, NULL))
  102. ";
  103. return con.Query<string>(sql, new { @ParentId = parentId }, transaction).SingleOrDefault();
  104. }
  105. catch (Exception)
  106. {
  107. throw;
  108. }
  109. }
  110. public string CreateDirectory(string parentId)
  111. {
  112. try
  113. {
  114. var sql = @"
  115. DECLARE @name nvarchar(100), @parent_node hierarchyid, @node hierarchyid
  116. SET @parent_node = CAST(@ParentId AS hierarchyid)
  117. SELECT @node = MAX(path_locator) FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.GetAncestor(1) = @parent_node
  118. SELECT @name = Convert(varchar(10),Getdate(),112) + Replace(Convert(varchar(8),Getdate(),108),':','')
  119. INSERT INTO DI_FILE.[dbo].[di_backup_file] ([name], is_directory, path_locator)
  120. OUTPUT
  121. INSERTED.path_locator.ToString()
  122. VALUES (@name, 1, @parent_node.GetDescendant(@node, NULL))
  123. ";
  124. using (var con = new SqlConnection(App._myConnection))
  125. {
  126. con.Open();
  127. return con.Query<string>(sql, new { @ParentId = parentId }).SingleOrDefault();
  128. }
  129. }
  130. catch (Exception)
  131. {
  132. return null;
  133. }
  134. }
  135. /// <summary>
  136. /// 디렉토리 생성(루트)
  137. /// </summary>
  138. /// <param name="con"></param>
  139. /// <param name="transaction"></param>
  140. /// <param name="name"></param>
  141. /// <returns></returns>
  142. public string CreateDirectoryToRoot(SqlConnection con, SqlTransaction transaction, string name)
  143. {
  144. try
  145. {
  146. var sql = @"
  147. DECLARE @parent_node hierarchyid, @node hierarchyid
  148. SET @parent_node = hierarchyid::GetRoot()
  149. SELECT @node = MAX(path_locator) FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.GetAncestor(1) = @parent_node
  150. INSERT INTO DI_FILE.[dbo].[di_backup_file] ([name], is_directory, path_locator)
  151. OUTPUT
  152. INSERTED.path_locator.ToString()
  153. VALUES (@Name, 1, @parent_node.GetDescendant(@node, NULL))
  154. ";
  155. return con.Query<string>(sql, new { @Name = name }, transaction).SingleOrDefault();
  156. }
  157. catch (Exception)
  158. {
  159. throw;
  160. }
  161. }
  162. /// <summary>
  163. /// 파일 업로드
  164. /// </summary>
  165. /// <param name="con"></param>
  166. /// <param name="transaction"></param>
  167. /// <param name="srcPath"></param>
  168. /// <param name="parentId"></param>
  169. /// <returns></returns>
  170. public Guid UploadFile(SqlConnection con, SqlTransaction transaction, string srcPath, string parentId)
  171. {
  172. try
  173. {
  174. var sql = @"
  175. DECLARE @parent_node hierarchyid, @node hierarchyid
  176. SET @parent_node = CAST(@ParentId AS hierarchyid)
  177. SELECT @node = MAX(path_locator) FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.GetAncestor(1) = @parent_node
  178. INSERT INTO DI_FILE.[dbo].[di_backup_file] ([name], file_stream, path_locator)
  179. OUTPUT
  180. INSERTED.file_stream.PathName() AS Path,
  181. INSERTED.stream_id AS StreamId
  182. VALUES (@Name, @Binary, @parent_node.GetDescendant(@node, NULL))
  183. ";
  184. var fileBinary = File.ReadAllBytes(srcPath);
  185. var insertedFile = con.Query<FileTable>(sql, new { @Name = Path.GetFileName(srcPath), Binary = fileBinary, @ParentId = parentId }, transaction).SingleOrDefault();
  186. return insertedFile.StreamId;
  187. }
  188. catch (Exception)
  189. {
  190. throw;
  191. }
  192. }
  193. /// <summary>
  194. /// 파일 다운로드
  195. /// </summary>
  196. /// <param name="con"></param>
  197. /// <param name="transaction"></param>
  198. /// <param name="dstPath"></param>
  199. /// <param name="streamId"></param>
  200. /// <returns></returns>
  201. public string DownloadFile(SqlConnection con, SqlTransaction transaction, string dstPath, Guid streamId)
  202. {
  203. try
  204. {
  205. if (!Directory.Exists(Path.GetDirectoryName(dstPath)))
  206. {
  207. Directory.CreateDirectory(Path.GetDirectoryName(dstPath));
  208. }
  209. var sql = @"
  210. SELECT TOP 1
  211. file_stream AS binary,
  212. file_stream.PathName() AS Path,
  213. name
  214. FROM DI_FILE.[dbo].[di_backup_file]
  215. WHERE stream_id = @StreamId
  216. ";
  217. var file = con.Query<FileTable>(sql, new { @StreamId = streamId }, transaction).SingleOrDefault();
  218. var tmpDstPath = $@"{Path.GetDirectoryName(dstPath)}\tmp_{Path.GetFileName(dstPath)}";
  219. File.WriteAllBytes(tmpDstPath, file.Binary);
  220. return tmpDstPath;
  221. }
  222. catch (Exception ex)
  223. {
  224. throw;
  225. }
  226. }
  227. /// <summary>
  228. /// 디렉터리 삭제 (자식노드 포함)
  229. /// </summary>
  230. /// <param name="name"></param>
  231. /// <param name="parentId"></param>
  232. /// <returns></returns>
  233. public bool RemoveDirectory(string parentId)
  234. {
  235. try
  236. {
  237. var sql = @"
  238. DECLARE @parent_node hierarchyid
  239. SET @parent_node = CAST(@ParentId AS hierarchyid)
  240. DELETE FROM DI_FILE.[dbo].[di_backup_file] WHERE path_locator.IsDescendantOf(@parent_node) = 1
  241. ";
  242. using (var con = new SqlConnection(App._myConnection))
  243. {
  244. con.Open();
  245. return 0 < con.Execute(sql, new { ParentId = parentId });
  246. }
  247. }
  248. catch (Exception)
  249. {
  250. return false;
  251. }
  252. }
  253. }
  254. }