-
Notifications
You must be signed in to change notification settings - Fork 173
/
signer.go
58 lines (47 loc) · 1.44 KB
/
signer.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
// Copyright 2016 VMware, Inc. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package tether
import (
"io"
"golang.org/x/crypto/ssh"
)
type ContainerSigner struct {
id string
}
func (c *ContainerSigner) PublicKey() ssh.PublicKey {
return *c
}
// we're going to ignore everything for the moment as we're repurposing the host key for the id.
// later we may use a genuine host key and an SSH out-of-band request to get the container id.
func (c *ContainerSigner) Sign(rand io.Reader, data []byte) (*ssh.Signature, error) {
return &ssh.Signature{
Format: "container-id",
Blob: []byte{},
}, nil
}
func (c ContainerSigner) Type() string {
return "container-id"
}
func (c ContainerSigner) Marshal() []byte {
return []byte(c.id)
}
func (c ContainerSigner) Verify(data []byte, sig *ssh.Signature) error {
return nil
}
func NewSigner(id string) *ContainerSigner {
signer := &ContainerSigner{
id: id,
}
return signer
}