using Microsoft.SharePoint;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Text.RegularExpressions;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace MoveFolderToSharePoint
{
   
static class Program
   
{
       
private static int file_count = 0;
       
private static int mbfile_count = 0;
       
static int folder_count = 0;
        private static double file_mb_size = 0;
       
private static int dir_too_count = 0;
       
private static int file_too_count = 0;
       
static System.Data.DataTable table = new System.Data.DataTable();
       
static byte[] byteArr = null;
       
static bool isValid = false;
       
static string illegalChars = "[\\~#%&*{}/:<>?|\"-]";
       
static string replacement = " ";
       
static string dirName = string.Empty;
       
static string FolderPath = string.Empty;
       
static string ListName = string.Empty;
       
static int limitFilesize = 0;
       
///
       
/// Get the file count of a
given directory recursively.
       
///
       
static void Main(string[] args)
       
{
            using
(SPSite site = new SPSite("http://win-2016"))
            {
                using (SPWeb web = site.OpenWeb())
                {
                    // Here we create a DataTable
with four columns.
                    table.Columns.Add("File Name", typeof(string));
                    table.Columns.Add("File Size", typeof(string));
                    table.Columns.Add("File MBSize", typeof(string));
                    table.Columns.Add("SizeStatus", typeof(string));
                    table.Columns.Add("Status", typeof(string));
                    table.Columns.Add("DateTime", typeof(DateTime));
                    table.Columns.Add("File Path", typeof(string));
                    Console.Write("Please enter folder
path : ");
                    FolderPath = Console.ReadLine();
                    Console.Write("Please enter document
library name : ");
                    ListName = Console.ReadLine();
                    Console.Write("Please enter file
size(< MB) : ");
                    limitFilesize = Convert.ToInt32(Console.ReadLine());
                    string dirPath = @"" + FolderPath + "";
                    dirName = Path.GetFileNameWithoutExtension(dirPath);
                    FolderPath = Regex.Replace(FolderPath.Split(':')[1], @"\\", "/");
                    Console.WriteLine("Working on
it...please wait..");
                    System.Data.DataTable tableExport =
GetSubFolder(dirPath, web);
                   
ExportListFromTable(tableExport, dirName + "_AllFileSizeLog");
                    Console.WriteLine("--------------------------------------------------");
                    Console.WriteLine("Total Files Count
==> {0}",
file_count);
                    Console.WriteLine("Total folder Count
==> {0}",
folder_count);
                    Console.WriteLine("-------------------------------------------");
                    Console.WriteLine("Total <100 MB
Files Count ==> {0}", mbfile_count);
                    Console.WriteLine("--------------------------------------------------");
                    Console.WriteLine("dir too big Total
Count ==> {0}",
dir_too_count);
                    Console.WriteLine("Files too big Count
==> {0}",
file_too_count);
                    Console.ReadKey();
                }
            }
       
}
       
/// <summary>
       
/// get folder tree
       
/// </summary>
       
/// <param name="folder"></param>
       
/// <returns></returns>
       
public static System.Data.DataTable GetSubFolder(string folder, SPWeb web)
       
{
    
       try
            {              
                if (folder.Length < 255)
                {
                    string dirPath = Regex.Replace(folder.Split(':')[1], @"\\", "/");
                    dirPath = dirPath.Remove(0,
FolderPath.Length);
                    Console.WriteLine(dirPath);
                    if (!string.IsNullOrEmpty(dirPath))
                    {
                        var folderWeb =
web.CreateFolder(ListName, dirPath);
                    }
                    string[] subFolders = Directory.GetDirectories(folder);
                    foreach (string subFolder in subFolders)
                    {
                        folder_count++;
                        GetSubFolder(subFolder,
web);
                    }
                    string[] files = Directory.GetFiles(folder);
FileInfo fileInfo = null;
                    foreach (string file in files)
                    {
                        string nameFile = Path.GetFileName(file);
                        string filefullPath = file;
                        isValid = Regex.IsMatch(nameFile,
illegalChars, RegexOptions.CultureInvariant);
                        if (isValid)
                        {
                            Regex regEx = new Regex(illegalChars);
       
                    nameFile = Regex.Replace(regEx.Replace(nameFile,
replacement), @"\s+", " ");
                            if (file.Length < 255)
                            {
                                System.IO.File.Move(file, @"" + folder + "\\" + nameFile);
                                filefullPath = @"" + folder + "\\" + nameFile;
                                File.Delete(file);
                            }
                        }
                        long size = 0;
                        if (filefullPath.Length <
255)
                        {
                            fileInfo = new FileInfo(filefullPath);
                            size =
fileInfo.Length;
                            file_mb_size =
ConvertBytesToMegabytes(size);
                            if (file_mb_size <
limitFilesize)
                            {
                                byteArr = File.ReadAllBytes(filefullPath);  // # % * : < > ? / 
                               
web.Files.Add(ListName + dirPath + "/" + nameFile, byteArr, true);
                                Console.WriteLine("File Uploaded("+ file_mb_size.ToString("0.000") + "<"+limitFilesize+"MB) :" + file_count + " :" + nameFile);
                                mbfile_count++;
                               
table.Rows.Add(nameFile, size, file_mb_size.ToString("0.000"), "<100", "Success", DateTime.Now, file);
                            }
                            else
                            {
                                Console.WriteLine("File Omitting..(>100MB) :" + file_count + " :" + nameFile);
                               
table.Rows.Add(nameFile, size, file_mb_size.ToString("0.000"), ">100", "Success", DateTime.Now, file);
                            }
                        }
                        else
                        {
                            Console.WriteLine("File too
big...:"
+ file_count + " :"
+ nameFile);
                        }
                        //truncate files to 255
characters
                        string truncatedFilename = file;
                        if (truncatedFilename.Length
> 255)
                        {
                            file_too_count++;
                            truncatedFilename =
truncatedFilename.Substring(0, 255);
                            //replace any single quote in
filename with two double quotes
                            truncatedFilename =
truncatedFilename.Replace("'",
"''");
                            table.Rows.Add(nameFile, size,
file_mb_size.ToString("0.000"),
"Null", "File Long", DateTime.Now, file);
                        }
                        file_count++;
                    }
                }
                else
                {
    
               dir_too_count++;
                    table.Rows.Add(folder, "0", file_mb_size.ToString("0.000"), "Null", "Folder Long", DateTime.Now, "None");
                }
                return table;
            }
            catch
(Exception ex)
            {
                Console.Write("Error : " + ex.Message);
                Console.Write("Trace : " + ex.StackTrace);
                return table;
            }
       
}
       
/// <summary>
       
/// bytes to MB
       
/// </summary>
       
/// <param name="bytes"></param>
       
/// <returns></returns>
       
static double ConvertBytesToMegabytes(long bytes)
       
{
            return (bytes / 1024f) / 1024f;
       
}
       
/// <summary>
       
/// Ensure SPFolder
       
/// </summary>
       
/// <param name="web"></param>
       
/// <param name="listTitle"></param>
       
/// <param name="folderUrl"></param>
       
/// <returns></returns>
       
public static SPFolder CreateFolder(this SPWeb web, string listTitle, string folderUrl)
       
{
            if
(string.IsNullOrEmpty(folderUrl))
                throw new ArgumentNullException("folderUrl");
            var
list = web.Lists.TryGetList(listTitle);
            return CreateFolderInternal(list, list.RootFolder, folderUrl);
       
}
       
/// <summary>
       
///CreateFolderInternal 
       
/// </summary>
       
/// <param name="list"></param>
       
/// <param name="parentFolder"></param>
       
/// <param name="folderUrl"></param>
       
/// <returns></returns>
       
private static SPFolder CreateFolderInternal(SPList list, SPFolder parentFolder, string folderUrl)
       
{
            var
folderNames = folderUrl.Split(new char[] { '/' }, StringSplitOptions.RemoveEmptyEntries);
            var
folderName = folderNames[0];
            var
curFolder =
               
parentFolder.SubFolders.Cast<SPFolder>()
                            .FirstOrDefault(
                                f =>
                                System.String.Compare(f.Name, folderName,
System.StringComparison.OrdinalIgnoreCase) ==
                                0);
            if
(curFolder == null)
            {
                var folderItem = list.Items.Add(parentFolder.ServerRelativeUrl, SPFileSystemObjectType.Folder,
                                               
folderName);
                folderItem.SystemUpdate();
                curFolder = folderItem.Folder;
            }
            if
(folderNames.Length > 1)
            {
                var subFolderUrl = string.Join("/", folderNames, 1,
folderNames.Length - 1);
                return CreateFolderInternal(list, curFolder, subFolderUrl);
            }
            return curFolder;
       
}
       
/// <summary>
       
/// Export to xls to directory
Path
       
/// </summary>
       
public static void
ExportListFromTable(System.Data.DataTable table, string filename)
       
{
            DirectoryInfo dir = new DirectoryInfo(@"C:\Reports");
            dir.Create();
            string excelFileName = string.Format(@"C:\Reports\" + filename + "_{0}.xls", DateTime.Now.Ticks.ToString());
            FileInfo file = new FileInfo(excelFileName);
            StreamWriter streamWriter = file.CreateText();
            StringWriter stringWriter = new
StringWriter();
            HtmlTextWriter htmlTextWriter = new
HtmlTextWriter(stringWriter);
            Table tblListView = new Table();
            tblListView.ID = "_tblListView";
            tblListView.BorderStyle = BorderStyle.Solid;
            tblListView.BorderWidth = Unit.Pixel(1);
            tblListView.GridLines = GridLines.Horizontal;
            tblListView.BorderColor =
System.Drawing.Color.LightGreen;
            System.Data.DataView dvListViewData = table.DefaultView;
            if
(dvListViewData != null &&
dvListViewData.Count > 0)
            {
                tblListView.Rows.Add(new TableRow());
                tblListView.Rows[0].BackColor =
System.Drawing.Color.LightGreen;
                tblListView.Rows[0].Font.Bold =
true;
                for (int i = 0; i <
table.Columns.Count; i++)
                {
                   
tblListView.Rows[0].Cells.Add(new
TableCell());
                   
tblListView.Rows[0].Cells[i].Text = table.Columns[i].ToString();
                }
                for (int i = 0; i <
dvListViewData.Count; i++)
                {
                    tblListView.Rows.Add(new TableRow());
                    for (int j = 0; j <
table.Columns.Count; j++)
                    {
                        tblListView.Rows[i +
1].BorderStyle = BorderStyle.Dotted;
                        tblListView.Rows[i +
1].Cells.Add(new TableCell());
                        tblListView.Rows[i +
1].Cells[j].Text = dvListViewData[i][j].ToString();
                    }
                }
            }
           
tblListView.RenderControl(htmlTextWriter);
           
streamWriter.Write(stringWriter.ToString());
            htmlTextWriter.Close();
            streamWriter.Close();
            stringWriter.Close();
       
}
   
}
}