autoImport('XDCDNInfo') autoImport('HTTPRequest') autoImport('PhotoFileInfo') autoImport('UpyunInfo') NetIngPersonalPhoto = class('NetIngPersonalPhoto') local gCachedDownloadTaskRecordID = {} local gCachedUploadTaskRecordID = {} function NetIngPersonalPhoto.Ins() if NetIngPersonalPhoto.ins == null then NetIngPersonalPhoto.ins = NetIngPersonalPhoto.new() end return NetIngPersonalPhoto.ins end function NetIngPersonalPhoto:Initialize() EventManager.Me():AddEventListener(ServiceEvent.NUserUploadSceneryPhotoUserCmd, self.OnReceiveUploadSceneryPhotoUserCmd, self) self.stopFormUploadFlag = {} self.tabIsExist = {} end function NetIngPersonalPhoto:Download(role_id, pos_index, photo_id, timestamp, progress_callback, success_callback, error_callback, o_or_t, extension) print(string.format('NetIngPersonalPhoto:Download\npos_index=%s', tostring(pos_index))) local tempDownloadRootPath = ApplicationHelper.persistentDataPath .. '/' .. self:GetTempDownloadRootPathOfLocal() if not FileHelper.ExistDirectory(tempDownloadRootPath) then FileHelper.CreateDirectory(tempDownloadRootPath) end local path = ApplicationHelper.persistentDataPath .. '/' .. self:GetTempDownloadPathOfLocal(photo_id, o_or_t, extension) local key = photo_id .. '_' .. (o_or_t and 'o' or 't') if table.ContainsKey(gCachedDownloadTaskRecordID, key) then local taskRecordID = gCachedDownloadTaskRecordID[key] if self:IsDownloading(photo_id, o_or_t) then CloudFile.CloudFileManager.Ins._CloudFileCallbacks:RegisterCallback(taskRecordID, progress_callback, success_callback, error_callback) else if FileHelper.ExistFile(path) then FileHelper.DeleteFile(path) end local fileServerURL = XDCDNInfo.GetFileServerURL() local newURL = fileServerURL .. '/' .. self:GetPathOfServer(role_id, pos_index, extension) .. (o_or_t and '' or '') .. '?t=' .. timestamp local taskRecord = CloudFile.CloudFileManager.Ins._TaskRecordCenter:GetTaskRecord(taskRecordID) taskRecord.URL = newURL CloudFile.CloudFileManager.Ins:RestartTask(taskRecordID) CloudFile.CloudFileManager.Ins._CloudFileCallbacks:UnregisterCallback(taskRecordID) CloudFile.CloudFileManager.Ins._CloudFileCallbacks:RegisterCallback(taskRecordID, progress_callback, success_callback, error_callback) end else if FileHelper.ExistFile(path) then FileHelper.DeleteFile(path) end local fileServerURL = XDCDNInfo.GetFileServerURL() local url = fileServerURL .. '/' .. self:GetPathOfServer(role_id, pos_index, extension) .. (o_or_t and '' or '') .. '?t=' .. timestamp local taskRecordID = nil if not BackwardCompatibilityUtil.CompatibilityMode(BackwardCompatibilityUtil.V13) then taskRecordID = CloudFile.CloudFileManager.Ins:Download(url, path, false, progress_callback ,success_callback, error_callback, nil) else taskRecordID = CloudFile.CloudFileManager.Ins:Download(url, path, false, progress_callback ,success_callback, error_callback) end if taskRecordID > 0 then gCachedDownloadTaskRecordID[key] = taskRecordID end end end function NetIngPersonalPhoto:IsDownloading(photo_id, o_or_t) local key = photo_id .. '_' .. (o_or_t and 'o' or 't') local taskRecordID = gCachedDownloadTaskRecordID[key] if taskRecordID ~= nil then local taskRecord = CloudFile.CloudFileManager.Ins._TaskRecordCenter:GetTaskRecord(taskRecordID) return taskRecord.State == CloudFile.E_TaskState.None or taskRecord.State == CloudFile.E_TaskState.Progress end return false end function NetIngPersonalPhoto:SetDownloadCallback(photo_id, progress_callback, success_callback, error_callback, o_or_t) local key = photo_id .. '_' .. (o_or_t and 'o' or 't') local taskRecordID = gCachedDownloadTaskRecordID[key] if taskRecordID ~= nil then CloudFile.CloudFileManager._CloudFileCallbacks:UnregisterCallback(taskRecordID) CloudFile.CloudFileManager._CloudFileCallbacks:RegisterCallback(taskRecordID, progress_callback, success_callback, error_callback) end end function NetIngPersonalPhoto:AddDownloadCallback(photo_id, progress_callback, success_callback, error_callback, o_or_t) local key = photo_id .. '_' .. (o_or_t and 'o' or 't') local taskRecordID = gCachedDownloadTaskRecordID[key] if taskRecordID ~= nil then CloudFile.CloudFileManager._CloudFileCallbacks:RegisterCallback(taskRecordID, progress_callback, success_callback, error_callback) end end function NetIngPersonalPhoto:StopDownload(photo_id, o_or_t) local key = photo_id .. '_' .. (o_or_t and 'o' or 't') local taskRecordID = gCachedDownloadTaskRecordID[key] if taskRecordID ~= nil then CloudFile.CloudFileManager.Ins:StopTask(taskRecordID) end end function NetIngPersonalPhoto:Upload(role_id, pos_index, photo_id, progress_callback, success_callback, error_callback) if table.ContainsKey(gCachedUploadTaskRecordID, photo_id) then local taskRecordID = gCachedUploadTaskRecordID[photo_id] local taskRecord = CloudFile.CloudFileManager.Ins._TaskRecordCenter:GetTaskRecord(taskRecordID) if taskRecord.State == CloudFile.E_TaskState.Progress then CloudFile.CloudFileManager.Ins:StopTask(taskRecordID) end CloudFile.CloudFileManager.Ins:RestartTask(taskRecordID) CloudFile.CloudFileManager.Ins._CloudFileCallbacks:UnregisterCallback(taskRecordID) CloudFile.CloudFileManager.Ins._CloudFileCallbacks:RegisterCallback(taskRecordID, progress_callback, success_callback, error_callback) else local path = ApplicationHelper.persistentDataPath .. '/' .. self:GetTempUploadPathOfLocal(photo_id) local url = UpyunInfo.GetNormalUploadURL() .. '/' .. self:GetPathOfServer(role_id, pos_index) local taskRecordID = nil if not BackwardCompatibilityUtil.CompatibilityMode(BackwardCompatibilityUtil.V13) then taskRecordID = CloudFile.CloudFileManager.Ins:NormalUpload(path, url, progress_callback ,success_callback, error_callback, nil) else taskRecordID = CloudFile.CloudFileManager.Ins:NormalUpload(path, url, progress_callback ,success_callback, error_callback) end if taskRecordID > 0 then gCachedUploadTaskRecordID[photo_id] = taskRecordID end end end function NetIngPersonalPhoto:StopUpload(photo_id) local taskRecordID = gCachedUploadTaskRecordID[photo_id] if taskRecordID ~= nil then CloudFile.CloudFileManager.Ins:StopTask(taskRecordID) end end local operatorName = 'roxdcdn' local formUploadCallbacks = {} function NetIngPersonalPhoto:FormUpload(pos_index, photo_id, progress_callback, success_callback, error_callback) formUploadCallbacks[pos_index] = {photoID = photo_id, progressCallback = progress_callback, successCallback = success_callback, errorCallback = error_callback} ServiceNUserProxy.Instance:CallUploadSceneryPhotoUserCmd(SceneUser2_pb.EALBUMTYPE_PHOTO, pos_index) self.stopFormUploadFlag[photo_id] = false end function NetIngPersonalPhoto:OnReceiveUploadSceneryPhotoUserCmd(message) print('NetIngPersonalPhoto:OnReceiveUploadSceneryPhotoUserCmd') local eType = message.type if eType == SceneUser2_pb.EALBUMTYPE_PHOTO then local posIndex = message.sceneryid local photoID = formUploadCallbacks[posIndex].photoID if not self.stopFormUploadFlag[photoID] then local policy = message.policy local signature = message.signature local authorization = "UPYUN " .. operatorName .. ":" .. signature; self:DoFormUpload( photoID, policy, authorization, formUploadCallbacks[posIndex].progressCallback, formUploadCallbacks[posIndex].successCallback, formUploadCallbacks[posIndex].errorCallback ) end formUploadCallbacks[posIndex] = nil end end function NetIngPersonalPhoto:DoFormUpload(photo_id, policy, authorization, progress_callback, success_callback, error_callback) if table.ContainsKey(gCachedUploadTaskRecordID, photo_id) then local taskRecordID = gCachedUploadTaskRecordID[photo_id] local taskRecord = CloudFile.CloudFileManager.Ins._TaskRecordCenter:GetTaskRecord(taskRecordID) if taskRecord.State == CloudFile.E_TaskState.Progress then CloudFile.CloudFileManager.Ins:StopTask(taskRecordID) end CloudFile.CloudFileManager.Ins:RestartTask(taskRecordID) CloudFile.CloudFileManager.Ins._CloudFileCallbacks:UnregisterCallback(taskRecordID) CloudFile.CloudFileManager.Ins._CloudFileCallbacks:RegisterCallback(taskRecordID, progress_callback, success_callback, error_callback) else local path = ApplicationHelper.persistentDataPath .. '/' .. self:GetTempUploadPathOfLocal(photo_id) local url = UpyunInfo.GetFormUploadURL() local taskRecordID = CloudFile.CloudFileManager.Ins:FormUpload(path, url, policy, authorization, progress_callback ,success_callback, error_callback, nil) if taskRecordID > 0 then gCachedUploadTaskRecordID[photo_id] = taskRecordID end end end function NetIngPersonalPhoto:StopFormUpload(photo_id) self.stopFormUploadFlag[photo_id] = true self:StopUpload(photo_id) end function NetIngPersonalPhoto:SetUserPathOfServer(user_path) self.userPathOfServer = user_path end function NetIngPersonalPhoto:GetPathOfServer(role_id, pos_index, pExtension) local extension = PhotoFileInfo.Extension if pExtension ~= nil then extension = pExtension end return self.userPathOfServer .. '/' .. role_id .. '/' .. pos_index .. '.' .. extension end function NetIngPersonalPhoto:GetTempDownloadRootPathOfLocal() return 'TempUsedToDownloadPersonalPhoto' end function NetIngPersonalPhoto:GetTempDownloadPathOfLocal(photo_id, o_or_t, pExtension) local extension = PhotoFileInfo.Extension if pExtension ~= nil then extension = pExtension end return self:GetTempDownloadRootPathOfLocal() .. '/' .. photo_id .. '_' .. (o_or_t and 'o' or 't') .. '.' .. extension end function NetIngPersonalPhoto:GetTempUploadRootPathOfLocal() return 'TempUsedToUploadPersonalPhoto' end function NetIngPersonalPhoto:GetTempUploadPathOfLocal(photo_id) return self:GetTempUploadRootPathOfLocal() .. '/' .. photo_id .. '.' .. PhotoFileInfo.Extension end function NetIngPersonalPhoto:SetExist(role_id, pos_index) if self.tabIsExist[role_id] == nil then self.tabIsExist[role_id] = {} end self.tabIsExist[role_id][pos_index] = 0 end local existResponseCode = { [200] = 0, } function NetIngPersonalPhoto:CheckExist(role_id, pos_index, exist_callback, error_callback, extension) local posIndexIsExist = self.tabIsExist[role_id] if posIndexIsExist ~= nil then if posIndexIsExist[pos_index] ~= nil then if exist_callback ~= nil then exist_callback() end return end end local url = UpyunInfo.GetVisitURL() .. '/' .. self:GetPathOfServer(role_id, pos_index, extension) HTTPRequest.Head(url, function (x) local unityWebRequest = x local responseCode = unityWebRequest.responseCode -- HTTPRequest.BackUnityWebRequest(unityWebRequest) -- unityWebRequest:Dispose() -- unityWebRequest = nil if existResponseCode[responseCode] == 0 then if exist_callback ~= nil then exist_callback() end else if error_callback ~= nil then error_callback() end end end) end