Clarify adding a share in instructions
[pyTivo/krkeegan.git] / plugins / admin / templates / settings.tmpl
blob64bf697131a3f91bc0f96e91ec45053ad1370465
1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">\r
2 <html>\r
3 <head>\r
4         <meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">\r
5         <title>pyTivo Web Configuration</title>\r
6         <script language="javascript" type="text/javascript">\r
7                 function fillBlank(){\r
8                         var texts=document.getElementsByTagName('input');\r
9                         for (var i_tem = 0; i_tem < texts.length; i_tem++){\r
10                                 if (texts[i_tem].value==''){\r
11                                         texts[i_tem].value=' ';\r
12                                 }\r
13                         }\r
14                 }\r
15                 function switchDiv(pass, type){ \r
16                         hideallids(type);\r
17                         showDiv(pass);\r
18                 }\r
19                 function hideallids(type){\r
20                         //loop through the array and hide each element by id\r
21                         var divs = document.getElementsByTagName('div');\r
22                         for (var i=0;i<divs.length;i++){\r
23                                 if(divs[i].id.match(type)){\r
24                                         hideDiv(divs[i].id);\r
25                                 }\r
26                         } \r
27                 }\r
28                 function hideDiv(pass) {\r
29                         var divs = document.getElementsByTagName('div');\r
30                         for(i=0;i<divs.length;i++){\r
31                                 if(divs[i].id.match(pass)){//if they are 'see' divs\r
32                                         if (document.getElementById){// DOM3 = IE5, NS6\r
33                                                 divs[i].style.visibility="hidden";// show/hide\r
34                                         }\r
35                                         else{\r
36                                                 if (document.layers){ // Netscape 4\r
37                                                         document.layers[divs[i]].display = 'hidden';\r
38                                                 }\r
39                                                 else{ // IE 4\r
40                                                         document.all.hideshow.divs[i].visibility = 'hidden';\r
41                                                 }\r
42                                         }\r
43                                 }\r
44                         }\r
45                 }\r
46                 function showDiv(pass) {\r
47                         var divs = document.getElementsByTagName('div');\r
48                         for(i=0;i<divs.length;i++){\r
49                                 if(divs[i].id == pass){\r
50                                         if (document.getElementById){\r
51                                                 divs[i].style.visibility="";\r
52                                         }\r
53                                         else {\r
54                                                 if (document.layers){ // Netscape 4\r
55                                                         document.layers[divs[i]].display = '';\r
56                                                 }\r
57                                                 else{ // IE 4\r
58                                                         document.all.hideshow.divs[i].visibility = '';\r
59                                                 }\r
60                                         }\r
61                                 }\r
62                         }\r
63                 }\r
64                 function deleteSection(id){\r
65                         if (select_section.section.options[id].text == 'Global Server Settings'){\r
66                                 alert('Delete Error:\n\nSorry the Global Server Settings Section is required for pyTivo to run and cannot be deleted');\r
67                                 return true;\r
68                         }\r
69                         var name = select_section.section.options[id].text;\r
70                         var answer = confirm("Are you sure you wish to delete the '" + name + "' Section?")\r
71                         if (answer){\r
72                                 switchDiv('set-delete', 'set-');\r
73                                 select_section.section.options[id] = null;\r
74                                 var field = document.getElementById(name).value;\r
75                                 document.getElementById(field).value = 'Delete_Me';\r
76                                 saveNotify();\r
77                                 return true;\r
78                         }               \r
79                 }\r
80                 function resetpyTivo(){\r
81                         var answer = confirm("Are you sure you wish to reset the pyTivo Server? Any unsaved changes will be lost!")\r
82                         if (answer){\r
83                                 window.location="/TiVoConnect?Command=Reset&Container=$container"\r
84                         }\r
85                 }\r
86                 function showData(form) {\r
87                         var section = ""\r
88                         var setting = ""\r
89                         re=/[\[\]<>|]/;\r
90                         inputs = form.getElementsByTagName("input");\r
91                         for (i = 0; i < inputs.length; i++){\r
92                                 if (inputs[i].type == 'text' && re.exec(inputs[i].value)){\r
93                                         setting = inputs[i].name;\r
94                                         break;\r
95                                 }\r
96                         }\r
97                         if (setting != ""){\r
98                                 var map = document.getElementById('Section_Map').value.split(']');\r
99                                 map.pop();\r
100                                 splitSetting = setting.split('.');\r
101                                 for(i=0;i<map.length;i++){\r
102                                         key = map[i].split('|');\r
103                                         //buffer += key[0] + "---" + key[1] + "===" + splitSetting[0] + "\n";\r
104                                         if (splitSetting[0] == 'Server'){\r
105                                                 section = 'server';\r
106                                                 break;\r
107                                         }\r
108                                         if (key[0] == splitSetting[0]){\r
109                                                 section = key[1];\r
110                                                 break;\r
111                                         }\r
112                                 }\r
113                                 alert("Invalid Entry:\nSorry these are not allowed \n[]<>|");\r
114                                 switchDiv('set-' + section, 'set-');\r
115                                 document.getElementById(setting).select();\r
116                                 return false;\r
117                         }\r
118                         fillBlank();\r
119                         document.config.submit();\r
120                 }\r
121                 function saveNotify(){\r
122                         document.getElementById('B1').style.fontWeight= 'bold';\r
123                         document.getElementById('B2').disabled = true;\r
124                 }\r
125         </script>\r
126 </head>\r
127 <body style="background-color: rgb(250, 250, 250);">\r
129 <p align="center"><font size="6">pyTivo Web\r
130 Configuration</font> <a href="javascript:switchDiv('help-instructions', 'help-');">help</a></p>\r
131 <center>\r
132 <table style="border: 1px solid rgb(220, 220, 220);background-color: rgb(255, 255, 255);text-align: left; margin-left: auto; margin-right: auto;" border="0" cellpadding="0" cellspacing="4">\r
134   <tbody>\r
136     <tr>\r
138       <td style="border-right: 1px dotted rgb(153, 153, 153); vertical-align: top;">\r
139       <div id="leftframe" style="position: relative; text-align: center; width: 200px;">\r
140       <form name="select_section">Sections\r
141         <select name="section" size="7">\r
142         <option value="set-server">Global Server Settings</option>\r
143 #for $name, $data in $shares_data\r
144         <option value="set-$name">$name</option>\r
145 #end for\r
146 #for $name, $data in $tivos_data\r
147         <option value="set-$name">$name</option>\r
148 #end for\r
149         </select>\r
151         <input name="B3" value="Edit Section" type="button" onclick="switchDiv(select_section.section.options[select_section.section.selectedIndex].value, 'set-');return true;"> \r
152         <input name="B4" value="Delete Section" type="button" onclick="deleteSection(select_section.section.selectedIndex)">\r
153         <input name="B5" value="Add Section" type="button" onclick="switchDiv('set-add', 'set-');return true;"></form>\r
155       <hr>Administration\r
156       <form method="post">\r
157         <p align="center"><input name="B1" id="B1" value="Save Changes" type="button" onclick="showData(document.config);return true;">\r
158         <input id="B2" name="B2" value="Soft Reset pyTivo" type="button" onclick="resetpyTivo();"></p>\r
160       </form>\r
162 <a href="javascript:alert('This feature is not available yet');">View Raw File</a> </div>\r
164       </td>\r
166       <td style="vertical-align: top;">\r
167       <div id="settings" style="width: 300px; overflow: scroll; height: 450px; position: relative;">\r
168       <form name="config" method="GET" action="TiVoConnect" onsubmit="fillBlank();showData(this);">\r
169       <input type="hidden" name="Command" value="UpdateSettings">\r
170       <input type="hidden" name="Container" value="$container">\r
171 <div id="set-server" style="width: 280px; text-align: center;position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
172         <b>Global Server Settings</b><br>\r
173         <hr style="width: 100%; height: 2px;"> \r
174         <table align="center">\r
175 #set $i = 0\r
176 #for $key in $server_known\r
177 #set $i += 1\r
178 #if $i%2\r
179 <tr style="background-color: rgb(250, 250, 250);">\r
180 #else\r
181 <tr>\r
182 #end if\r
183 <td>\r
184 #if $key in $server_data\r
185         $key :</td><td><input size="20" id="Server.$key" name="Server.$key" value="$server_data[$key]" onChange="saveNotify();" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
187 #else\r
188         $key :</td><td><input size="20" id="Server.$key" name="Server.$key" value="" onChange="saveNotify();" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
190 #end if\r
191 </td></tr>\r
192 #end for\r
193 <tr><td colspan="2" align="center" style="border-bottom: 1px solid rgb(153, 153, 153);">User Defined Settings:</td></tr>        \r
194 #set $i = 0\r
195 #for $key in $server_data \r
196         #if not $key in $server_known\r
197                 #set $i += 1\r
198                 #if $i%2\r
199                         <tr style="background-color: rgb(250, 250, 250);">\r
200                 #else\r
201                         <tr>\r
202                 #end if\r
203                 <td>         $key :</td><td>\r
204                 <input size="20" id="Server.$key" name="Server.$key" value="$server_data[$key]" onChange="saveNotify();" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
205                 </td></tr>\r
206         #end if \r
207 #end for \r
208         </table>\r
209         <div style="width: 280px; position: relative;">\r
210                 <div id="add-server-button" style="width: 280px; position: absolute; position: absolute; left: 0px; top: 0px;">\r
211                         <br>\r
212                         <center>\r
213                         <input type="button" value="Add Setting" onclick="switchDiv('add-server-field', 'add-server-');return true;">\r
214                         </center>\r
215                 </div>\r
216                 <div id="add-server-field" style="position: absolute; position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
217                         <table style="width: 265px;">\r
218                         <tr><td colspan="2" align="center" style="border-bottom: 1px solid rgb(153, 153, 153);">Add a Setting</td></tr>\r
219                         <tr><td>Setting Name:</td><td>Setting Value:</td></tr>\r
220                         <tr><td><input size="16" id="Server.new_settting" name="Server.new__setting" onChange="saveNotify();" type="text" value=""></td><td><input size="16" type="text" onChange="saveNotify();" id="Server.new_value"  name="Server.new__value" value=""></td></tr>\r
221                         </table>\r
222                 </div>\r
223         </div>\r
224 </div>\r
225 #set $section_count = 0\r
226 #set $section_map = ''\r
227 #for $name, $data in $shares_data\r
228         #set $section_count += 1\r
229         #set $section_number = 'section-' + str($section_count)\r
230         <input type="hidden" name="$name" id="$name" value="$section_number">\r
231         #set $section_map += $section_number + '|' + $name + ']'\r
232         <div id="set-$name" style="text-align: center;position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
233         [<input size="20" onChange="saveNotify();" id="$section_number" name="$section_number" value="$name">]<br>\r
234         <hr style="width: 100%; height: 2px;"><table align="center">\r
235         #set $i = 0\r
236         #for $key in $shares_known\r
237                 #set $i += 1\r
238                 #if $i%2\r
239                         <tr style="background-color: rgb(250, 250, 250);">\r
240                 #else\r
241                         <tr>\r
242                 #end if\r
243                 #if $key in $data\r
244                         <td>$key :</td><td><input onChange="saveNotify();" size="20" id="$section_number.$key" name="$section_number.$key" value="$data[$key]" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
245                         </td>\r
246                 #else\r
247                         <td>$key : </td><td><input onChange="saveNotify();" size="20" id="$section_number.$key" name="$section_number.$key" value="" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
248                         </td>\r
249                 #end if\r
250                 </tr>\r
251         #end for\r
253         <tr><td colspan="2" align="center" style="border-bottom: 1px solid rgb(153, 153, 153);">User Defined Settings:</td></tr> \r
254         #set $i = 0\r
255         #for $key in $data \r
256                 #if not $key in $shares_known\r
257                         #set $i += 1\r
258                         #if $i%2\r
259                                 <tr style="background-color: rgb(250, 250, 250);">\r
260                         #else\r
261                                 <tr>\r
262                         #end if\r
263                         <td> $key : </td><td>\r
264                         <input size="20" onChange="saveNotify();" id="$section_number.$key" name="$section_number.$key" value="$data[$key]" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
265                         </td></tr>\r
266                 #end if \r
267         #end for\r
268         </table>\r
269                 <div style="position: relative;">\r
270                         <div id="add-$name-button" style="width: 280px; position: absolute; position: absolute; left: 0px; top: 0px;">\r
271                                 <br>\r
272                                 <center>\r
273                                 <input type="button" value="Add Setting" onclick="switchDiv('add-$name-field', 'add-$name-');return true;">\r
274                                 </center>\r
275                         </div>\r
276                         <div id="add-$name-field" style="position: absolute; position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
277                                 <table style="width: 265px;">\r
278                                 <tr><td colspan="2" align="center" style="border-bottom: 1px solid rgb(153, 153, 153);">Add a Setting</td></tr>\r
279                                 <tr><td>Setting Name:</td><td>Setting Value:</td></tr>\r
280                                 <tr><td><input onChange="saveNotify();" size="16" id="$(section_number).new__setting" name="$(section_number).new__setting" type="text" value=""></td><td><input onChange="saveNotify();" size="16" type="text" id="$(section_number).new__value" name="$(section_number).new__value" value=""></td></tr>\r
281                                 </table>\r
282                         </div>\r
283                 </div>\r
284         </div>\r
285 #end for\r
287 #for $name, $data in $tivos_data\r
288         #set $section_count += 1\r
289         #set $section_number = 'section-' + str($section_count)\r
290         <input type="hidden" name="$name" id="$name" value="$section_number">\r
291         #set $section_map += $section_number + '|' + $name + ']'\r
292         <div id="set-$name" style="text-align: center;position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
293         [<input size="20" onChange="saveNotify();" id="$section_number" name="$section_number" value="$name">]<br>\r
294         <hr style="width: 100%; height: 2px;"><table align="center">\r
295         #set $i = 0\r
296         #for $key in $tivos_known\r
297                 #set $i += 1\r
298                 #if $i%2\r
299                         <tr style="background-color: rgb(250, 250, 250);">\r
300                 #else\r
301                         <tr>\r
302                 #end if\r
303                 #if $key in $data\r
304                         <td>$key :</td><td><input onChange="saveNotify();" size="20" id="$section_number.$key" name="$section_number.$key" value="$data[$key]" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
305                         </td>\r
306                 #else\r
307                         <td>$key :</td><td><input onChange="saveNotify();" size="20" id="$section_number.$key" name="$section_number.$key" value="" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
308                         </td>\r
309                 #end if\r
310                 </tr>\r
311         #end for\r
313         <tr><td colspan="2" align="center" style="border-bottom: 1px solid rgb(153, 153, 153);">User Defined Settings:</td></tr> \r
314         #set $i = 0\r
315         #for $key in $data \r
316                 #if not $key in $tivos_known\r
317                         #set $i += 1\r
318                         #if $i%2\r
319                                 <tr style="background-color: rgb(250, 250, 250);">\r
320                         #else\r
321                                 <tr>\r
322                         #end if\r
323                         <td> $key :</td><td> \r
324                         <input size="20" onChange="saveNotify();" id="$section_number.$key" name="$section_number.$key" value="$data[$key]" onfocus="switchDiv('help-$key', 'help-');return true;" type="text">\r
325                         </td></tr>\r
326                 #end if \r
327         #end for\r
328         </table>\r
329                 <div style="position: relative;">\r
330                         <div id="add-$name-button" style="width: 280px; position: absolute; position: absolute; left: 0px; top: 0px;">\r
331                                 <br>\r
332                                 <center>\r
333                                 <input type="button" value="Add Setting" onclick="switchDiv('add-$name-field', 'add-$name-');return true;">\r
334                                 </center>\r
335                         </div>\r
336                         <div id="add-$name-field" style="position: absolute; position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
337                                 <table style="width: 265px;">\r
338                                 <tr><td colspan="2" align="center" style="border-bottom: 1px solid rgb(153, 153, 153);">Add a Setting</td></tr>\r
339                                 <tr><td>Setting Name:</td><td>Setting Value:</td></tr>\r
340                                 <tr><td><input onChange="saveNotify();" size="16" id="$(section_number).new__setting" name="$(section_number).new__setting" type="text" value=""></td><td><input onChange="saveNotify();" size="16" type="text" id="$(section_number).new__value" name="$(section_number).new__value" value=""></td></tr>\r
341                                 </table>\r
342                         </div>\r
343                 </div>\r
344         </div>\r
345 #end for\r
346 <div id="set-add" style="text-align: center;position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
347         Add a New Section\r
348         <hr>\r
349         <table>\r
350         <tr>\r
351         <td> Section Name :</td><td> \r
352                 <input onChange="saveNotify();" type="text" size="20" name="new_Section" value="" onfocus="switchDiv('help-add', 'help-');return true;">\r
353         </td></tr></table>\r
354         The new section name will be added to the pyTivo.conf file when you click <b>Save Changes</b>.\r
355 </div>\r
356 <div id="set-delete" style="text-align: center;position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
357         Delete a Section\r
358         <hr>\r
359         <br>\r
360         The Section has been marked for deletion. However it will not be actually deleted until you click the <b>Save Changes</b> button.\r
361 </div>\r
362 <input type="hidden" id="Section_Map" name="Section_Map" value="$section_map">\r
363       </form>\r
365       </div>\r
367       </td>\r
369       <td style="border-left: 1px dotted rgb(153, 153, 153); vertical-align: top;">\r
370       <div id="sidesections" style="width: 400px; position: relative;"><!-- HELP SECTIONS -->\r
371       <div id="help-instructions" style="visibility: visible; width: 400px; overflow: scroll; height: 450px; position: absolute; left: 0px; top: 0px;">\r
372       <p align="center"><strong>Instructions</strong>\r
373       </p>\r
374       <b>To Edit a Share:</b><br>\r
375       Select the share in the left hand menu and click edit.<br><br>\r
376       \r
377       <b>To Delete a Share</b><br>\r
378       Select the share in the left hand menu and click delete.<br><br>\r
379       \r
380       <b>To Add a Share/Tivo/Section</b><br>\r
381       Click the add section button.  Then provide the name of the share or TiVo. You must save your \r
382       changes before you can edit settings in the new share.<br><br>\r
383       \r
384       <b>To Add a Setting</b><br>\r
385       Select you share first.  If the setting is a known setting simply add the value to the appropriate setting.\r
386       If the setting is not listed you can add a "User Defined Setting".  Simple click add setting and provide\r
387       the name and value of this new setting.<br><br>\r
388       \r
389       <b>To Delete a Setting</b><br>\r
390       Delete the value of the setting so that it is blank.  If this is a known share the name will remain after a save.\r
391       If the setting is a user defined setting the name will be deleted after the save.<br><br>\r
392       \r
393       <b>Save Settings</b><br>\r
394       Clicking Save Settings will write your changes to the pyTivo.conf file.  These settings will not have an effect on\r
395       your pyTivo server until it is Soft Reset or restarted.<br><br>\r
396       \r
397       <b>Soft Reset</b><br>\r
398       Soft Reset allows your new settings to take effect without manually restarting the TiVo.  The Soft Reset will cause\r
399       a re-read of the pyTivo.conf file so your changes must be saved to the file before the reset.  <b>Note:</b> The only\r
400       setting that will not take effect until a hard restart is the Port setting.  Changing the Port setting requires a full\r
401       restart.      \r
402       </div>\r
404         <div id="help-add" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
405       <p align="center"><strong>Add a New Section</strong> </p>\r
407       <p> Add the name of a new section.<br>\r
409       Remember if you want to add TiVo section remember it must start with _tivo_<br>\r
411       You must save your settings before the new section will be editable.<br>\r
412         </p>\r
414       </div>\r
416       <div id="help-port" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
417       <p align="center"><strong>port</strong> </p>\r
419       <p> <strong>Default Setting:</strong> None,\r
420 must be entered. Distributed conf file uses 9032<br>\r
422       <strong>Valid Entries:</strong> Valid port number<br>\r
424       <strong>Required:</strong> Yes, without a port\r
425 setting in the conf file pyTivo will not start.<br>\r
427       <strong>Skill:</strong> Basic<br>\r
429       <strong>Description:</strong> The port which pyTivo\r
430 uses to serve your files. Can be changed if it conflicts with another\r
431 program. It is reported on Ubuntu that this port is already used so you\r
432 may need to change it to something like port=9254.<br>\r
434       <strong>Example Settings:</strong> 9032 </p>\r
436       </div>\r
438       <div id="help-guid" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
439       <p align="center"><strong>guid</strong> </p>\r
441       <p> <strong>Default Setting:</strong> 123456<br>\r
443       <strong>Valid Entries:</strong> Any 6 digit number<br>\r
445       <strong>Required:</strong> Generally NO, will default\r
446 to '123456' if left blank. If you use more than one pyTivo server on\r
447 the same network a different random number is required here.<br>\r
449       <strong>Skill:</strong> Advanced<br>\r
451       <strong>Description:</strong> A unique identifier\r
452 used in the beacon to identify this server. If you have 2 or more\r
453 pyTivo servers on one network each server must use its own unique\r
454 identifier.<br>\r
456       <strong>Example Settings:</strong> Any 6 digit\r
457 number. </p>\r
459       </div>\r
461       <div id="help-ffmpeg" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
462       <p align="center"><strong>ffmpeg</strong>\r
463       </p>\r
465       <p> <strong>Default Setting:</strong> There is\r
466 none.<br>\r
468       <strong>Valid Entries:</strong> Operating system path<br>\r
470       <strong>Required:</strong> Yes! <br>\r
472       <strong>Skill:</strong> Basic<br>\r
474       <strong>Description:</strong> This is the full path\r
475 to your ffmpeg binary. For windows users ffmpeg is distributed with\r
476 pyTivo and is in the plugins/video folder<br>\r
478       <strong>Example Settings:</strong> <span class="underline">Linux</span> = /usr/bin/ffmpeg | <span class="underline">Windows</span> = c:\Program\r
479 Files\pyTivo\plugins\video\ffmpeg_mp2.exe </p>\r
481       </div>\r
483       <div id="help-beacon" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
484       <p align="center"><strong>beacon</strong>\r
485       </p>\r
487       <p> <strong>Default Setting:</strong>\r
488 255.255.255.255<br>\r
490       <strong>Valid Entries:</strong> A Subnet or Listen<br>\r
492       <strong>Required:</strong> No, defaults to\r
493 255.255.255.255<br>\r
495       <strong>Skill:</strong> Advanced<br>\r
497       <strong>Description:</strong> The subnet which the\r
498 beacon should broadcast on. Most people can leave this at the default\r
499 setting. If set to listen will accept incoming TCP requests.<br>\r
501       <strong>Example Settings:</strong> 255.255.255.255 </p>\r
503       </div>\r
505       <div id="help-hack83" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
506       <p align="center"><strong>hack83</strong>\r
507       </p>\r
509       <p> <strong>Default Setting:</strong> False<br>\r
511       <strong>Valid Entries:</strong> True/False<br>\r
513       <strong>Required:</strong> No<br>\r
515       <strong>Skill:</strong> Moderate<br>\r
517       <strong>Description:</strong> Available in the <a class="wiki" href="/wiki/SubFoldersBranch">SubFoldersBranch</a>.\r
518 Allows TiVos with software 8.3 and above to display subfolders as users\r
519 are accustomed too prior to the 8.3Software glitch. If you use this\r
520 then you don't need to use <a href="http://pytivo.armooo.net/wiki/ConfigurepyTivo#auto_subshares">auto_subshares</a>.\r
521       <strong>Warning:</strong> navigating folders too fast\r
522 with this setting enabled may cause <a class="wiki" href="/wiki/TiVo">TiVo</a> to reboot. <br>\r
524       <strong>Example Settings:</strong> True/False </p>\r
526       </div>\r
528       <div id="help-debug" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
529       <p align="center"><strong>debug</strong>\r
530       </p>\r
532       <p> <strong>Default Setting:</strong> False<br>\r
534       <strong>Valid Entries:</strong> True/False<br>\r
536       <strong>Required:</strong> No<br>\r
538       <strong>Skill:</strong> Advanced<br>\r
540       <strong>Description:</strong> Will create a file\r
541 named debug.txt in the base folder of pyTivo. This file will contain\r
542 debug information helpful in diagnosing problems. Generally only\r
543 necessary if you are having a problem and the information is requested\r
544 by support staff.<br>\r
546       <strong>Example Settings:</strong> True/False </p>\r
548       </div>\r
550       <div id="help-optres" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
551       <p align="center"><strong>optres</strong>\r
552       </p>\r
554       <p> <strong>Default Setting:</strong> False<br>\r
556       <strong>Valid Entries:</strong> True/False<br>\r
558       <strong>Required:</strong> No<br>\r
560       <strong>Skill:</strong> Moderate<br>\r
562       <strong>Description:</strong> Allows for the use of\r
563 the Optimal Resolution in transcoding. By setting optes = true pyTivo\r
564 will treat the <a href="http://pytivo.armooo.net/wiki/ConfigurepyTivo#height">height</a>\r
565 and <a href="http://pytivo.armooo.net/wiki/ConfigurepyTivo#width">width</a>\r
566 settings in the conf file as a maximum. If the video to be transcoded\r
567 has smaller dimensions that are closer to other acceptable TiVo\r
568 dimensions then pyTivo will use these dimensions. This allows for\r
569 faster transcoding and small files when the initial video is a lower\r
570 quality.<br>\r
572       <strong>Example Settings:</strong> True/False </p>\r
574       </div>\r
576       <div id="help-audio_br" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
577       <p align="center"><strong>audio_br</strong>\r
578       </p>\r
580       <p> <strong>Default Setting:</strong> 192K<br>\r
582       <strong>Valid Entries:</strong> Any valid Bit rate.\r
583 Up to 384K for SD TiVos. Up to 448K for HD TiVos.<br>\r
585       <strong>Required:</strong> No<br>\r
587       <strong>Skill:</strong> Advanced<br>\r
589       <strong>Description:</strong> This allows you to\r
590 choose the default server audio bit rate used in transcoding. The\r
591 default is likely fine for most users. Users with HD units and high\r
592 quality videos to transcode will want to use higher value. Higher\r
593 values may slow down transcoding and will increase the file size.\r
594 Increased file sizes take up more room on the <a class="wiki" href="/wiki/TiVo">TiVo</a> and take longer to transfer\r
595 over the network.<br>\r
597       <strong>Example Settings:</strong> 192K, 384K, 448K. </p>\r
599       </div>\r
601       <div id="help-max_audio_br" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
602       <p align="center"><strong>max_audio_br</strong>\r
603       </p>\r
605       <p> <strong>Default Setting:</strong> 448K<br>\r
607       <strong>Valid Entries:</strong> Any valid Bit rate. <br>\r
609       <strong>Required:</strong> No<br>\r
611       <strong>Skill:</strong> Advanced<br>\r
613       <strong>Description:</strong> This sets the maximum\r
614 audio bit rate that can be sent to the <a class="wiki" href="/wiki/TiVo">TiVo</a>. Files having a higher bit\r
615 rate will be transcoded to ensure <a class="wiki" href="/wiki/TiVo">TiVo</a> compatibilty. <br>\r
617       <strong>Example Settings:</strong> 384K, 448K. </p>\r
619       </div>\r
621       <div id="help-video_br" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
622       <p align="center"><strong>video_br</strong>\r
623       </p>\r
625       <p> <strong>Default Setting:</strong> 4096K\r
626 for SD <a class="wiki" href="/wiki/TiVo">TiVo</a>'s,\r
627 8192K for HD <a class="wiki" href="/wiki/TiVo">TiVo</a>'s<br>\r
629       <strong>Valid Entries:</strong> Any valid Bit rate.\r
630 1024K = 1Mi<br>\r
632       <strong>Required:</strong> No<br>\r
634       <strong>Skill:</strong> Advanced<br>\r
636       <strong>Description:</strong> This allows you to\r
637 choose the default server video bit rate used in transcoding. FFmpeg\r
638 does not strictly follow this bit rate, there is a certain level of\r
639 tolerance that is allowed. Also a low quality file will always have a\r
640 low bit rate. The default is likely fine for most users. Higher values\r
641 may slow down transcoding and will increase the file size. Increased\r
642 file sizes take up more room on the <a class="wiki" href="/wiki/TiVo">TiVo</a> and take longer to transfer\r
643 over the network.<br>\r
645       <strong>Example Settings:</strong> 4096K, 8Mi, 12Mi </p>\r
647       </div>\r
649       <div id="help-max_video_br" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
650       <p align="center"><strong>max_video_br</strong>\r
651       </p>\r
653       <p> <strong>Default Setting:</strong> 17408k<br>\r
655       <strong>Valid Entries:</strong> Any valid Bit rate.\r
656 1024K = 1Mi<br>\r
658       <strong>Required:</strong> No<br>\r
660       <strong>Skill:</strong> Advanced<br>\r
662       <strong>Description:</strong> This allows you to\r
663 choose the maximum bit rate and is more strict than the <a href="http://pytivo.armooo.net/wiki/ConfigurepyTivo#video_br">video_br</a>\r
664 setting above. However setting this can cause buffer overflows and can\r
665 cause issues with ffmpeg. In addition to setting the ffmpeg maxrate\r
666 option, this setting is used to determine if the video bitrate of the\r
667 source video file is too high for the <a class="wiki" href="/wiki/TiVo">TiVo</a>. Otherwise compatible\r
668 mpeg's with a video bitrate above this setting will be transcoded\r
669 rather than sent to the <a class="wiki" href="/wiki/TiVo">TiVo</a>\r
670 untouched. Raising this setting much higher than the default will likly\r
671 result in pixelation during playback. Recommended only for skilled\r
672 users. <strong>Note:</strong> there is a report that\r
673 ffmpeg throws an error with 17Mi but accepts 17408K just fine. <br>\r
675       <strong>Example Settings: 17408k</strong> </p>\r
677       </div>\r
679       <div id="help-width" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
680       <p align="center"><strong>width</strong>\r
681       </p>\r
683       <p> <strong>Default Setting:</strong> 544<br>\r
685       <strong>Valid Entries:</strong> Any valid pixel\r
686 dimension. Setting will be rounded to nearest acceptable <a class="wiki" href="/wiki/TiVo">TiVo</a>\r
687 dimension<br>\r
689       <strong>Required:</strong> No<br>\r
691       <strong>Skill:</strong> Moderate<br>\r
693       <strong>Description:</strong> Allows you to choose\r
694 the output dimension of the transcoded videos. SD units are limited to\r
695 544 and below. Likely HD users will want to choose a higher value.\r
696 Higher values may slow down transcoding and will increase the file\r
697 size. Increased file sizes take up more room on the TiVo and take\r
698 longer to transfer over the network.<br>\r
700       <strong>Example Settings:</strong> 1920, 1440, 1280,\r
701 720, 704, 544, 480, 352. </p>\r
703       </div>\r
705       <div id="help-height" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
706       <p align="center"><strong>height</strong>\r
707       </p>\r
709       <p> <strong>Default Setting:</strong> 480<br>\r
711       <strong>Valid Entries:</strong> Any valid pixel\r
712 dimension. Setting will be rounded to nearest acceptable <a class="wiki" href="/wiki/TiVo">TiVo</a>\r
713 dimension<br>\r
715       <strong>Required:</strong> No<br>\r
717       <strong>Skill:</strong> Moderate<br>\r
719       <strong>Description:</strong> Allows you to choose\r
720 the output dimension of the transcoded videos. SD units are limited to\r
721 480 and below. Likely HD users will want to choose a higher value.\r
722 Higher values may slow down transcoding and will increase the file\r
723 size. Increased file sizes take up more room on the TiVo and take\r
724 longer to transfer over the network.<br>\r
726       <strong>Example Settings:</strong> 1080, 720, 480 </p>\r
728       </div>\r
730       <div id="help-ffmpeg_prams" style="position: absolute; overflow: scroll; left: 0px; top: 0px; visibility: hidden;">\r
731       <p align="center"><strong>ffmpeg_prams</strong>\r
732       </p>\r
734       <p> <strong>Default Setting:</strong> -vcodec\r
735 mpeg2video -r 29.97 -b %(video_br)s -maxrate %(max_video_br)s -bufsize\r
736 %(buff_size)s %(aspect_ratio)s -comment pyTivo.py -ac 2 -ab\r
737 %(audio_br)s -ar 44100 -f vob -<br>\r
739       <strong>Valid Entries:</strong> A valid ffmpeg command<br>\r
741       <strong>Required:</strong> No<br>\r
743       <strong>Skill:</strong> Very Advanced<br>\r
745       <strong>Description:</strong> This allows you to\r
746 control the parameters passed to ffmpeg. Most users will be just fine\r
747 with the default setting. Some HD users are experimenting with the\r
748 following line:<br>\r
750 -vcodec mpeg2video -maxrate %(max_video_br)s -qscale 1.2 -bufsize\r
751 %(buff_size)s -comment pyTivo.py -acodec ac3 -ab %(audio_br)s -ar 48000\r
752 -f vob -<br>\r
754 The major difference is that this does not alter the dimensions of the\r
755 video. The native height and width setting of the video used to\r
756 transcode the video. This will only work for HD and S3 units. So far\r
757 there has not been any report of dimensions which the HD units will not\r
758 accept. Additionally this line increases the audio frequency setting to\r
759 48000 too. <strong>Example Settings:</strong> See Above\r
760 and the forum. </p>\r
762       </div>\r
764       <div id="help-bufsize" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
765       <p align="center"><strong>bufsize</strong>\r
766       </p>\r
768       <p> <strong>Default Setting:</strong> 1024k<br>\r
770       <strong>Valid Entries:</strong> Any valid byte size<br>\r
772       <strong>Required:</strong> No<br>\r
774       <strong>Skill:</strong> Very Advanced<br>\r
776       <strong>Description:</strong> Allows you to set the\r
777 buffer size used by ffmpeg. I don't know much about this setting, but\r
778 from what I can tell it is rather touchy and should only be edited by\r
779 advanced users.<br>\r
781       <strong>Example Settings:</strong> 1024k<br>\r
783       </p>\r
785       </div>\r
787       <div id="help-type" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
788       <p align="center"><strong>type</strong> </p>\r
790       <p> <strong>Default Setting:</strong> None<br>\r
792       <strong>Valid Entries:</strong> Video, Music, or any\r
793 other valid plugin name.<br>\r
795       <strong>Required:</strong> Yes<br>\r
797       <strong>Skill:</strong> Basic<br>\r
799       <strong>Description:</strong> Sets the type of share\r
800 that this will be. This must be set to something otherwise pyTivo will\r
801 not start.<br>\r
803       <strong>Example Settings:</strong> Video or Music </p>\r
805       </div>\r
807       <div id="help-path" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
808       <p align="center"><strong>path</strong> </p>\r
810       <p> <strong>Default Setting:</strong> None<br>\r
812       <strong>Valid Entries:</strong> Any operating system\r
813 path<br>\r
815       <strong>Required:</strong> Yes<br>\r
817       <strong>Skill:</strong> Basic<br>\r
819       <strong>Description:</strong> Sets the base path to\r
820 your media content. While pyTivo will start with an invalid path your\r
821 shares will not work at all.<br>\r
823       <strong>Example Settings:</strong> <span class="underline">Windows</span> = C:\videos | <span class="underline">Linux</span> = /home/user/media </p>\r
825       </div>\r
827       <div id="help-auto_subshares" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
828       <p align="center"><strong>auto_subshares</strong>\r
829       </p>\r
831       <p> <strong>Default Setting:</strong> false<br>\r
833       <strong>Valid Entries:</strong> True/False<br>\r
835       <strong>Required:</strong> No<br>\r
837       <strong>Skill:</strong> Moderate<br>\r
839       <strong>Description:</strong> Subfolders of the share\r
840 paths you define will be seen by pyTivo and displayed as subfolders in\r
841 the Now Playing List. This is an alternative to the <a href="http://pytivo.armooo.net/wiki/ConfigurepyTivo#hack83">hack83</a>\r
842 setting which enables the <a class="wiki" href="/wiki/SubFoldersBranch">SubFoldersBranch</a><br>\r
844       <strong>Example Settings:</strong> True/False </p>\r
846       </div>\r
848       <div id="help-precache" style="position: absolute; overflow: scroll; left: 0px; top: 0px; visibility: hidden;">\r
849       <p align="center"><strong>precache</strong>\r
850       </p>\r
852       <p> <strong>Default Setting:</strong> false<br>\r
854       <strong>Valid Entries:</strong> True/False<br>\r
856       <strong>Required:</strong> No<br>\r
858       <strong>Skill:</strong> Moderate<br>\r
860       <strong>Description:</strong> In order to verify that\r
861 the video files present on your computer were compatible with ffmpeg in\r
862 older versions pyTivo would query ffmpeg for each file. While this\r
863 information was cached it still caused a delay in the initial loading\r
864 of a list of files. This precache setting forced pyTivo to inspect each\r
865 video prior to starting the pyTivo server. However, this had two\r
866 drawbacks. 1. It took time as much as two minutes before pyTivo was\r
867 ready to accept requests. 2. It did not update the cache if new files\r
868 were added while the pyTivo server was running. <br>\r
870 In the more recent releases, anything after Feb 16, 2008, pyTivo no\r
871 longer needs to query ffmpeg when creating a file list. Instead pyTivo\r
872 has a list of accepted video format extensions. If the file extension\r
873 falls within this list it is displayed on the TiVo. This achieves the\r
874 same speed increase as the precache method without the delay in loading\r
875 the pyTivo server. <br>\r
877 There are still two drawbacks to this method. 1. The video file must\r
878 have an extension that is in the list. There is a possibility that a\r
879 new video file extension could come out before pyTivo is updated. 2.\r
880 Incomplete or video files with errors will still appear in the TiVo\r
881 listing if they have the correct extension, even though they are not\r
882 valid files. Both of these concerns are minimal. 1. Very few new\r
883 formats of video files come out very often. And all extensions are\r
884 stored in the video.ext file which is easily edited. 2. When viewing\r
885 the file details before transferring the pyTivo server queries ffmpeg\r
886 to make sure it is valid. If the file is not valid it will show up as a\r
887 copyrighted file and transferring it will be prevented by TiVo. <br>\r
889 It is recommended that you leave precaching turned off as it is no\r
890 longer needed.<br>\r
892       <strong>Example Settings:</strong> True/False </p>\r
894       </div>\r
896       <div id="help-aspect169" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
897       <p align="center"><strong>aspect169</strong>\r
898       </p>\r
900       <p> <strong>Default Setting:</strong> True<br>\r
902       <strong>Valid Entries:</strong> True/False<br>\r
904       <strong>Required:</strong> No<br>\r
906       <strong>Skill:</strong> Moderate<br>\r
908       <strong>Description:</strong> Most TiVos, even S2,\r
909 can handle 16:9 videos perfectly. Some S2s are known not to handle 16:9\r
910 and will default to false in this setting. If you are experiencing\r
911 major distortion you can try setting this to false. Likely mos users\r
912 will not have to mess with this.<br>\r
914       <strong>Example Settings:</strong> True/False </p>\r
916       </div>\r
918       <div id="help-shares" style="position: absolute; left: 0px; top: 0px; visibility: hidden;">\r
919       <p align="center"><strong>shares</strong>\r
920       </p>\r
922       <p> <strong>Default Setting:</strong> Blank,\r
923 which is equivalent to allow all shares on this TiVo.<br>\r
925       <strong>Valid Entries:</strong> The name of any share\r
926 in your pyTivo.conf file. A comma separated list.<br>\r
928       <strong>Required:</strong> No<br>\r
930       <strong>Skill:</strong> Easy<br>\r
932       <strong>Description:</strong> Only the shares listed\r
933 in this setting will be visible on this TiVo. Will ignore invalid\r
934 shares. If no valid shares are listed or the setting does not exist,\r
935 all shares will be visible on this TiVo.<br>\r
937       <strong>Example Settings:</strong> Movies, Kids Stuff\r
938       </p>\r
940       </div>\r
941 <!-- END HELP SECTIONS --> </div>\r
943       </td>\r
945     </tr>\r
947   </tbody>\r
948 </table>\r
949 </center>\r
950 </body>\r
951 </html>\r