void CWizKbSync::onAttachmentsGetInfo(const std::deque<WIZDOCUMENTATTACHMENTDATAEX>& arrayRet) { size_t count = arrayRet.size(); // new attachment if (count == 0) { WIZDOCUMENTATTACHMENTDATA data; data.strGUID = m_currentUploadAttachment.strGUID; data.strDocumentGUID = m_currentUploadAttachment.strDocumentGUID; data.strName = m_currentUploadAttachment.strName; data.tInfoModified = COleDateTime(1900, 1, 1, 0, 0, 0); data.tDataModified = data.tInfoModified; data.strInfoMD5 = "-1"; data.strDataMD5 = "-1"; onQueryAttachmentInfo(data); // server return exist } else if (count == 1) { onQueryAttachmentInfo(arrayRet[0]); // fatal error } else { Q_EMIT processErrorLog("Can not query document info"); onXmlRpcError(SyncMethod_GetDocumentsInfo, errorXmlRpcFault, -1, "Fault error: Invalid document info"); } }
void CWizKbSync::onDocumentsGetInfo(const std::deque<WIZDOCUMENTDATABASE>& arrayRet) { size_t count = arrayRet.size(); // new document if (count == 0) { WIZDOCUMENTDATABASE data; data.strGUID = m_currentUploadDocument.strGUID; data.strTitle = m_currentUploadDocument.strTitle; data.strLocation = m_currentUploadDocument.strLocation; data.tInfoModified = COleDateTime(1900, 1, 1, 0, 0, 0); data.tDataModified = data.tInfoModified; data.tParamModified = data.tInfoModified; data.strInfoMD5 = "-1"; data.strDataMD5 = "-1"; data.strParamMD5 = "-1"; onQueryDocumentInfo(data); // server already have this document } else if (count == 1) { onQueryDocumentInfo(arrayRet[0]); // absolutely count should not more than 1 } else { Q_EMIT processErrorLog("Can not query document info"); onXmlRpcError(SyncMethod_GetDocumentsInfo, errorXmlRpcFault, -1, "Fault error: Invalid document info"); } }
void CWizKbSync::onDocumentsGetInfo(const std::deque<WIZDOCUMENTDATABASE>& arrayRet) { size_t count = arrayRet.size(); // new document if (count == 0) { WIZDOCUMENTDATABASE data; data.strGUID = m_currentUploadDocument.strGUID; data.strTitle = m_currentUploadDocument.strTitle; data.strLocation = m_currentUploadDocument.strLocation; data.tInfoModified = COleDateTime(1900, 1, 1, 0, 0, 0); data.tDataModified = data.tInfoModified; data.tParamModified = data.tInfoModified; data.strInfoMD5 = "-1"; data.strDataMD5 = "-1"; data.strParamMD5 = "-1"; onQueryDocumentInfo(data); // server already have this document } else if (count == 1) { // if document version bigger than local max version number means conflict found __int64 nLocalVersion = m_db->GetObjectVersion(WIZDOCUMENTDATA::ObjectName()); if (arrayRet[0].nVersion >= nLocalVersion) { WIZDOCUMENTDATA localData; m_db->DocumentFromGUID(arrayRet[0].strGUID, localData); localData.nObjectPart = calDocumentParts(arrayRet[0], localData); // do conflict back only if document data is modified if (localData.nObjectPart & WIZKM_XMLRPC_OBJECT_PART_DATA) { Q_EMIT processLog(tr("Conflict found: ") + localData.strTitle); m_conflictedDocument = localData; callDocumentGetData(localData); return; } } onQueryDocumentInfo(arrayRet[0]); // absolutely count should not more than 1 } else { Q_EMIT processErrorLog("Can not query document info"); onXmlRpcError(SyncMethod_GetDocumentsInfo, errorXmlRpcFault, -1, "Fault error: Invalid document info"); } }
void CWizApiBase::_onXmlRpcError(const QString& strMethodName, WizXmlRpcError err, int errorCode, const QString& errorMessage) { // token timeout if (strMethodName == SyncMethod_ClientKeepAlive && err == errorXmlRpcFault) { TOLOG(tr("Token expired, Try to request another")); WizGlobal()->clearToken(); callClientLogin(m_strUserId, m_strPasswd); return; } if (err == errorNetwork) { WizGlobal()->clearToken(); } onXmlRpcError(strMethodName, err, errorCode, errorMessage); }
void CWizApiBase::xmlRpcError(const QString& strMethodName, WizXmlRpcError err, int errorCode, const QString& errorMessage) { onXmlRpcError(strMethodName, err, errorCode, errorMessage); }