github.com/anonymouse64/snapd@v0.0.0-20210824153203-04c4c42d842d/gadget/install/params.go (about) 1 // -*- Mode: Go; indent-tabs-mode: t -*- 2 3 /* 4 * Copyright (C) 2019-2020 Canonical Ltd 5 * 6 * This program is free software: you can redistribute it and/or modify 7 * it under the terms of the GNU General Public License version 3 as 8 * published by the Free Software Foundation. 9 * 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * 15 * You should have received a copy of the GNU General Public License 16 * along with this program. If not, see <http://www.gnu.org/licenses/>. 17 * 18 */ 19 20 package install 21 22 import ( 23 "github.com/snapcore/snapd/secboot" 24 ) 25 26 type Options struct { 27 // Also mount the filesystems after creation 28 Mount bool 29 // Encrypt the data partition 30 Encrypt bool 31 } 32 33 // EncryptionKeySet is a set of encryption keys. 34 type EncryptionKeySet struct { 35 Key secboot.EncryptionKey 36 RecoveryKey secboot.RecoveryKey 37 } 38 39 // InstalledSystemSideData carries side data of an installed system, eg. secrets 40 // to access its partitions. 41 type InstalledSystemSideData struct { 42 // KeysForRoles contains key sets for the relevant structure roles. 43 KeysForRoles map[string]*EncryptionKeySet 44 }