forked from snapcore/snapd
/
cmd_ack.go
79 lines (66 loc) · 2.06 KB
/
cmd_ack.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// -*- Mode: Go; indent-tabs-mode: t -*-
/*
* Copyright (C) 2016 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
package main
import (
"fmt"
"io/ioutil"
"github.com/jessevdk/go-flags"
"github.com/snapcore/snapd/client"
"github.com/snapcore/snapd/i18n"
)
type cmdAck struct {
clientMixin
AckOptions struct {
AssertionFile flags.Filename
} `positional-args:"true" required:"true"`
}
var shortAckHelp = i18n.G("Add an assertion to the system")
var longAckHelp = i18n.G(`
The ack command tries to add an assertion to the system assertion database.
The assertion may also be a newer revision of a pre-existing assertion that it
will replace.
To succeed the assertion must be valid, its signature verified with a known
public key and the assertion consistent with and its prerequisite in the
database.
`)
func init() {
addCommand("ack", shortAckHelp, longAckHelp, func() flags.Commander {
return &cmdAck{}
}, nil, []argDesc{{
// TRANSLATORS: This needs to begin with < and end with >
name: i18n.G("<assertion file>"),
// TRANSLATORS: This should not start with a lowercase letter.
desc: i18n.G("Assertion file"),
}})
}
func ackFile(cli *client.Client, assertFile string) error {
assertData, err := ioutil.ReadFile(assertFile)
if err != nil {
return err
}
return cli.Ack(assertData)
}
func (x *cmdAck) Execute(args []string) error {
if len(args) > 0 {
return ErrExtraArgs
}
if err := ackFile(x.client, string(x.AckOptions.AssertionFile)); err != nil {
return fmt.Errorf("cannot assert: %v", err)
}
return nil
}