]> git.vomp.tv Git - vompserver.git/blob - vdrcommand.h
Merge branch '10736-remake' into 0-4-0rc
[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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  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_GETMEDIALIST        = 30;
67 const static ULONG VDR_OPENMEDIA           = 31;
68 const static ULONG VDR_GETMEDIABLOCK       = 32;
69 const static ULONG VDR_GETMEDIAINFO        = 35;
70 const static ULONG VDR_CLOSECHANNEL        = 36;
71
72 class VDR_Command : public SerializableList {
73   public:
74     VDR_Command(const ULONG cmd) {
75       command=cmd;
76       addParam(&command);
77     }
78     virtual ~VDR_Command(){}
79     ULONG command;
80 };
81
82 class VDR_GetMediaListRequest : public VDR_Command {
83   public:
84     VDR_GetMediaListRequest(MediaURI *root) :VDR_Command(VDR_GETMEDIALIST) {
85       addParam(root);
86     }
87 };
88
89 class VDR_GetMediaListResponse : public VDR_Command {
90   public:
91     VDR_GetMediaListResponse(ULONG *flags,MediaList *m) : VDR_Command(VDR_GETMEDIALIST|VDR_RESPONSE_FLAG){
92       addParam(flags);
93       addParam(m);
94     }
95 };
96
97 class VDR_OpenMediumRequest : public VDR_Command {
98   public:
99     VDR_OpenMediumRequest(ULONG *channel,MediaURI *u,ULONG *xsize, ULONG *ysize) :
100       VDR_Command(VDR_OPENMEDIA) {
101         addParam(channel);
102         addParam(u);
103         addParam(xsize);
104         addParam(ysize);
105       }
106 };
107 class VDR_OpenMediumResponse : public VDR_Command {
108   public:
109     VDR_OpenMediumResponse(ULONG *flags,ULLONG *size) :
110       VDR_Command(VDR_OPENMEDIA|VDR_RESPONSE_FLAG) {
111         addParam(flags);
112         addParam(size);
113       }
114 };
115 class VDR_GetMediaBlockRequest : public VDR_Command {
116   public:
117     VDR_GetMediaBlockRequest(ULONG * channel, ULLONG *pos, ULONG *max):
118       VDR_Command(VDR_GETMEDIABLOCK) {
119         addParam(channel);
120         addParam(pos);
121         addParam(max);
122       }
123 };
124
125 //no response class for GetMediaBlock
126
127
128 class VDR_CloseMediaChannelRequest : public VDR_Command {
129   public:
130     VDR_CloseMediaChannelRequest(ULONG * channel):
131       VDR_Command(VDR_CLOSECHANNEL) {
132         addParam(channel);
133       }
134 };
135
136 class VDR_CloseMediaChannelResponse : public VDR_Command {
137   public:
138     VDR_CloseMediaChannelResponse(ULONG * flags):
139       VDR_Command(VDR_CLOSECHANNEL|VDR_RESPONSE_FLAG) {
140         addParam(flags);
141       }
142 };
143
144 class VDR_GetMediaInfoRequest : public VDR_Command {
145   public:
146     VDR_GetMediaInfoRequest(ULONG * channel):
147       VDR_Command(VDR_GETMEDIAINFO) {
148         addParam(channel);
149       }
150 };
151 class VDR_GetMediaInfoResponse : public VDR_Command {
152   public:
153     VDR_GetMediaInfoResponse(ULONG * flags,MediaInfo *info):
154       VDR_Command(VDR_GETMEDIAINFO|VDR_RESPONSE_FLAG) {
155         addParam(flags);
156         addParam(info);
157       }
158 };
159
160
161
162
163 #endif