Extension talk:VideoSectionLink
Contents
Dev notes
Still reading about parser functions.
I've just added a couple of traces and the browser prints those fine. In my wikitext mainpage locally I have
{{videosectionlink:broom}}
and that prints the traces and does nothing.
If instead I put into the article
{{#videosectionlink:broom}}
i get the traces then
Fatal error: Call to a member function getPrefixedDBkey() on a non-object in C:\www\wiki4\includes\parser\Preprocessor_DOM.php on line 994
--Jack 12:44, 9 November 2008 (NZDT)
- I'd recommend going back to the initial template again and deleting the tag out again bit by bit, you must have removed something you shouldn't have because the extension is fully functional before being modified from the template. Also, you should use camelCase for all functions, the current code has the function magicVideosectionlink which should be magicVideoSectionLink. --nad 13:04, 9 November 2008 (NZDT)
- Also the braces syntax for categorisation and php syntax need to be inside the php comment section otherwise they make the code unexecutable --nad 13:07, 9 November 2008 (NZDT)
Yo thats got started pretty quick :-) but best to to set the tag name to something shorter like videosection --nad 21:26, 31 October 2008 (NZDT)
- What I want to do now is to just list all the sub-parts of this extension so I expect they are all contained in the comments below, if there is any missed I expect I will find out soon enough --Jack 21:40, 31 October 2008 (NZDT)
- may as well dump the tag stuff since we only need the parser-function for this
--nad 22:03, 31 October 2008 (NZDT)
I note that the add tab in code snippets mentions adding a processing function to the UnknownAction hook but I don't see one --Jack 15:12, 3 November 2008 (NZDT)
- Adding tabs is a different thing again, many tabs will not be an action - like the email article tab which goes to a special page. You don't really need any example, just add a callback to $wgHooks for UnknownAction. You can see from the MW docs on the hook that it has two parameters, the action being requested and the article, so just check if the action is your one, and if so, do your print_r or whatever. --nad 16:13, 3 November 2008 (NZDT)
Parser function
We need a parser function so that links can be made using syntax such as the following:
{{#videosection:http://foo.bar/baz.avi|01:25:31|01:25:50}}
This would generate a link which when clicked downloads the specified segment of content from the specified video resource. Of course such a resource doesn't exist though, so the link is actually back to the wiki with action=videosection in the query string which will prompt the extension to generate the video section and return it to the client. The other parameters supplied in the parser-function should also be added to the query-string of the link.
Later we may add more parameters such as format and maybe embed - although embedding may be able to be achieved by using the existing video embedding extension with a VideoSectionLink URL as its source parameter.
Unknown action hook
The UnknownAction hook is used for executing code in response to new actions specified in the query string. An example of it's use is the PdfBook extension, it defines a callback method in its class called onUnknownAction and registers it with the hook in the classes' constructor.
This hook must construct an ffmpeg shell command from the query-string parameters and execute it, then pass the resulting binary or file back to the client. To pass the video data back to the client in such a way as to make it bring up the download dialog, use the following snippet. <php>
- First disable MediaWiki's output and set headers so the client knows this is a video for download
$wgOut->disable(); header("Content-Type: video/mpeg"); header("Content-Disposition: attachment; filename=\"$name.mpeg\"");
- Use this if sending string content to client
print $content;
- or use this if sending content of a file back to the client
readfile($file); </php>
- see php.net/readfile
Caching (later)
Whenever a new clip is generated, it should be stored in the wiki's tmp directory (which is where it also stores cached math equations and resized images. Here's a snippet of code taken from Extension:Flashlets.php which is doing a similar task. It's creating a binary file of compiled actionscript which has a filename that's unique to the actionscript so that different actionscript produces a different filename. VideoSectionLink would create cache files a similar way except that the unique names should be generated from the shell command string instead, and the command being executed to generate the content is ffmpeg or similar instead of the mtasc compiler. <php>
- create swf filename unique to the actionscript content and parameters
$swf = md5("$actionscript$ver$width$height$fps"); $file = "$wgFlashletsDirectory/$swf"; $path = "$wgFlashletsPath/$swf.swf";
- Compile the SWF if it doesn't already exist
if (!file_exists("$file.swf")) {
# Write the actionscript to a file for MTASC to compile from if ($handle = fopen("$file.as", 'w+')) { fwrite($handle,$actionscript); fclose($handle); $cont = $this->container; $sh = "$wgFlashletsMTASC -cp $wgFlashletsCP -swf $cont -out $file.swf -main -version $ver -header $width:$height:$fps $file.as 2>&1"; $html = shell_exec($sh); unlink("$file.as"); } else $html = "Could not open '$file.as' for writing!"; } </php>
Special page (later)
Later it could be good to have a special page which allows simple navigation of the video content to determine the exact start and finish times, and also as a means of creating a repository of video slices which could be then referred to by other sites that don't have the ability to refer to sections of video content.
ffmpeg
- Wikipedia:ffmpeg
- ffmpeg documentation
- joining video segments - not necessary for this, but useful anyway
- How to split video files - this is exactly what we need :-)
Use Case
- Article Writer to be able to display a pre-selected part of a nominated video by writing a simple magic word such as:
{{#videosection:http://foo.bar/baz.avi|01:25:31|01:25:50}}
- Viewer to be able to click on an apparently normal link. Perhaps to view it in a window on the same page, or as a Javascript popup.
- Video can be hosted elsewhere on the Web or on the local system.
- Range of video formats to be as complete as possible.
Code Needed
- Create skeleton extension from template - done
- Set up videosection as an action
- Construct query string leading back to to the wiki, adding other parameters supplied in the parser-function i.e. start and finish times
- Define a callback method onUnknownAction
- Register the callback method with the hook in the constructor
- Hook constructs an ffmpeg shell command from the query-string parameters and executes it