func (u unZip) OnSave(file *storage.File, w http.ResponseWriter, r *http.Request, s *storage.Storage) (e error) { mode := u.needUnZip(r) if mode == UNZIP_NO { return } aelog.Debugf("UnZip: start unzip(%d) files to: %s (%s)", mode, file.Name, utils.HumanBytes(file.FSize)) if mode == UNZIP_FORCE { s.DeleteChilds(file.Name) } filesCount, filesSize, err := u.unZipTo(file.Name, file, s) if err != nil { aelog.Debugf("UnZip: error: %v", err) w.Header().Add("X-Ae-Unzip-Error", err.Error()) return } aelog.Debugf("UnZip: unziped: %s (%d files, %s files size)", file.Name, filesCount, utils.HumanBytes(filesSize)) w.Header().Add("X-Ae-Unzip-Count", fmt.Sprint(filesCount)) w.Header().Add("X-Ae-Unzip-Size", utils.HumanBytes(filesSize)) return }