]> git.vomp.tv Git - vompserver.git/blob - vdrcommand.h
Add handling for recording minuatures
[vompserver.git] / vdrcommand.h
1 /*
2     Copyright 2004-2005 Chris Tallon, Andreas Vogel
3
4     This file is part of VOMP.
5
6     VOMP is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by
8     the Free Software Foundation; either version 2 of the License, or
9     (at your option) any later version.
10
11     VOMP is distributed in the hope that it will be useful,
12     but WITHOUT ANY WARRANTY; without even the implied warranty of
13     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14     GNU General Public License for more details.
15
16     You should have received a copy of the GNU General Public License
17     along with VOMP; if not, write to the Free Software
18     Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19 */
20
21 #ifndef VDRCOMMAND_H
22 #define VDRCOMMAND_H
23
24 #include "defines.h"
25 #include "serialize.h"
26 #include "media.h"
27
28 /**
29   * data holder for VDR commands
30   * it's only important to add serializable objects
31   * in the same order on both sides
32   */
33
34 //until we really have response - commands we simply take
35 //the request+this flag for responses
36 //not really necessary but for checks it's better to have a command ID at least in some responses
37 const static ULONG VDR_RESPONSE_FLAG =0x1000000;
38
39 //as this header is only included by vdr.cc the constants are this way private
40 //but can easily be used on the server side as well
41
42 const static ULONG VDR_LOGIN               = 1;
43 const static ULONG VDR_GETRECORDINGLIST    = 2;
44 const static ULONG VDR_DELETERECORDING     = 3;
45 const static ULONG VDR_GETCHANNELLIST      = 5;
46 const static ULONG VDR_STREAMCHANNEL       = 6;
47 const static ULONG VDR_GETBLOCK            = 7;
48 const static ULONG VDR_STOPSTREAMING       = 8;
49 const static ULONG VDR_STREAMRECORDING     = 9;
50 const static ULONG VDR_GETCHANNELSCHEDULE  = 10;
51 const static ULONG VDR_CONFIGSAVE          = 11;
52 const static ULONG VDR_CONFIGLOAD          = 12;
53 const static ULONG VDR_RESCANRECORDING     = 13;  // FIXME obselete
54 const static ULONG VDR_GETTIMERS           = 14;
55 const static ULONG VDR_SETTIMER            = 15;
56 const static ULONG VDR_POSFROMFRAME        = 16;
57 const static ULONG VDR_FRAMEFROMPOS        = 17;
58 const static ULONG VDR_MOVERECORDING       = 18;
59 const static ULONG VDR_GETNEXTIFRAME       = 19;
60 const static ULONG VDR_GETRECINFO          = 20;
61 const static ULONG VDR_GETMARKS            = 21;
62 const static ULONG VDR_GETCHANNELPIDS      = 22;
63 const static ULONG VDR_DELETETIMER         = 23;
64 const static ULONG VDR_GETLANGUAGELIST     = 33;
65 const static ULONG VDR_GETLANGUAGECONTENT  = 34;
66 const static ULONG VDR_SETCHARSET          = 37;
67 const static ULONG VDR_GETMEDIALIST        = 30;
68 const static ULONG VDR_OPENMEDIA           = 31;
69 const static ULONG VDR_GETMEDIABLOCK       = 32;
70 const static ULONG VDR_GETMEDIAINFO        = 35;
71 const static ULONG VDR_CLOSECHANNEL        = 36;
72 const static ULONG VDR_GETRECSCRAPEREVENTTYPE = 38;
73 const static ULONG VDR_GETSCRAPERMOVIEINFO = 39;
74 const static ULONG VDR_GETSCRAPERSERIESINFO = 40;
75 const static ULONG VDR_LOADTVMEDIA          =41;
76 const static ULONG VDR_LOADTVMEDIARECTHUMB  =42;
77 const static ULONG VDR_SHUTDOWN            = 666;
78
79 class VDR_Command : public SerializableList {
80   public:
81     VDR_Command(const ULONG cmd) {
82       command=cmd;
83       addParam(&command);
84     }
85     virtual ~VDR_Command(){}
86     ULONG command;
87 };
88
89 class VDR_GetMediaListRequest : public VDR_Command {
90   public:
91     VDR_GetMediaListRequest(MediaURI *root) :VDR_Command(VDR_GETMEDIALIST) {
92       addParam(root);
93     }
94 };
95
96 class VDR_GetMediaListResponse : public VDR_Command {
97   public:
98     VDR_GetMediaListResponse(ULONG *flags,MediaList *m) : VDR_Command(VDR_GETMEDIALIST|VDR_RESPONSE_FLAG){
99       addParam(flags);
100       addParam(m);
101     }
102 };
103
104 class VDR_OpenMediumRequest : public VDR_Command {
105   public:
106     VDR_OpenMediumRequest(ULONG *channel,MediaURI *u,ULONG *xsize, ULONG *ysize) :
107       VDR_Command(VDR_OPENMEDIA) {
108         addParam(channel);
109         addParam(u);
110         addParam(xsize);
111         addParam(ysize);
112       }
113 };
114 class VDR_OpenMediumResponse : public VDR_Command {
115   public:
116     VDR_OpenMediumResponse(ULONG *flags,ULLONG *size) :
117       VDR_Command(VDR_OPENMEDIA|VDR_RESPONSE_FLAG) {
118         addParam(flags);
119         addParam(size);
120       }
121 };
122 class VDR_GetMediaBlockRequest : public VDR_Command {
123   public:
124     VDR_GetMediaBlockRequest(ULONG * channel, ULLONG *pos, ULONG *max):
125       VDR_Command(VDR_GETMEDIABLOCK) {
126         addParam(channel);
127         addParam(pos);
128         addParam(max);
129       }
130 };
131
132 //no response class for GetMediaBlock
133
134
135 class VDR_CloseMediaChannelRequest : public VDR_Command {
136   public:
137     VDR_CloseMediaChannelRequest(ULONG * channel):
138       VDR_Command(VDR_CLOSECHANNEL) {
139         addParam(channel);
140       }
141 };
142
143 class VDR_CloseMediaChannelResponse : public VDR_Command {
144   public:
145     VDR_CloseMediaChannelResponse(ULONG * flags):
146       VDR_Command(VDR_CLOSECHANNEL|VDR_RESPONSE_FLAG) {
147         addParam(flags);
148       }
149 };
150
151 class VDR_GetMediaInfoRequest : public VDR_Command {
152   public:
153     VDR_GetMediaInfoRequest(ULONG * channel):
154       VDR_Command(VDR_GETMEDIAINFO) {
155         addParam(channel);
156       }
157 };
158 class VDR_GetMediaInfoResponse : public VDR_Command {
159   public:
160     VDR_GetMediaInfoResponse(ULONG * flags,MediaInfo *info):
161       VDR_Command(VDR_GETMEDIAINFO|VDR_RESPONSE_FLAG) {
162         addParam(flags);
163         addParam(info);
164       }
165 };
166
167
168
169
170 #endif