mirror of
https://github.com/documize/community.git
synced 2025-07-18 20:59:43 +02:00
97 lines
2.9 KiB
Go
97 lines
2.9 KiB
Go
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
|
|
//
|
|
// This software (Documize Community Edition) is licensed under
|
|
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
|
|
//
|
|
// You can operate outside the AGPL restrictions by purchasing
|
|
// Documize Enterprise Edition and obtaining a commercial license
|
|
// by contacting <sales@documize.com>.
|
|
//
|
|
// https://documize.com
|
|
|
|
// Package backup handle data backup/restore to/from ZIP format.
|
|
package backup
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/documize/community/core/env"
|
|
"github.com/documize/community/domain"
|
|
"github.com/documize/community/model"
|
|
"github.com/documize/community/model/org"
|
|
)
|
|
|
|
// Manifest contains backup meta information.
|
|
type Manifest struct {
|
|
// ID is unique per backup.
|
|
ID string `json:"id"`
|
|
|
|
// A value of "*' means all tenants/oragnizations are backed up (requires global admin permission).
|
|
// A genuine ID means only that specific organization is backed up.
|
|
OrgID string `json:"org"`
|
|
|
|
// Product edition at the time of the backup.
|
|
Edition domain.Edition `json:"edition"`
|
|
|
|
// When the backup took place.
|
|
Created time.Time `json:"created"`
|
|
|
|
// Product version at the time of the backup.
|
|
Major string `json:"major"`
|
|
Minor string `json:"minor"`
|
|
Patch string `json:"patch"`
|
|
Revision string `json:"revision"`
|
|
Version string `json:"version"`
|
|
|
|
// Database provider used by source system.
|
|
StoreType env.StoreType `json:"storeType"`
|
|
}
|
|
|
|
// ExportSpec controls what data is exported to the backup file.
|
|
type ExportSpec struct {
|
|
// A value of "*' means all tenants/oragnizations are backed up (requires global admin permission).
|
|
// A genuine ID means only that specific organization is backed up.
|
|
OrgID string `json:"org"`
|
|
|
|
// Retain will keep the backup file on disk after operation is complete.
|
|
// File is located in the same folder as the running executable.
|
|
Retain bool `json:"retain"`
|
|
}
|
|
|
|
// SystemBackup happens if org ID is "*".
|
|
func (e *ExportSpec) SystemBackup() bool {
|
|
return e.OrgID == "*"
|
|
}
|
|
|
|
// ImportSpec controls what content is imported and how.
|
|
type ImportSpec struct {
|
|
// Overwrite current organization settings.
|
|
OverwriteOrg bool `json:"overwriteOrg"`
|
|
|
|
// As found in backup file.
|
|
Manifest Manifest
|
|
|
|
// Handle to the current organization being used for restore process.
|
|
Org org.Organization
|
|
|
|
// Was the backup file for a global system backup?
|
|
// TRUE if Manifest.Org = "*".
|
|
GlobalBackup bool
|
|
}
|
|
|
|
// User represents user object for backup/restore operations.
|
|
// We include user specific secrets in such operations.
|
|
type User struct {
|
|
model.BaseEntity
|
|
Firstname string `json:"firstname"`
|
|
Lastname string `json:"lastname"`
|
|
Email string `json:"email"`
|
|
Initials string `json:"initials"`
|
|
Active bool `json:"active"`
|
|
GlobalAdmin bool `json:"global"`
|
|
Password string `json:"password"`
|
|
Salt string `json:"salt"`
|
|
Reset string `json:"reset"`
|
|
LastVersion string `json:"lastVersion"`
|
|
Locale string `json:"locale"`
|
|
}
|