Add default constructor that creates a random ID.
[jSite2.git] / src / net / pterodactylus / jsite / core / Request.java
1 /*
2  * jSite-next - Request.java -
3  * Copyright © 2009 David Roden
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18  */
19
20 package net.pterodactylus.jsite.core;
21
22 import net.pterodactylus.jsite.util.IdGenerator;
23 import net.pterodactylus.util.number.Hex;
24
25 /**
26  * Wraps a request that is executed by the Freenet node.
27  *
28  * @author <a href="mailto:bombe@pterodactylus.net">David ‘Bombe’ Roden</a>
29  */
30 public class Request {
31
32         /** The ID of the request. */
33         private final String id;
34
35         /** The client token of the request. */
36         private String clientToken;
37
38         /**
39          * Creates a new request with a random ID.
40          */
41         public Request() {
42                 this(Hex.toHex(IdGenerator.generateId()));
43         }
44
45         /**
46          * Creates a new request.
47          *
48          * @param id
49          *            The ID of the request
50          */
51         public Request(String id) {
52                 this.id = id;
53         }
54
55         /**
56          * Returns the ID of the request.
57          *
58          * @return The request’s ID
59          */
60         public String getId() {
61                 return id;
62         }
63
64         /**
65          * Returns the client token of the request.
66          *
67          * @return The request’s client token
68          */
69         public String getClientToken() {
70                 return clientToken;
71         }
72
73         /**
74          * Sets the client token of the request
75          *
76          * @param clientToken
77          *            The request’s new client token
78          */
79         public void setClientToken(String clientToken) {
80                 this.clientToken = clientToken;
81         }
82
83 }