aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/org/gnunet/dht/messages/MonitorPutMessage.java
blob: c268866f773097d1ea7345004c9ecee3559de0c3 (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
/*
 This file is part of GNUnet.
 Copyright (C) 2011, 2012 Christian Grothoff (and other contributing authors)

 GNUnet is free software; you can redistribute it and/or modify
 it under the terms of the GNU General Public License as published
 by the Free Software Foundation; either version 3, or (at your
 option) any later version.

 GNUnet 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 GNUnet; see the file COPYING.  If not, write to the
 Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
 Boston, MA 02110-1301, USA.
 */

package org.gnunet.dht.messages;

import org.gnunet.construct.*;
import org.gnunet.util.AbsoluteTimeMessage;
import org.gnunet.util.GnunetMessage;
import org.gnunet.util.HashCode;
import org.gnunet.util.PeerIdentity;

/**
 * Message to monitor put requests going through peer, DHT service --> clients.
 */
@UnionCase(151)
public class MonitorPutMessage implements GnunetMessage.Body {
    /**
     * Message options, actually an 'enum GNUNET_DHT_RouteOption' value.
     */
    @UInt32
    public int options;

    /**
     * The type of data in the getRequestIdentifier.
     */
    @UInt32
    public int type;

    /**
     * Hop count so far.
     */
    @UInt32
    public int hopCount;

    /**
     * Replication level for this message
     */
    @UInt32
    public int desiredReplicationLevel;

    /**
     * Number of peers recorded in the outgoing path from source to the
     * storage location of this message.
     */
    @UInt32
    public int putPathLength;

    /**
     * How long should this data persist?
     */
    @NestedMessage
    public AbsoluteTimeMessage expirationTime;

    /**
     * The key to store the value under.
     */
    @NestedMessage
    public HashCode key;

    @VariableSizeArray(lengthField = "putPathLength")
    public PeerIdentity[] putPath;

    @FillWith @UInt8
    public byte[] data;
}