Exemplo n.º 1
0
 static void Main(string[] args)
 {
     Lettera22Program.Main(args);
     try
     {
         if (cmdLine.GetDocToProcess().Length > 0)
         {
             ProcessFile(cmdLine.GetDocToProcess(), cmdLine.IsForced(), true);
         }
         else
         {
             ProcessFolder();
         }
     }
     catch (Exception ex)
     {
         Globals.m_Logger.Error(ex.Message, ex);
     }
     finally
     {
         Lettera22Program.Close();
     }
 }
Exemplo n.º 2
0
        /// <project>Lettera22</project>
        /// <copyright company="Claudio Tortorelli">
        /// Copyright (c) 2019 All Rights Reserved
        /// </copyright>
        /// <author>Claudio Tortorelli</author>
        /// <email>[email protected]</email>
        /// <web>http://www.claudiotortorelli.it</web>
        /// <date>Nov 2019</date>
        /// <summary>
        /// </summary>
        /// https://choosealicense.com/licenses/mit/
        static void Main(string[] args)
        {
            Lettera22Program.Main(args);

            if (cmdLine.IsHash())
            {
                if (!File.Exists(cmdLine.GetDocToProcess()))
                {
                    Globals.m_Logger.Error("File not found: " + cmdLine.GetDocToProcess());
                    Lettera22Program.Close();
                }
                Globals.m_Logger.Info("SHA256:");
                Globals.m_Logger.Info(Utils.GetHashSha256(cmdLine.GetDocToProcess()));
                Lettera22Program.Close();
            }

            try
            {
                List <MetaDoc> textWorks      = LoadTextWorks();
                List <MetaDoc> worksToProcess = textWorks;
                if (cmdLine.GetDocToProcess().Length > 0)
                {
                    worksToProcess = new List <MetaDoc>();
                    MetaDoc txtWK = new MetaDoc();
                    if (txtWK.Load(cmdLine.GetDocToProcess()) && txtWK.IsShowInGlobalIndex())
                    {
                        Globals.m_Logger.Warn("Linking specific doc: " + cmdLine.GetDocToProcess());
                        worksToProcess.Add(txtWK);
                    }
                }

                if (worksToProcess.Count == 0)
                {
                    throw new Exception("No textwork found: index is not processed");
                }

                List <MetaDoc> updatedWorks = UpgradeHTMLToPublishFolder(worksToProcess, cmdLine.IsForced());
                if (updatedWorks.Count > 0)
                {
                    string indexHash = Index.ProcessIndex(textWorks);
                    if (indexHash.Length == 0)
                    {
                        throw new Exception("Unable to rebuild index");
                    }

                    if (!Utils.IsConnectionAvailable())
                    {
                        Globals.m_Logger.Warn("No connection. No more to do...");
                        Lettera22Program.Close();
                    }
                    if (!Globals.IsFTPEnabled())
                    {
                        Globals.m_Logger.Warn("FTP is not enabled in options. No more action is possible");
                        Lettera22Program.Close();
                    }

                    if (Globals.IsIndexSignatureEnabled())
                    {
                        string indexFilePath = Globals.IndexFolder() + Globals.IndexFileName();
                        if (!Index.SignIndex(indexFilePath, indexHash) && !cmdLine.IsForced())
                        {
                            throw new Exception("Unable to sign index");
                        }
                    }

                    Ftp ftpClient = new Ftp(Globals.FTPHost(), Globals.FTPUser(), Globals.FTPPassword());

                    if (!SynchIndex(ftpClient))
                    {
                        throw new Exception("Unable to update remote index");
                    }
                    if (!SynchSharedRes(ftpClient))
                    {
                        throw new Exception("Unable to update remote resources");
                    }
                    if (!SynchDocuments(ftpClient, updatedWorks))
                    {
                        throw new Exception("Unable to update remote documents");
                    }
                    if (cmdLine.IsShowResult())
                    {
                        System.Diagnostics.Process.Start(Globals.GetMainUrl());
                    }
                }
                else
                {
                    Globals.m_Logger.Info("Nothing to update...");
                }
            }
            catch (Exception ex)
            {
                Globals.m_Logger.Error(ex.Message, ex);
            }
            finally
            {
                Lettera22Program.Close();
            }
        }