KKMK
Meeskond
- Kaido Tarma (D23)
- Katre Paabo (D22)
- Mark-Hendrik Mäeste (D21)
- Kaisa Taelma (D23)
XML'i kodutöö
XML'i genereerimiseks loodud programm
using System;
using System.Text;
using System.Xml;
namespace Praktikum4
{
class Program
{
static void Main(string[] args)
{
Random r = new Random();
int i, j, k;
int minTeemad = 1;
int maxTeemad = 5;
int minVastused = 1;
int maxVastused = 9;
string[] ained = new string[] { "Algebra ja graafiteooria", "Arvutigraafika", "Microsofti mobiilirakenduste arendamine", "Mobiilirakenduste arendamine Androidile", "Sidevõrgud", "Sissejuhatus Apple-i mob.", "Tarkvara testimise alused", "Veebirakenduste loomine ASP .NET abil", "Võrgurakendused II" };
string[] inimesed = new string[] { "Mati", "Kati", "Jüri", "Teet", "Linda", "Vilma", "Olga", "Vallo", "Kaupo", "Peeter" };
string[] teemanimed = new string[] { "Eksami eeldus", "Lisatunnid", "Esimene kontrolltöö", "Teine kontrolltöö", "Enesetestid", "Abimaterjalid", "Mingi teema", "Kehva teema", "Spikrid" };
string[] tekstid = new string[] {
"Tere, ma ei saa teemast üldse aru.",
"Miks me ometi sellist asja tegema peame?",
"Homses töös tuleb maha kirjutada.",
"Soovin rentida pastakat..",
"Please RTFM!",
"Pliiats on kõver!!",
"Tunnis saab ju niisama istuda, kodus on aega õppida.",
"Kui õppejõule silma ei jää, siis häid hindeid ei saa!",
"Mis te tulite siia nalja tegema vää?",
"Kolmekesi üheskoos!",
"Tahvel jäi mustaks..",
"Kolmanda vastus oli 332232323*C-124321543512343564123",
"Raske töö oli jah..",
"Astrofüüsik!",
"Kes viisi tahab saada??"
};
int teemaID = 1;
int postitusID = 1;
int vastusID = 1;
int postitajaID = 1;
XmlWriterSettings settings = new XmlWriterSettings();
settings.Indent = true;
settings.IndentChars = "\t";
XmlWriter xmlWriter = XmlWriter.Create("test.xml", settings);
xmlWriter.WriteStartDocument();
xmlWriter.WriteStartElement("KOOLIFOORUM");
for (i = 0; i < ained.Length; i++)
{
xmlWriter.WriteStartElement("AINE");
xmlWriter.WriteAttributeString("ID", i.ToString());
xmlWriter.WriteAttributeString("NIMI", ained[i]);
xmlWriter.WriteAttributeString("KOOD", ained[i].Substring(0, 4).ToUpper());
for (j = 0; j < r.Next(minTeemad, maxTeemad); j++)
{
xmlWriter.WriteStartElement("TEEMA");
xmlWriter.WriteAttributeString("ID", teemaID.ToString());
teemaID++;
xmlWriter.WriteAttributeString("NIMI", teemanimed[r.Next(0, teemanimed.Length - 1)]);
xmlWriter.WriteStartElement("POSTITUS");
xmlWriter.WriteAttributeString("ID", postitusID.ToString());
postitusID++;
xmlWriter.WriteStartElement("AEG");
DateTime aeg = new DateTime(r.Next(2000, 2010), r.Next(1, 12), r.Next(1, 28), r.Next(0, 23), r.Next(0, 59), r.Next(0, 59));
xmlWriter.WriteValue(aeg);
xmlWriter.WriteEndElement(); //AEG
xmlWriter.WriteStartElement("POSTITAJA");
postitajaID = r.Next(1, inimesed.Length - 1);
xmlWriter.WriteAttributeString("ID", postitajaID.ToString());
xmlWriter.WriteString(inimesed[postitajaID]);
xmlWriter.WriteEndElement(); //POSTITAJA
xmlWriter.WriteStartElement("TEKST");
xmlWriter.WriteString(tekstid[r.Next(0, tekstid.Length - 1)]);
xmlWriter.WriteEndElement(); //TEKST
xmlWriter.WriteEndElement(); //POSTITUS
for (k = 0; k < r.Next(minVastused, maxVastused); k++)
{
xmlWriter.WriteStartElement("VASTUS");
xmlWriter.WriteAttributeString("ID", vastusID.ToString());
vastusID++;
xmlWriter.WriteStartElement("AEG");
aeg = aeg.AddHours(r.Next(1, 2000));
aeg = aeg.AddSeconds(r.Next(1, 2000));
xmlWriter.WriteValue(aeg);
xmlWriter.WriteEndElement(); //AEG
xmlWriter.WriteStartElement("POSTITAJA");
postitajaID = r.Next(1, inimesed.Length - 1);
xmlWriter.WriteAttributeString("ID", postitajaID.ToString());
xmlWriter.WriteString(inimesed[postitajaID]);
xmlWriter.WriteEndElement(); //POSTITAJA
xmlWriter.WriteStartElement("TEKST");
xmlWriter.WriteString(tekstid[r.Next(0, tekstid.Length - 1)]);
xmlWriter.WriteEndElement(); //TEKST
xmlWriter.WriteEndElement(); //VASTUS
}
xmlWriter.WriteEndElement(); //TEEMA
}
xmlWriter.WriteEndElement(); //AINE
}
xmlWriter.WriteEndDocument(); //KOOLIFOORUM
xmlWriter.Close();
}
}
}
Genereeritud XML
<?xml version="1.0" encoding="UTF-8"?>
<KOOLIFOORUM>
<AINE ID="1" NIMI="Algebra ja graafiteooria" KOOD="ALGE">
<TEEMA ID="1" NIMI="Mingi teema">
<POSTITUS ID="1">
<AEG>2004-09-24T18:18:12</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</POSTITUS>
<VASTUS ID="1">
<AEG>2004-10-19T20:42:22</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="2" NIMI="Arvutigraafika" KOOD="ARVU">
<TEEMA ID="2" NIMI="Mingi teema">
<POSTITUS ID="2">
<AEG>2007-05-06T22:04:43</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Pliiats on kõver!!</TEKST>
</POSTITUS>
<VASTUS ID="2">
<AEG>2007-05-29T14:21:05</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="3">
<AEG>2007-06-25T06:46:48</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="4">
<AEG>2007-09-01T13:53:27</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</VASTUS>
<VASTUS ID="5">
<AEG>2007-09-30T21:00:27</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="3" NIMI="Lisatunnid">
<POSTITUS ID="3">
<AEG>2008-08-05T20:19:01</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Pliiats on kõver!!</TEKST>
</POSTITUS>
<VASTUS ID="6">
<AEG>2008-09-29T09:33:07</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="3" NIMI="Microsofti mobiilirakenduste arendamine" KOOD="MICR">
<TEEMA ID="4" NIMI="Mingi teema">
<POSTITUS ID="4">
<AEG>2004-03-25T06:20:58</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Tahvel jäi mustaks..</TEKST>
</POSTITUS>
<VASTUS ID="7">
<AEG>2004-04-23T03:42:33</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="8">
<AEG>2004-05-19T23:52:09</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Kolmekesi üheskoos!</TEKST>
</VASTUS>
<VASTUS ID="9">
<AEG>2004-07-15T02:12:34</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Tahvel jäi mustaks..</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="5" NIMI="Mingi teema">
<POSTITUS ID="5">
<AEG>2001-09-24T06:46:57</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</POSTITUS>
<VASTUS ID="10">
<AEG>2001-11-30T11:18:05</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Tunnis saab ju niisama istuda, kodus on aega õppida.</TEKST>
</VASTUS>
<VASTUS ID="11">
<AEG>2002-01-11T03:23:25</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Kolmekesi üheskoos!</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="6" NIMI="Esimene kontrolltöö">
<POSTITUS ID="6">
<AEG>2002-02-25T19:21:26</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</POSTITUS>
<VASTUS ID="12">
<AEG>2002-04-09T00:47:33</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Mis te tulite siia nalja tegema vää?</TEKST>
</VASTUS>
<VASTUS ID="13">
<AEG>2002-06-21T22:16:18</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
<VASTUS ID="14">
<AEG>2002-07-22T13:37:51</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="4" NIMI="Mobiilirakenduste arendamine Androidile" KOOD="MOBI">
<TEEMA ID="7" NIMI="Esimene kontrolltöö">
<POSTITUS ID="7">
<AEG>2001-05-22T01:56:53</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</POSTITUS>
<VASTUS ID="15">
<AEG>2001-08-11T09:10:32</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
<VASTUS ID="16">
<AEG>2001-10-30T22:10:54</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="8" NIMI="Mingi teema">
<POSTITUS ID="8">
<AEG>2006-04-09T02:28:08</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Please RTFM!</TEKST>
</POSTITUS>
<VASTUS ID="17">
<AEG>2006-05-24T09:50:41</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</VASTUS>
<VASTUS ID="18">
<AEG>2006-07-24T01:11:00</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="19">
<AEG>2006-07-31T01:42:12</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</VASTUS>
<VASTUS ID="20">
<AEG>2006-08-10T17:47:32</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Kolmekesi üheskoos!</TEKST>
</VASTUS>
<VASTUS ID="21">
<AEG>2006-08-28T18:54:19</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Please RTFM!</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="9" NIMI="Lisatunnid">
<POSTITUS ID="9">
<AEG>2005-11-13T17:50:34</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Tunnis saab ju niisama istuda, kodus on aega õppida.</TEKST>
</POSTITUS>
<VASTUS ID="22">
<AEG>2005-12-06T18:01:49</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Soovin rentida pastakat..</TEKST>
</VASTUS>
<VASTUS ID="23">
<AEG>2006-02-17T05:12:51</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="24">
<AEG>2006-03-22T17:26:33</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="5" NIMI="Sidevõrgud" KOOD="SIDE">
<TEEMA ID="10" NIMI="Esimene kontrolltöö">
<POSTITUS ID="10">
<AEG>2003-04-14T18:43:18</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</POSTITUS>
<VASTUS ID="25">
<AEG>2003-05-13T01:50:09</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Pliiats on kõver!!</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="11" NIMI="Abimaterjalid">
<POSTITUS ID="11">
<AEG>2008-10-09T10:32:20</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</POSTITUS>
<VASTUS ID="26">
<AEG>2008-11-24T19:37:37</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Kolmekesi üheskoos!</TEKST>
</VASTUS>
<VASTUS ID="27">
<AEG>2008-12-07T18:55:04</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</VASTUS>
<VASTUS ID="28">
<AEG>2008-12-15T12:02:16</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Mis te tulite siia nalja tegema vää?</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="12" NIMI="Esimene kontrolltöö">
<POSTITUS ID="12">
<AEG>2003-11-24T13:31:16</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</POSTITUS>
<VASTUS ID="29">
<AEG>2004-01-05T10:01:45</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="6" NIMI="Sissejuhatus Apple-i mob." KOOD="SISS">
<TEEMA ID="13" NIMI="Esimene kontrolltöö">
<POSTITUS ID="13">
<AEG>2001-02-23T09:30:10</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Please RTFM!</TEKST>
</POSTITUS>
<VASTUS ID="30">
<AEG>2001-03-28T13:42:14</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Pliiats on kõver!!</TEKST>
</VASTUS>
<VASTUS ID="31">
<AEG>2001-03-31T17:08:02</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
<VASTUS ID="32">
<AEG>2001-04-20T23:39:09</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</VASTUS>
<VASTUS ID="33">
<AEG>2001-06-08T02:06:32</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Mis te tulite siia nalja tegema vää?</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="14" NIMI="Abimaterjalid">
<POSTITUS ID="14">
<AEG>2006-09-05T09:08:49</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</POSTITUS>
<VASTUS ID="34">
<AEG>2006-09-19T20:18:16</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</VASTUS>
<VASTUS ID="35">
<AEG>2006-11-06T18:42:59</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</VASTUS>
<VASTUS ID="36">
<AEG>2006-12-25T01:45:19</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="7" NIMI="Tarkvara testimise alused" KOOD="TARK">
<TEEMA ID="15" NIMI="Eksami eeldus">
<POSTITUS ID="15">
<AEG>2008-08-15T01:52:45</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Tahvel jäi mustaks..</TEKST>
</POSTITUS>
<VASTUS ID="37">
<AEG>2008-09-04T20:19:06</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
<VASTUS ID="38">
<AEG>2008-09-10T17:21:33</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Kolmekesi üheskoos!</TEKST>
</VASTUS>
<VASTUS ID="39">
<AEG>2008-12-02T09:28:00</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="16" NIMI="Abimaterjalid">
<POSTITUS ID="16">
<AEG>2008-07-02T14:46:16</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</POSTITUS>
<VASTUS ID="40">
<AEG>2008-07-18T11:55:29</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Pliiats on kõver!!</TEKST>
</VASTUS>
<VASTUS ID="41">
<AEG>2008-08-03T01:24:04</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Tunnis saab ju niisama istuda, kodus on aega õppida.</TEKST>
</VASTUS>
<VASTUS ID="42">
<AEG>2008-10-23T10:50:39</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
<VASTUS ID="43">
<AEG>2008-11-01T08:14:37</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Soovin rentida pastakat..</TEKST>
</VASTUS>
<VASTUS ID="44">
<AEG>2009-01-11T11:35:00</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Please RTFM!</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="17" NIMI="Eksami eeldus">
<POSTITUS ID="17">
<AEG>2006-02-13T11:02:08</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Raske töö oli jah..</TEKST>
</POSTITUS>
<VASTUS ID="45">
<AEG>2006-05-05T05:10:52</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="46">
<AEG>2006-05-17T19:30:27</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Tahvel jäi mustaks..</TEKST>
</VASTUS>
<VASTUS ID="47">
<AEG>2006-07-07T04:51:29</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="18" NIMI="Enesetestid">
<POSTITUS ID="18">
<AEG>2009-02-16T02:44:09</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</POSTITUS>
<VASTUS ID="48">
<AEG>2009-04-19T08:45:00</AEG>
<POSTITAJA ID="9">Kaupo</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
<VASTUS ID="49">
<AEG>2009-06-26T19:48:59</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</VASTUS>
<VASTUS ID="50">
<AEG>2009-08-05T10:04:47</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Kolmekesi üheskoos!</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="8" NIMI="Veebirakenduste loomine ASP .NET abil" KOOD="VEEB">
<TEEMA ID="19" NIMI="Esimene kontrolltöö">
<POSTITUS ID="19">
<AEG>2003-05-05T13:23:44</AEG>
<POSTITAJA ID="5">Linda</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</POSTITUS>
<VASTUS ID="51">
<AEG>2003-05-30T15:46:30</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</VASTUS>
<VASTUS ID="52">
<AEG>2003-07-26T20:52:26</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
<VASTUS ID="53">
<AEG>2003-10-02T15:59:39</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
<VASTUS ID="54">
<AEG>2003-11-03T03:19:50</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="20" NIMI="Enesetestid">
<POSTITUS ID="20">
<AEG>2008-02-23T06:40:58</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Mis te tulite siia nalja tegema vää?</TEKST>
</POSTITUS>
<VASTUS ID="55">
<AEG>2008-04-04T01:56:57</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="21" NIMI="Esimene kontrolltöö">
<POSTITUS ID="21">
<AEG>2000-09-09T06:27:22</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</POSTITUS>
<VASTUS ID="56">
<AEG>2000-11-25T05:39:35</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Kolmanda vastus oli 332232323*C-124321543512343564123</TEKST>
</VASTUS>
<VASTUS ID="57">
<AEG>2000-12-23T15:04:12</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Tahvel jäi mustaks..</TEKST>
</VASTUS>
<VASTUS ID="58">
<AEG>2000-12-26T22:13:02</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Tere, ma ei saa teemast üldse aru.</TEKST>
</VASTUS>
</TEEMA>
</AINE>
<AINE ID="9" NIMI="Võrgurakendused II" KOOD="VÕRG">
<TEEMA ID="22" NIMI="Abimaterjalid">
<POSTITUS ID="22">
<AEG>2003-09-05T15:45:26</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Homses töös tuleb maha kirjutada.</TEKST>
</POSTITUS>
<VASTUS ID="59">
<AEG>2003-09-14T22:50:35</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Tunnis saab ju niisama istuda, kodus on aega õppida.</TEKST>
</VASTUS>
<VASTUS ID="60">
<AEG>2003-11-12T12:13:42</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Mis te tulite siia nalja tegema vää?</TEKST>
</VASTUS>
<VASTUS ID="61">
<AEG>2004-01-19T21:39:24</AEG>
<POSTITAJA ID="2">Kati</POSTITAJA>
<TEKST>Tahvel jäi mustaks..</TEKST>
</VASTUS>
<VASTUS ID="62">
<AEG>2004-01-25T22:45:18</AEG>
<POSTITAJA ID="8">Vallo</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</VASTUS>
<VASTUS ID="63">
<AEG>2004-03-31T05:49:55</AEG>
<POSTITAJA ID="1">Mati</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
<VASTUS ID="64">
<AEG>2004-05-07T17:02:52</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Soovin rentida pastakat..</TEKST>
</VASTUS>
</TEEMA>
<TEEMA ID="23" NIMI="Enesetestid">
<POSTITUS ID="23">
<AEG>2002-01-17T14:38:24</AEG>
<POSTITAJA ID="6">Vilma</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</POSTITUS>
<VASTUS ID="65">
<AEG>2002-02-06T23:57:36</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Miks me ometi sellist asja tegema peame?</TEKST>
</VASTUS>
<VASTUS ID="66">
<AEG>2002-02-21T15:30:47</AEG>
<POSTITAJA ID="4">Teet</POSTITAJA>
<TEKST>Mis te tulite siia nalja tegema vää?</TEKST>
</VASTUS>
<VASTUS ID="67">
<AEG>2002-04-09T14:35:29</AEG>
<POSTITAJA ID="3">Jüri</POSTITAJA>
<TEKST>Kui õppejõule silma ei jää, siis häid hindeid ei saa!</TEKST>
</VASTUS>
<VASTUS ID="68">
<AEG>2002-04-18T00:54:36</AEG>
<POSTITAJA ID="7">Olga</POSTITAJA>
<TEKST>Astrofüüsik!</TEKST>
</VASTUS>
</TEEMA>
</AINE>
</KOOLIFOORUM>
Stiilifail 1
See stiilifail väljastab html lehel kõik postitused ning nende vastused.
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl">
<!--See stiilifail väljastab html lehel kõik postitused ning nende vastused-->
<xsl:output method="html" indent="yes"/>
<xsl:template match="/">
<html>
<body style="background-color:#294052;font-family:Arial;font-size:12pt">
<span style="font-size:25pt;font-weight:bold;color:white">
KOOLIFOORUM
</span>
<xsl:for-each select="KOOLIFOORUM/AINE" >
<div style="background-color:#8FBCDB;font-size:20pt;font-weight:bold;padding:5px">
<xsl:value-of select="@NIMI"/>
</div>
<xsl:for-each select="TEEMA" >
<div style="background-color:#F4D6BC;padding:5px">
<span style="font-size:16pt;font-weight:bold">
<xsl:value-of select="@NIMI"/>
</span>
</div>
<div style="background-color:#F8E4CC;padding:10px">
<b>Postitus </b> @
<xsl:value-of select="POSTITUS/AEG"/><br></br>
<xsl:value-of select="POSTITUS/POSTITAJA"/>:
<xsl:value-of select="POSTITUS/TEKST"/><br></br>
<xsl:for-each select="VASTUS">
<b>Vastus </b> @
<xsl:value-of select="AEG"/> <br></br>
<xsl:value-of select="POSTITAJA"/>:
<xsl:value-of select="TEKST"/> <br></br>
</xsl:for-each>
</div>
</xsl:for-each>
</xsl:for-each>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Stiilitud HTML
Stiilifail 1'ga stiilitud XML, väljastus HTML kujul: http://enos.itcollege.ee/~ktarma/Vorgurakendused/XML/test_Stiil1.xml
Stiilifail 2
Antud stiilifail kuvab kõik foorumi kasutajad ja iga kasutaja puhul kasutaja algatatud teemad ühes postitamise ajaga.
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl" xmlns:fn="http://www.w3.org/2005/xpath-functions">
<!--Antud stiilifail kuvab kõik foorumi kasutajad ja iga kasutaja puhul kasutaja algatatud teemad ühes postitamise ajaga-->
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/">
<KASUTAJAD>
<xsl:for-each select="//POSTITAJA[not(. = preceding::POSTITAJA)]" >
<KASUTAJANIMI>
<xsl:value-of select="."/>
</KASUTAJANIMI>
<xsl:variable name="tmp" select="@ID" />
<POSTITUSED>
<xsl:for-each select="//POSTITUS[POSTITAJA/@ID = $tmp]" >
<POSTITUS>
<AEG>
<xsl:value-of select="AEG"/>
</AEG>
<TEXT>
<xsl:value-of select="TEKST"/>
</TEXT>
</POSTITUS>
</xsl:for-each>
</POSTITUSED>
</xsl:for-each>
</KASUTAJAD>
</xsl:template>
</xsl:stylesheet>
Stiilifail 3
See stiilifail väljastab XML kujul kõikide postituste teema ning aine, kus see asub.
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<!--See stiilifail väljastab XML kujul kõikide postituste teema ning aine, kus see asub-->
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="/">
<POSTITUSED>
<xsl:for-each select="KOOLIFOORUM/AINE/TEEMA/POSTITUS">
<POSTITUS>
<xsl:attribute name="ID">
<xsl:value-of select="@ID"/>
</xsl:attribute>
<TEEMA>
<xsl:attribute name="NIMI">
<xsl:value-of select="../@NIMI"/>
</xsl:attribute>
</TEEMA>
<AINE>
<xsl:attribute name="NIMI">
<xsl:value-of select="../../@NIMI"/>
</xsl:attribute>
<xsl:attribute name="KOOD">
<xsl:value-of select="../../@KOOD"/>
</xsl:attribute>
</AINE>
</POSTITUS>
</xsl:for-each>
</POSTITUSED>
</xsl:template>
</xsl:stylesheet>
Manuaalselt genereeritud skeemifail
<?xml version="1.0" encoding="utf-8"?>
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="KOOLIFOORUM" type="foorumType" />
<xs:complexType name="foorumType">
<xs:sequence minOccurs="1" maxOccurs="unbounded">
<xs:element name="AINE" type="aineType" />
</xs:sequence>
</xs:complexType>
<xs:complexType name="aineType">
<xs:sequence minOccurs="0" maxOccurs="unbounded">
<xs:element name="TEEMA" type="teemaType" />
</xs:sequence>
<xs:attribute name="ID" type="xs:positiveInteger" use="required" />
<xs:attribute name="NIMI" type="xs:string" use="required" />
<xs:attribute name="KOOD" type="xs:string" use="required" />
</xs:complexType>
<xs:complexType name="teemaType">
<xs:sequence minOccurs="1" maxOccurs="unbounded">
<xs:element name="POSTITUS" type="postitusType" />
<xs:element name="VASTUS" type="postitusType" minOccurs="0" maxOccurs="unbounded" />
</xs:sequence>
<xs:attribute name="ID" type="xs:positiveInteger" use="required" />
<xs:attribute name="NIMI" type="xs:string" use="required" />
</xs:complexType>
<xs:complexType name="postitusType">
<xs:all>
<xs:element name="AEG" type="xs:dateTime" />
<xs:element name="POSTITAJA" type="postitajaType" />
<xs:element name="TEKST" type="xs:string" />
</xs:all>
<xs:attribute name="ID" type="xs:positiveInteger" use="required" />
</xs:complexType>
<xs:complexType name="postitajaType">
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="ID" type="xs:positiveInteger" use="required" />
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:schema>
Automaatselt genereeritud skeemifail
<?xml version="1.0" encoding="utf-8"?>
<xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
<xs:element name="KOOLIFOORUM">
<xs:complexType>
<xs:sequence>
<xs:element maxOccurs="unbounded" name="AINE">
<xs:complexType>
<xs:sequence>
<xs:element maxOccurs="unbounded" name="TEEMA">
<xs:complexType>
<xs:sequence>
<xs:element name="POSTITUS">
<xs:complexType>
<xs:sequence>
<xs:element name="AEG" type="xs:dateTime" />
<xs:element name="POSTITAJA">
<xs:complexType>
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="ID" type="xs:unsignedByte" use="required" />
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:element>
<xs:element name="TEKST" type="xs:string" />
</xs:sequence>
<xs:attribute name="ID" type="xs:unsignedByte" use="required" />
</xs:complexType>
</xs:element>
<xs:element maxOccurs="unbounded" name="VASTUS">
<xs:complexType>
<xs:sequence>
<xs:element name="AEG" type="xs:dateTime" />
<xs:element name="POSTITAJA">
<xs:complexType>
<xs:simpleContent>
<xs:extension base="xs:string">
<xs:attribute name="ID" type="xs:unsignedByte" use="required" />
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:element>
<xs:element name="TEKST" type="xs:string" />
</xs:sequence>
<xs:attribute name="ID" type="xs:unsignedByte" use="required" />
</xs:complexType>
</xs:element>
</xs:sequence>
<xs:attribute name="ID" type="xs:unsignedByte" use="required" />
<xs:attribute name="NIMI" type="xs:string" use="required" />
</xs:complexType>
</xs:element>
</xs:sequence>
<xs:attribute name="ID" type="xs:unsignedByte" use="required" />
<xs:attribute name="NIMI" type="xs:string" use="required" />
<xs:attribute name="KOOD" type="xs:string" use="required" />
</xs:complexType>
</xs:element>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
XML Retsensioonid
Retsensioon meeskonna "BitByBit" XML ülesande kohta
Meeskond BitbyBit on valinud oma teemaks muusika ning sellega seotud elementide kategoriseerimise ja kirjeldamise. XML fail juurelemendiks on üldiselt muusika (music), järjestuse järgmiseks etapiks on esitaja (artist), kellel võib olla mitu albumit. Igal albumil on järjestatud lood (song), milledel on eraldi kommentaarid, ja albumi kommentaar.
XML on süntaktilise ehituse poolest korrektne. Otsingute tegemiseks on selline XML küllaltki hea. Sellegi poolest jääb arusaamatuks, miks on igal lool eraldi žanr, kui iga albumi juures on kirjeldatud selle muusikavool. See oleks mõistetav, kui tegemist on n-ö kogutud teoste või aastahittidega, millel iga laul võib olla eri žanrist. Sellisel juhul peaks iga laulu juures olema ka eraldi esitaja, mis enamus juhtudel tekitaks info liiasust. Samuti näib eraldi albumi kommentaar (album comments) liiasena, sest iga muusikapala juures on eraldi kommentaar.
XML-i skeemifail (XSD) on vastavuses XML-is esinevate elementide, atribuutide ja atribuudi nimede ning tüüpidega.
Esimese päringu puhul on tegemist kõiki „metal“ žanri sisaldavate lugude väljaeraldamisega. Selline otsing on vajalik juhul, kui tegemist on albumiga, millel on paljude esinejate palad. Praegusel juhul piisaks otsingust üle albumi žanrite.
Teine päring käib üle kõik albumid ning kuvab nende andmed üksteise järel. Tulemuseks on loetavavad eraldused, millest on väga hea lugeda iga albumi kohta.
Kolmas päring on samuti head ülevaadet andev tabel lauljate ning kõigi nende albumite kohta. Selline päring on paslik näiteks muusikapoes, kus tihti on vaja ülevaadet konkreetse artisti kõikidest albumitest.
Töö täitis ülesande tingimusi. Vaatamata on lühidusele, täitab see oma ülesannet. Hea loetavuse tõttu ei näe põhjust eraldi dokumentatsiooniks ega kommentaarideks. Iga päringu juures oli välja trükitud, mida konkreetne väärtus tähendab.
Retsensioon meeskonna "Trenniinfo" XML ülesande kohta
XML fail on suhteliselt lühike. Aadressi asemel oleks võinud kasutada linna, sest aadress märgib pigem täpsemat asukohta. Kalev Spa spordialade juures on mõlemal treeningajaks argipäevad. Ühes on see ka eraldi välja toodud, teises on ainult päevadena kirja pandud. See oleks võinud olla ühtemoodi tehtud.
Sama kehtib ka Saku spordikompleksi kohta. Treeningpäevad võiks olla ühtemoodi märgitud. Kui trenni saab teha igapäevaselt, siis võiks see igal pool ka samamoodi märgitud olla. Samuti hakkab siin silma ka spordialade juures ära märgitud tasuta võimaluse koht, kuigi allpool maksumuse juures on selleks täiesti hea koht olemas. Pole vajadust sama infot allpool uuesti korrata.
Esimese XML transformatsioonifaili puhul väljastatakse kõik spordikohad koos infoga. Paremini loetavuse koha pealt võiks peale treeningu kohta ja ennem spordiala olla ka üks tühi rida, sest vastasel juhul tekib mulje, et see kehtibki vaid esimese spordiala kohta, kui tegelikult näitab see infot ka järgmiste kohta.
Teise XML transformatsiooni faili puhul on sama asi. Ei ole väga hästi aru saada, kas andmed kehtivad vaid teatud informatsiooni kohta või laienevad ka allpool olevatele. Tulemus on praktiliselt sama, mis esimese puhul. Muutunud on ainult see, et maksumuse koha peal öeldakse, et see on tasuta.
Kolmanda XML transformatsiooni faili juures võib märgata praktiliselt sama tulemust, mis eelmiste puhul. Seekord on aga paremini aru saada, mille kohta info käib. Siin tulevad välja ka erinevused treeningpäevade suhtes. Kui ühel on ETKNRLP kirjeldatud päevadena, siis teisel on märgitud, et toimub igapäevaselt, kuigi need tähendavad ühte ja sama asja.
Kõiki kolme transformatsiooni puhul oleks võinud olla erinevad väljastused. Hetkel väljastavad kõik kolm praktiliselt ühte ja sama väärtust. Aga oleks võinud olla väljastused näiteks kõikidele sisehallidele või kõikidele jõutreeningutele.
Teenuse Kirjeldus
Teenus on mõeldud foorumitega seonduva loomiseks, haldamiseks ja muutmiseks.
Iga foorumi juures on kategooriad, mis liigitavad konkreetse foorumi suundi.
Kategooria jaguneb omakorda teemadeks, mida võib ühe kategooria raames olla mitmeid.
Teemal on kasutajate poolt postitatud teated ehk postitused.
Foorumi päringud
Foorumi päringud implementeerivad foorumi interfacei.
Kategooria päringud
Kategooria päringud implementeerivad kategooria interfacei, mis omakorda baas interfacei (ITemplate).
Teema päringud
Teema päringud implementeerivad teema interfacei, mis omakorda baas interfacei (ITemplate).
Postituse päringud
Postituse päringud implementeerivad postituse interfacei, mis omakorda baas interfacei (ITemplate).
Kasutaja päringud
Kasutaja päringud implementeerivad kasutaja interfacei.
Rolli päringud
Rolli päringud implementeerivad rolli interfacei.
FirstQueries
Membership päringud
Membership päringud implementeerivad Membership interfacei.
Klientrakenduse Kirjeldus
Rakendusel on kahte tüüpi kasutajaid-tavakasutajad ja administraator.
Selleks, et foorumeid, kategooriaid ja teemasid vaadata on vaja sisse logida.
Kui kasutajal veel kontot pole, saab ta selle teha registreerimise lehel.
Kasutaja saab vajadusel muuta enda andmeid ja profiilipilti.
Kasutaja saab lisada, muuta ja kommenteerida vaid postitusi.
Foorumeid, kategooriaid ja topicuid saab lisada vaid administraator.
Administraator saab foorumeid aktiivseks ja mitteaktiivseks teha. Lisaks saab administraator muuta ning vaadata kasutajate andmeid ja vajadusel kasutajaid kustutada.
Selliseid rakendusi on maailmas palju, ning nagu näha, siis pole olemas seda kõige paremat - täiuslikku foorumit.
Ka meie rakendust(ja selle kõrvalt teenust) saaks veel suurel määral täiendada. Hetkel peame suurimaks puuduseks ebaturvalisust ja seda, et kliendile pole lisatud töötavat custom membershipi.
Kasutasime ASP.NET MVC4 tehnoloogiat.
Rakenduse käivitamine
1) Esmalt tuleb alla laadida pakk siit või kasutada selleks TFSi.
2) Siis tuleb ära muuta WcfForumService Web.config'u serviceCertificate thumbprint (WcfForumService->Web.config->Advanced->Service Behaviors->serviceBehavior->serviceCredentials->serviceCertificate). (enne seda peab teil olema vajalik sertifikaat, mille loomist kirjeldatakse siin)
3) Tõenäoliselt peate ka rebuildima library, clienti ja service.
4) Nüüd tuleb luua andmebaasi(.\sqlexpress) vajalikud tabelid. Selleks on vastavad SQL skriptid ForumServiceLibrary/Scripts kaustas.
5) Nüüd tuleb ka ASP.NET Membershipi jaoks vajalikud tabelid luua, seda on kirjeldatud siin.
5.1) See võib visata errorit, et NETWORK SERVICE on juba olemas, siis tuleb see käsitsi ära kustutada ja ikkagi 5) uuesti teha.
6) Siis võite käivitada rakenduse.
7) Teile näidatakse tühja lehte, kus veel ühtegi foorumit ei ole, kuna andmebaas on tühi. Esimene setup toimub aadressil: http://localhost:64621/Home/Setup
8) Peale seda peaks teil olema administraatori õigusega kasutaja ning esimene foorum loodud.
8.1) Kui esineb probleeme sellise "külma stardiga", siis võite andmebaasist vanad kirjed ära kustutada skriptiga (ForumServiceLibrary/Scripts/SQLdelete.sql) ning uuesti proovida.
Teenuse Retsensioonid
Retsensioon meeskonna "X-Ladu" Teenuse ülesande kohta
Teenus
Tegemist on Windows Communication Foundation tehnoloogial realiseeritud teenusega. Teenuse funksionaalsus on defineeritud projektis X-LaduLibrary. Seega teenus ja kasutatav äriloogika on eraldatud, ning seega on võimalik olemasoleva loogika lihtsam muutmine ning taaskasutus teistes projektides. Teenus vastab üldjoontes aines toodud ülesandepüstitusele:
- Teenus võimaldab pidada logi kasutajate tegevuste kohta ja kasutajate haldamist. Logi on baasis toodud eraldi tabelina, kuid logi täiendamine ei toimu teenuses automaatselt vaid see funktsionaalsus peab olema realiseeritud kliendi poolel. Teenus kujutab endast suuresti lihtsalt liidest klientrakenduse ja baasi vahel.
- Kasutajate tuvastamine teenuse poolel piirdub parooli ja kasutajanime põhjal kasutaja baasist leidmisega. Nagu ka autorid ise on öelnud, siis teenuse turvamine on hetkel veel realiseerimata. Kasutusel on basicHttpBinding.
Teenus on loodud ühe konkreetse ettevõtte tarbeks ja üldiselt teistele teenuse pakkumist ei võimalda, kuna kliendi tuvastamine puudub ja uute klientide lisamine eeldab ka olemasoleva klientrakenduse muutmist (ülesande püstituse kohalt pole see küll puudus, kuna teenus võibki olla loodud vaid ühe “juriidilise” kliendi tarbeks). Teisalt, skaleeruvust arvestades on tegemist siiski miinusega, kuna edaspidine muutmine on selle võrra keerulisem.
Meeskonna lehel on kergesti leitav nii ammendav teenuse kirjeldus kui ka kasutajajuhend, mille abil on võimalik teenus ka reaalselt käivitada.
Kood
Teenuses on kood loogiliselt liigendatud: eraldi kaustades on mudelid ja “data access” kiht, milles on baasi vastu käivad päringud. Päringud on eristatud kasutaja õiguste põhjal (tavakasutaja ja administraatori päringud), mitte olemite kaupa (nt tootegrupi pärningud jne). Taoline lähenemine ilmselt kergendab kliendis loogika kirjeldamist. Lisaks on eraldi välja toodud nn automaatsed päringud kasutaja autoriseerimiseks ning logi lisamiseks.
Projektle on lisatud ka vajalik sql skript, mis võimaldab projekti tööle saada ka retsenseerijatel.
Andmebaasis on toodud tabelid “Kasutaja”, “KasutajaLogi”, “Kommentar”, “Toode”, ja “Tootegrupp”. Kuigi ka nende tabelite abil saab luua töötava rakenduse, siis andmebaasi disain jääb kohati siiski küsitavaks. Näiteks on olemis “Kasutaja” sõnena kirjas kommentaar, kuid samas on loodud ka Kommentaari tabel, millesse kasutaja saab lisada kommentaare toote kohta. Üldisem lahendus oleks kasutada Kommentaaride tabelit ja kahte vahetabelit kasutajate ja toodete kommentaaride hoidmiseks. Sellisel juhul ei tekiks ka segadust nimetustega, kuna mõiste “Kommentaar” tähendaks ühte ja sama nii toote kui ka kasutaja puhul.
Andmebaasi disaini juures tasuks märkida ka seda, et sõltuvalt toote kategooriast võidakse baasis hoida suurel hulgal liigseid andmeid: näiteks toote “tomatimahl” korral on tabelis “Toode” ikkagi olemas väljad pikkuse, laiuse, rõiva suuruse ja muude parameetrite kirjeldamiseks. Üheks lahenduseks oleks lisada tabelid erinevate parameetrite grupeerimiseks toote iseloomu järgi. Ka ühikud võiksid olla eraldi tabelis.
Võimalik, et taoline lähenemine muudaks projekti mõnevõrra keerukamaks, kuid taas: edaspidi oleks lihtsam teenust muuta (näiteks lisada ühikute teisendamise loogika teenusesse). Lisaks paraneks kasutusmugavus, kuna kasutaja ei pea leidma suure hulga info hulgast tarvilikke parameetreid.
Kommentaare pole mõistetavatel põhjustel paljudele meetoditele lisatud. Nimelt on meetodite ja argumentide nimetused valdavalt ennast seletavad (näiteks meetod annaToodeKoguseJargi(double kogus)) ja seega kommentaaride vähesus üldjuhul ei häiri. Küll aga võiks ära mainida, et kui jätta kommentaarid lisamata, siis pole mõtet jätta koodi ka tühjasid dokumentatsiooni väljasid, mis häirivad rohkem kui puuduvad märked. Tõenäoliselt on tegu ajapuuduse tagajärjega, kuid olulisem osa (teenuse poolt pakutavad meetodid) on ka dokumenteeritud.
Mis on mõnevõrra harjumatu on valitud keel: koodis on igal võimalikul juhul kasutusel eesti keel ja näiteks andmebaasi juures tähendab see võrdlemisi kummalisi tabelite nimetusi (näiteks “Toodes”). Teisalt on valitud stiili läbivalt järgitud, kui välja arvata vahemuutuja “query”. Üldiselt on eestikeelne kood küll harjumatu, kuid arvatavasti pole see mitte otseselt puudus, kuna tegemist on koolitöö raames valminud projektiga. Probleemiks osutuks see tõenäoliselt alles reaalse kasutamise korral.
Kokkuvõte
Üldjoontes on teenus realiseeritud korrektselt: kogu olemasolev funktsionaalsus töötab ja kood on lihtsalt loetav. Miinustena võib välja tuua teenuse turvalisuse puudumist ja võibolla ka mudelite disaini, mis piirab liigselt pakutavaid võimalusi ja vähendab kasutusmugavust.
Teenus on piisaval määral dokumenteeritud.
Rakenduste Retsensioonid
Retsensioon meeskonna "X-Ladu" Rakenduse kohta
Log
07.03.2013 - sai valmis esimene osa kodusest tööst (XML)
09.03.2013 - kandsime esimese osa (XML) WIKI keskkonda
29.03.2013 - kandsime XML retsensioonid WIKI keskkonda
25.05.2013 - kandsime teenuse kirjelduse WIKI keskkonda
26.05.2013 - kandsime rakenduse kirjelduse WIKI keskkonda