summaryrefslogtreecommitdiffstats
path: root/rss.php
blob: 269b734b2fbbdf8eb73763f95a9d5570ce46f6ec (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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
<?php
/* Copyright 2006, 2007, 2008, 2009, 2010, 2011, 2012 Arun Persaud <arun@nubati.net>
 *
 *   This file is part of e-DoKo.
 *
 *   e-DoKo 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 of the License, or
 *   (at your option) any later version.
 *
 *   e-DoKo 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 e-DoKo.  If not, see <http://www.gnu.org/licenses/>.
 *
 */

  /* get some information from the database */
error_reporting(E_ALL);

/* start a session, if it is not already running.
 * This way people don't have to log in all the times.
 * The session variables can also be read out from different
 * php scripts, so that the code can be easily split up across several files
 */

include_once("config.php");                /* needs to be first in list, since other includes use this */
include_once("./include/output.php");      /* html output only */
include_once("./include/db.php");          /* database only */
include_once("./include/functions.php");   /* the rest */

/* make sure that user has set all variables in config.php */
config_check();

/* open the database */
if(DB_open()<0)
  {
    output_header();
    echo "Database error, can't connect... Please wait a while and try again. ".
      "If the problem doesn't go away feel free to contact $ADMIN_NAME at $ADMIN_EMAIL.";
    output_footer();
    exit();
  }

$ok = 0;
$id = 0;

if(!myisset("uid","token"))
  {
    echo "error";
  }
else
  {
    $id = $_REQUEST['uid'];
    $token = get_user_token($id);

    if($token == $_REQUEST['token'])
      $ok = 1;
  }

if(! $ok)
  {
    echo "No valid userid";
    exit();
  }

header("Content-Type: text/xml");
/* start the feed */
?>
<feed xmlns="http://www.w3.org/2005/Atom">
<title>E-DoKo Feed</title>
<?php

  /* set language */
  $PREF = DB_get_PREF($id);
  $lang = $PREF['language'];

  switch($lang)
    {
    case 'de':
      putenv("LC_ALL=de_DE");
      setlocale(LC_ALL, "de_DE");
      // Specify location of translation tables
      bindtextdomain("edoko", "./locale");
      // Choose domain
      textdomain("edoko");
      break;
    default:
      /* do nothing */
    }

echo '<subtitle>'._('Know when it is your turn')."</subtitle>\n";

  global $WIKI,$INDEX, $HOST;

  /* output last creation date */
echo "<link href=\"$HOST/$INDEX\" />\n";
echo "<link rel=\"self\" href=\"".$HOST.htmlentities($_SERVER['REQUEST_URI'])."\" />\n";
$date = DB_query_array("Select create_date from User order by create_date ASC limit 1");
$date = $date[0];
$timestamp = strtotime($date);
echo "<id>tag:".$_SERVER['SERVER_NAME'].",".date("Y-m-d",$timestamp).":$INDEX</id>\n";
echo "<updated>".date(DATE_ATOM)."</updated>\n";
echo "<author>\n";
echo "<name>$ADMIN_NAME  $date $timestamp</name>\n";
echo "<email>$ADMIN_EMAIL</email>\n";
echo "</author>\n\n";


 /* output the entries */


  $result = DB_query("SELECT Hand.hash,Hand.game_id,Game.player from Hand".
		     " LEFT JOIN Game On Hand.game_id=Game.id".
		     " WHERE Hand.user_id='$id'".
		     " AND ( Game.player='$id' OR ISNULL(Game.player) )".
		     " AND ( Game.status='pre' OR Game.status='play' )".
		     " ORDER BY Game.session" );

  while( $r = DB_fetch_array($result))
    {
      echo "<entry>\n";
      echo "<title>"._('game').' '.DB_format_gameid($r[1])."</title>\n";
      $url=$INDEX."?action=game&amp;me=".$r[0];
      echo "<link href=\"".$HOST.$url."\" />\n";
      $date = DB_get_game_timestamp($r[1]);
      $timestamp = strtotime($date);
      $date = date("Y-m-d",$timestamp);
      echo "<id>tag:doko.nubati.net,$date:$url</id>\n";
      echo "<updated>".date(DATE_ATOM,$timestamp)."</updated>\n";
      echo '<summary>'._('Please use the link to access the game.')."</summary>\n";
      echo "</entry>\n\n";
    }

?>
</feed>