2014-07-13 00:45:33 +02:00
|
|
|
// Copyright (C) 2014 Jakob Borg and Contributors (see the CONTRIBUTORS file).
|
|
|
|
// All rights reserved. Use of this source code is governed by an MIT-style
|
|
|
|
// license that can be found in the LICENSE file.
|
2014-06-01 22:50:14 +02:00
|
|
|
|
2014-02-20 17:40:15 +01:00
|
|
|
package protocol
|
|
|
|
|
2014-07-12 23:06:48 +02:00
|
|
|
import "fmt"
|
|
|
|
|
2014-02-20 17:40:15 +01:00
|
|
|
type IndexMessage struct {
|
2014-07-25 09:01:54 +02:00
|
|
|
Repository string // max:64
|
|
|
|
Files []FileInfo
|
2014-02-20 17:40:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type FileInfo struct {
|
2014-08-25 08:47:59 +02:00
|
|
|
Name string // max:8192
|
2014-07-15 13:04:37 +02:00
|
|
|
Flags uint32
|
|
|
|
Modified int64
|
|
|
|
Version uint64
|
|
|
|
LocalVersion uint64
|
2014-07-25 09:01:54 +02:00
|
|
|
Blocks []BlockInfo
|
2014-02-20 17:40:15 +01:00
|
|
|
}
|
|
|
|
|
2014-07-12 23:06:48 +02:00
|
|
|
func (f FileInfo) String() string {
|
|
|
|
return fmt.Sprintf("File{Name:%q, Flags:0%o, Modified:%d, Version:%d, Size:%d, Blocks:%v}",
|
|
|
|
f.Name, f.Flags, f.Modified, f.Version, f.Size(), f.Blocks)
|
|
|
|
}
|
|
|
|
|
|
|
|
func (f FileInfo) Size() (bytes int64) {
|
2014-08-12 13:53:31 +02:00
|
|
|
if IsDeleted(f.Flags) || IsDirectory(f.Flags) {
|
|
|
|
return 128
|
|
|
|
}
|
2014-07-12 23:06:48 +02:00
|
|
|
for _, b := range f.Blocks {
|
|
|
|
bytes += int64(b.Size)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2014-08-12 13:53:31 +02:00
|
|
|
func (f FileInfo) IsDeleted() bool {
|
|
|
|
return IsDeleted(f.Flags)
|
|
|
|
}
|
|
|
|
|
2014-09-01 09:07:51 +02:00
|
|
|
func (f FileInfo) IsInvalid() bool {
|
|
|
|
return IsInvalid(f.Flags)
|
|
|
|
}
|
|
|
|
|
2014-08-12 13:53:31 +02:00
|
|
|
// Used for unmarshalling a FileInfo structure but skipping the actual block list
|
|
|
|
type FileInfoTruncated struct {
|
2014-08-25 08:47:59 +02:00
|
|
|
Name string // max:8192
|
2014-08-12 13:53:31 +02:00
|
|
|
Flags uint32
|
|
|
|
Modified int64
|
|
|
|
Version uint64
|
|
|
|
LocalVersion uint64
|
|
|
|
NumBlocks uint32
|
|
|
|
}
|
|
|
|
|
2014-08-12 16:36:24 +02:00
|
|
|
// Returns a statistical guess on the size, not the exact figure
|
2014-08-12 13:53:31 +02:00
|
|
|
func (f FileInfoTruncated) Size() int64 {
|
|
|
|
if IsDeleted(f.Flags) || IsDirectory(f.Flags) {
|
|
|
|
return 128
|
|
|
|
}
|
2014-08-12 16:36:24 +02:00
|
|
|
if f.NumBlocks < 2 {
|
|
|
|
return BlockSize / 2
|
|
|
|
} else {
|
|
|
|
return int64(f.NumBlocks-1)*BlockSize + BlockSize/2
|
|
|
|
}
|
2014-08-12 13:53:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func (f FileInfoTruncated) IsDeleted() bool {
|
|
|
|
return IsDeleted(f.Flags)
|
|
|
|
}
|
|
|
|
|
2014-09-01 09:07:51 +02:00
|
|
|
func (f FileInfoTruncated) IsInvalid() bool {
|
|
|
|
return IsInvalid(f.Flags)
|
|
|
|
}
|
|
|
|
|
2014-08-12 13:53:31 +02:00
|
|
|
type FileIntf interface {
|
|
|
|
Size() int64
|
|
|
|
IsDeleted() bool
|
2014-09-01 09:07:51 +02:00
|
|
|
IsInvalid() bool
|
2014-08-12 13:53:31 +02:00
|
|
|
}
|
|
|
|
|
2014-02-20 17:40:15 +01:00
|
|
|
type BlockInfo struct {
|
2014-07-12 23:06:48 +02:00
|
|
|
Offset int64 // noencode (cache only)
|
|
|
|
Size uint32
|
|
|
|
Hash []byte // max:64
|
|
|
|
}
|
|
|
|
|
|
|
|
func (b BlockInfo) String() string {
|
|
|
|
return fmt.Sprintf("Block{%d/%d/%x}", b.Offset, b.Size, b.Hash)
|
2014-02-20 17:40:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type RequestMessage struct {
|
|
|
|
Repository string // max:64
|
2014-08-25 08:47:59 +02:00
|
|
|
Name string // max:8192
|
2014-02-20 17:40:15 +01:00
|
|
|
Offset uint64
|
|
|
|
Size uint32
|
|
|
|
}
|
|
|
|
|
2014-07-28 11:31:22 +02:00
|
|
|
type ResponseMessage struct {
|
|
|
|
Data []byte
|
|
|
|
}
|
|
|
|
|
2014-04-13 15:28:26 +02:00
|
|
|
type ClusterConfigMessage struct {
|
|
|
|
ClientName string // max:64
|
|
|
|
ClientVersion string // max:64
|
|
|
|
Repositories []Repository // max:64
|
|
|
|
Options []Option // max:64
|
|
|
|
}
|
|
|
|
|
2014-08-14 23:15:26 +01:00
|
|
|
func (o *ClusterConfigMessage) GetOption(key string) string {
|
|
|
|
for _, option := range o.Options {
|
|
|
|
if option.Key == key {
|
|
|
|
return option.Value
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2014-04-13 15:28:26 +02:00
|
|
|
type Repository struct {
|
|
|
|
ID string // max:64
|
|
|
|
Nodes []Node // max:64
|
|
|
|
}
|
|
|
|
|
|
|
|
type Node struct {
|
2014-07-15 13:04:37 +02:00
|
|
|
ID []byte // max:32
|
|
|
|
Flags uint32
|
|
|
|
MaxLocalVersion uint64
|
2014-02-20 17:40:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
type Option struct {
|
|
|
|
Key string // max:64
|
|
|
|
Value string // max:1024
|
|
|
|
}
|
2014-07-26 21:27:55 +02:00
|
|
|
|
|
|
|
type CloseMessage struct {
|
|
|
|
Reason string // max:1024
|
|
|
|
}
|
2014-07-28 11:31:22 +02:00
|
|
|
|
|
|
|
type EmptyMessage struct{}
|