Files
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

514 lines
18 KiB
C++

/*
* (c) Copyright Ascensio System SIA 2010-2023
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
* street, Riga, Latvia, EU, LV-1050.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
#include "ImageManager.h"
#include <boost/algorithm/string.hpp>
#include "../../../OOXML/SystemUtility/SystemUtility.h"
#include "../../../DesktopEditor/common/Directory.h"
CMediaManager::CMediaManager() : m_lIndexNextImage(0), m_lIndexNextAudio(0), m_lIndexNextVideo(0), m_lIndexNextOleObject(0)
{
}
CMediaManager::~CMediaManager()
{
}
void CMediaManager::Clear()
{
m_mapMedia.clear();
m_lIndexNextImage = 0;
m_lIndexNextAudio = 0;
m_lIndexNextVideo = 0;
m_lIndexNextOleObject = 0;
}
std::wstring CMediaManager::FindMedia(const std::wstring &strInput)
{
std::map<std::wstring, std::wstring>::iterator pPair = m_mapMedia.find(strInput);
if (m_mapMedia.end() != pPair)
{
return pPair->second;
}
return L"";
}
void CMediaManager::SetDstEmbeddings(const std::wstring& strDst)
{
m_strDstEmbeddings = strDst;
}
void CMediaManager::SetDstMedia(const std::wstring &strDst)
{
m_strDstMedia = strDst;
}
void CMediaManager::SetTempMedia(const std::wstring& strSrc)
{
OOX::CPath pathSrc(strSrc);
m_strTempMedia = pathSrc.GetPath();
}
std::wstring CMediaManager::GenerateVideo(const std::wstring &strInput, const std::wstring& strExt)
{
return GenerateMedia(strInput, L"video", m_lIndexNextVideo, strExt.empty() ? L".avi" : strExt);
}
std::wstring CMediaManager::GenerateAudio(const std::wstring &strInput, const std::wstring& strExt)
{
return GenerateMedia(strInput, L"audio", m_lIndexNextAudio, strExt.empty() ? L".wav" : strExt);
}
std::wstring CMediaManager::GenerateImage(const std::wstring &strInput)
{
return GenerateMedia(strInput, L"image", m_lIndexNextImage, L".png");
}
std::wstring CMediaManager::GenerateOleObject(const std::wstring& strInput)
{
return GenerateEmbedding(strInput, L"oleObject", m_lIndexNextOleObject, L".bin");
}
std::wstring CMediaManager::GenerateImageJPEG(const std::wstring &strInput)
{
return GenerateMedia(strInput, L"image", m_lIndexNextImage, L".jpeg");
}
std::wstring CMediaManager::GenerateEmbedding(const std::wstring &strInput, const std::wstring &Template, long &Indexer, const std::wstring &strDefaultExt)
{
std::map<std::wstring, std::wstring>::iterator pPair = m_mapMedia.find(strInput);
if (m_mapMedia.end() != pPair)
{
return pPair->second;
}
// if (IsNeedDownload(strInput))
// {
//#ifndef DISABLE_FILE_DOWNLOADER
// NSNetwork::NSFileTransport::CFileDownloader oDownloader(strInput, TRUE);
// if ( oDownloader.DownloadSync() )
// {
// std::wstring file_name = oDownloader.GetFilePath();
//
// //todooo - check media file
// return GenerateEmbedding(file_name , Template, Indexer, strDefaultExt);
// }
//#endif
// }
std::wstring strExts = strDefaultExt;
int nIndexExt = strInput.rfind(wchar_t('.'));
if (-1 != nIndexExt)
strExts = strInput.substr(nIndexExt);
if (strExts == L".tmp" || strExts.empty()) strExts = strDefaultExt;
std::wstring strMediaName = Template + std::to_wstring(++Indexer);
std::wstring strOutput = m_strDstEmbeddings + strMediaName + strExts;
strMediaName = L"../embeddings/" + strMediaName + strExts;
OOX::CPath pathInput(strInput);
std::wstring strPathInput = pathInput.GetPath();
if (std::wstring::npos == strPathInput.find(m_strTempMedia))
{
return L"";
}
if (strOutput != strInput)
{
NSDirectory::CreateDirectory(m_strDstEmbeddings);
if (NSFile::CFileBinary::Copy(strInput, strOutput) == false)
{
return L"";
}
}
m_mapMedia[strInput] = strMediaName;
return strMediaName;
}
std::wstring CMediaManager::GenerateMedia(const std::wstring& strInput, const std::wstring& Template, long& Indexer, const std::wstring& strDefaultExt)
{
std::map<std::wstring, std::wstring>::iterator pPair = m_mapMedia.find(strInput);
if (m_mapMedia.end() != pPair)
{
return pPair->second;
}
if (IsNeedDownload(strInput))
{
#ifndef DISABLE_FILE_DOWNLOADER
NSNetwork::NSFileTransport::CFileDownloader oDownloader(strInput, TRUE);
if (oDownloader.DownloadSync())
{
std::wstring file_name = oDownloader.GetFilePath();
//todooo - check media file
return GenerateMedia(file_name, Template, Indexer, strDefaultExt);
}
#endif
}
std::wstring strExts = strDefaultExt;
int nIndexExt = strInput.rfind(wchar_t('.'));
if (-1 != nIndexExt)
strExts = strInput.substr(nIndexExt);
if (strExts == L".video" || strExts == L".audio")
{
std::wstring strInput1 = strInput.substr(0, nIndexExt);
strExts.clear();
}
if (strExts == L".tmp" || strExts.empty()) strExts = strDefaultExt;
if (strDefaultExt == L"sfil")
{
strExts = L".wav";
//todooo - detect format by file
}
std::wstring strMediaName = Template + std::to_wstring(++Indexer);
std::wstring strOutput = m_strDstMedia + strMediaName + strExts;
strMediaName = L"../media/" + strMediaName + strExts;
OOX::CPath pathInput(strInput);
std::wstring strPathInput = pathInput.GetPath();
if (std::wstring::npos == strPathInput.find(m_strTempMedia))
{
return L"";
}
//todooo ? test format
if (strOutput != strInput)
{
NSDirectory::CreateDirectory(m_strDstMedia);
if (NSFile::CFileBinary::Copy(strInput, strOutput) == false)
{
return L"";
}
}
m_mapMedia[strInput] = strMediaName;
return strMediaName;
}
void CMediaManager::WriteAudioCollection(const std::vector<PPT::CExFilesInfo> &audioCont)
{
if (audioCont.empty()) return;
for (auto& audio : audioCont)
{
auto pathAudio = GenerateAudio(audio.m_strFilePath, audio.m_strFileExt);
}
}
bool CMediaManager::IsNeedDownload(const std::wstring &strFile)
{
int n1 = strFile.find(L"www");
int n2 = strFile.find(L"http");
int n3 = strFile.find(L"ftp");
if (((n1 >= 0) && (n1 < 10)) || ((n2 >= 0) && (n2 < 10)) || ((n3 >= 0) && (n3 < 10)))
return true;
return false;
}
std::wstring CorrectXmlString3(const std::wstring &str)
{
std::wstring buffer;
buffer.reserve(str.size());
for(size_t pos = 0; pos != str.size(); ++pos)
{
switch(str[pos])
{
case '&': buffer.append(L"&amp;"); break;
case '\"': buffer.append(L"&quot;"); break;
case '\'': buffer.append(L"&apos;"); break;
case '<': buffer.append(L"&lt;"); break;
case '>': buffer.append(L"&gt;"); break;
default: buffer.append(&str[pos], 1); break;
}
}
return buffer;
}
CRelsGenerator::CRelsGenerator(CMediaManager *pManager) : m_oWriter(), m_lNextRelsID(1)
{
m_pManager = pManager;
}
CRelsGenerator::~CRelsGenerator()
{
}
void CRelsGenerator::Clear()
{
m_oWriter.ClearNoAttack();
m_lNextRelsID = 1;
m_mapMediaRelsID.clear();
m_mapHyperlinks.clear();
}
void CRelsGenerator::StartMaster(int nIndexTheme, int nStartLayoutIndex, int nCountLayouts)
{
std::wstring str1 = L"<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?>\
<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">";
m_oWriter.WriteString(str1);
for (int i = 0; i < nCountLayouts; ++i)
{
std::wstring str = L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) + L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/slideLayout\" Target=\"../slideLayouts/slideLayout"
+ std::to_wstring(nStartLayoutIndex + 1) + L".xml\"/>";
nStartLayoutIndex++;
m_oWriter.WriteString(str);
}
std::wstring s = L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) + L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme\" Target=\"../theme/theme"
+ std::to_wstring(nIndexTheme + 1) + L".xml\"/>";
m_oWriter.WriteString(s);
}
void CRelsGenerator::StartLayout(int nIndexTheme)
{
std::wstring str1 = L"<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>\
<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">";
m_oWriter.WriteString(str1);
std::wstring str = L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) +
L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/slideMaster\" Target=\"../slideMasters/slideMaster"
+ std::to_wstring(nIndexTheme + 1) + L".xml\"/>";
m_oWriter.WriteString(str);
}
void CRelsGenerator::StartNotes(int nIndexSlide, bool bMaster)
{
m_oWriter.WriteString(L"<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>\
<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">");
if (bMaster)
{
m_oWriter.WriteString(L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) +
L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/notesMaster\" Target=\"../notesMasters/notesMaster1.xml\"/>");
}
if (nIndexSlide >= 0)
{
m_oWriter.WriteString(L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) +
L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/slide\" Target=\"../slides/slide"
+ std::to_wstring(nIndexSlide + 1) + L".xml\"/>");
}
}
void CRelsGenerator::StartSlide(int nIndexLayout, int nIndexNotes)
{
m_oWriter.WriteString(L"<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>\
<Relationships xmlns=\"http://schemas.openxmlformats.org/package/2006/relationships\">");
m_oWriter.WriteString(L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) + L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/slideLayout\" Target=\"../slideLayouts/slideLayout"
+ std::to_wstring(nIndexLayout + 1) + L".xml\"/>");
if (nIndexNotes >= 0)
{
m_oWriter.WriteString(L"<Relationship Id=\"rId" + std::to_wstring(m_lNextRelsID++) +
L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/notesSlide\" Target=\"../notesSlides/notesSlide"
+ std::to_wstring(nIndexNotes + 1) + L".xml\"/>");
}
}
void CRelsGenerator::CloseRels()
{
std::wstring str = L"</Relationships>";
m_oWriter.WriteString(str);
}
void CRelsGenerator::SaveRels(const std::wstring &strFile)
{
NSFile::CFileBinary oFile;
oFile.CreateFileW(strFile);
std::wstring strMem = m_oWriter.GetData();
oFile.WriteStringUTF8(strMem);
oFile.CloseFile();
}
std::wstring CRelsGenerator::WriteHyperlink(const std::wstring &strHyperlink, bool isExternal)
{
std::map<std::wstring, std::wstring>::iterator pPair = m_mapHyperlinks.find(strHyperlink);
if (m_mapHyperlinks.end() != pPair)
{
std::wstring strRid = L"rId" + pPair->second;
return strRid;
}
m_mapHyperlinks[strHyperlink] = std::to_wstring(m_lNextRelsID);
std::wstring strRid = L"rId" + std::to_wstring( m_lNextRelsID++);
std::wstring strRels = L"<Relationship Id=\"";
strRels += strRid + L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink\" Target=\"";
strRels += XmlUtils::EncodeXmlStringExtend(strHyperlink);
strRels += (isExternal ? L"\" TargetMode=\"External\" />" : L"\"/>");
m_oWriter.WriteString(strRels);
return strRid;
}
std::wstring CRelsGenerator::WriteFile(const std::wstring &strPath)
{
std::map<std::wstring, std::wstring>::iterator pPair = m_mapHyperlinks.find(strPath);
if (m_mapHyperlinks.end() != pPair)
{
std::wstring strRid = L"rId" + pPair->second;
return strRid;
}
m_mapHyperlinks[strPath] = std::to_wstring( m_lNextRelsID );
std::wstring strRid = L"rId" + std::to_wstring( m_lNextRelsID++);
std::wstring strRels = L"<Relationship Id=\"";
strRels += strRid + L"\" Type=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships/hyperlink\" Target=\"";
strRels += L"file:///" + strPath + L"\" TargetMode=\"External\" />";
m_oWriter.WriteString(strRels);
return strRid;
}
std::wstring CRelsGenerator::WriteHyperlinkMedia(const std::wstring &strMedia, bool bExternal, bool newRIdAlways, std::wstring strRelsType)
{
if (!newRIdAlways)
{
std::map<std::wstring, int>::iterator pPair = m_mapMediaRelsID.find(strMedia);
if (m_mapMediaRelsID.end() != pPair)
{
std::wstring strRid = L"rId" + std::to_wstring(pPair->second);
return strRid;
}
m_mapMediaRelsID[strMedia] = m_lNextRelsID;
}
std::wstring strRid = L"rId" + std::to_wstring(m_lNextRelsID++);
std::wstring strRels = L"<Relationship Id=\"" + strRid + L"\"" + L" Type=\"" + strRelsType + L"\""
+ L" Target=\"" + strMedia + L"\"";
if (bExternal)
strRels += L" TargetMode=\"External\"";
strRels += L"/>";
m_oWriter.WriteString(strRels);
return strRid;
}
std::wstring CRelsGenerator::WriteHyperlinkImage(const std::wstring & strFileName, bool bExternal)
{
return WriteHyperlinkMedia(strFileName, bExternal, false, L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/image");
}
std::wstring CRelsGenerator::WriteHyperlinkAudio(const std::wstring & strFileName, bool bExternal)
{
return WriteHyperlinkMedia(strFileName, bExternal, false, L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/audio");
}
std::wstring CRelsGenerator::WriteHyperlinkVideo(const std::wstring & strFileName, bool bExternal)
{
return WriteHyperlinkMedia(strFileName, bExternal, false, L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/video");
}
std::wstring CRelsGenerator::WriteHyperlinkOleObject(const std::wstring &strFileName, bool bExternal)
{
return WriteHyperlinkMedia(strFileName, bExternal, false, L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/oleObject");
}
std::wstring CRelsGenerator::WriteMedia(const std::wstring &strMediaPath)
{
std::wstring strMedia = m_pManager->FindMedia(strMediaPath);
if (strMedia.empty()) return WriteHyperlinkMedia(CorrectXmlString3(strMediaPath), true, true);
return WriteHyperlinkMedia(strMedia, false, false); // changed
}
std::wstring CRelsGenerator::WriteImage(const std::wstring &strImagePath)
{
std::wstring strImage = m_pManager->GenerateImage(strImagePath);
if (strImage.empty()) return WriteHyperlinkImage(CorrectXmlString3(strImagePath), true);
return WriteHyperlinkImage(strImage, false);
}
std::wstring CRelsGenerator::WriteOleObject(const std::wstring& strOleObjectPath)
{
std::wstring strOleObject = m_pManager->GenerateOleObject(strOleObjectPath);
if (strOleObject.empty())
return WriteHyperlinkOleObject(CorrectXmlString3(strOleObjectPath), true);
return WriteHyperlinkOleObject(strOleObject, false);
}
std::wstring CRelsGenerator::WriteSlideRef(const std::wstring &strLocation)
{
int sldNum = PPT::CExFilesInfo::GetSlideNumber(strLocation);
std::wstring strSlide(L"slide");
strSlide += std::to_wstring(sldNum);
strSlide += L".xml";
return WriteHyperlinkMedia(strSlide, false, false, L"http://schemas.openxmlformats.org/officeDocument/2006/relationships/slide");
}
std::wstring CRelsGenerator::WriteAudio(const std::wstring &strAudioPath, bool &bExternal)
{
std::wstring strAudio = m_pManager->GenerateAudio(strAudioPath);
if (strAudio.empty())
{
bExternal = true;
return WriteHyperlinkAudio(CorrectXmlString3(strAudioPath), true);
}
else
{
return WriteHyperlinkAudio(strAudio, false);
}
}
std::wstring CRelsGenerator::WriteVideo(const std::wstring &strVideoPath, bool &bExternal)
{
std::wstring strVideo = m_pManager->GenerateVideo(strVideoPath);
if (strVideo.empty())
{
bExternal = true;
return WriteHyperlinkVideo(CorrectXmlString3(strVideoPath), true);
}
else
{
return WriteHyperlinkVideo(strVideo, false);
}
}