summaryrefslogtreecommitdiff
path: root/src/frontend/generate_taler_contract.php
blob: 8b4d77c819ce5d4ab78cec791f2bd30a0bfe0e0b (plain)
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
90
91
92
93
94
95
96
97
98
99
<?php 
/*
  This file is part of GNU TALER.
  Copyright (C) 2014, 2015 GNUnet e.V.

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

  TALER 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 Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public License along with
  TALER; see the file COPYING.  If not, If not, see <http://www.gnu.org/licenses/>

*/

/*  
  This code generates a Taler contract in JSON format. Key steps are:

  1. recover the PHP session with the contract information
  2. generate the JSON to forward to the backend
  3. forward the response with the contract from the backend to
     to the wallet
*/


// 1) recover the session information
session_start();
if ( (! isset($_SESSION['receiver'])) ||
     (! isset($_SESSION['amount']))
{
  http_response_code (404);
  echo "Please select a contract before getting to this page...";
  exit (0);
}

/* Obtain session state */
$receiver = $_SESSION['receiver'];
$amount = intval ($_SESSION['amount']);

/* Fill in variables for simple JSON contract */
// fake product id 
// --- FIXME: base on receiver for more realism!
$p_id = rand(0,1001);
// generate a front-end transaction id. 
// In production context, we might want to
// record this value somewhere together
// with the rest of the contract data.
$transaction_id = rand(0, 1001);
// Human-readable description of this deal
$desc = "Donation to " . $receiver;
// Add the value
$value = $amount;
// We don't have a fraction.
$fraction = 0;
// This is our 'toy' currency
$currency = "KUDOS";

// pack the JSON for the contract 
// --- FIXME: exact format needs review!
$json = json_encode (array ('desc' => $desc, 
                            'product' => $p_id, 
                            'cid' => $transaction_id,
                            'price' => array ('value' => $value,
			                      'fraction' => $fraction,
                                              'currency' => $currency)));

// Craft the HTTP request, note that the backend
// could be on an entirely different machine if
// desired.
$req = new http\Client\Request ("POST",
                                "/backend/contract",
				array ("Content-Type" => "application/json"));
$req->getBody()->append ($json);

// Execute the HTTP request
$client = new http\Client;
$client->enqueue($req)->send ();

// Fetch the response
$resp = $client->getResponse ();
$status_code = $resp->getResponseCode ();

// Our response code is the same we got from the backend:
http_response_code ($status_code);

// Now generate our body  
if ($status_code != 200)
{
  echo "Error while generating the contract, response code: " . $status_code;
}
else
{
  // send the contract back to the wallet without touching it
  echo $resp->body->toString ();
}
?>