aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/golang.org/x/crypto/openpgp/packet/literal.go
blob: 1a9ec6e51e81d482b056e5fb26bc8b5cd6643ee6 (plain) (blame)
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
80
81
82
83
84
85
86
87
88
89
// Copyright 2011 The Go Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.

package packet

import (
    "encoding/binary"
    "io"
)

// LiteralData represents an encrypted file. See RFC 4880, section 5.9.
type LiteralData struct {
    IsBinary bool
    FileName string
    Time     uint32 // Unix epoch time. Either creation time or modification time. 0 means undefined.
    Body     io.Reader
}

// ForEyesOnly returns whether the contents of the LiteralData have been marked
// as especially sensitive.
func (l *LiteralData) ForEyesOnly() bool {
    return l.FileName == "_CONSOLE"
}

func (l *LiteralData) parse(r io.Reader) (err error) {
    var buf [256]byte

    _, err = readFull(r, buf[:2])
    if err != nil {
        return
    }

    l.IsBinary = buf[0] == 'b'
    fileNameLen := int(buf[1])

    _, err = readFull(r, buf[:fileNameLen])
    if err != nil {
        return
    }

    l.FileName = string(buf[:fileNameLen])

    _, err = readFull(r, buf[:4])
    if err != nil {
        return
    }

    l.Time = binary.BigEndian.Uint32(buf[:4])
    l.Body = r
    return
}

// SerializeLiteral serializes a literal data packet to w and returns a
// WriteCloser to which the data itself can be written and which MUST be closed
// on completion. The fileName is truncated to 255 bytes.
func SerializeLiteral(w io.WriteCloser, isBinary bool, fileName string, time uint32) (plaintext io.WriteCloser, err error) {
    var buf [4]byte
    buf[0] = 't'
    if isBinary {
        buf[0] = 'b'
    }
    if len(fileName) > 255 {
        fileName = fileName[:255]
    }
    buf[1] = byte(len(fileName))

    inner, err := serializeStreamHeader(w, packetTypeLiteralData)
    if err != nil {
        return
    }

    _, err = inner.Write(buf[:2])
    if err != nil {
        return
    }
    _, err = inner.Write([]byte(fileName))
    if err != nil {
        return
    }
    binary.BigEndian.PutUint32(buf[:], time)
    _, err = inner.Write(buf[:])
    if err != nil {
        return
    }

    plaintext = inner
    return
}