Difference between revisions of "Extension:VideoSectionLink"

From Organic Design wiki
($this)
(Change title data)
 
(35 intermediate revisions by 2 users not shown)
Line 1: Line 1:
<?php{{Category:Extensions|VideoSectionLink}}{{php}}{{Category:Extensions created with Template:Extension}}
+
<?php
/**
+
/**{{Category:Extensions|VideoSectionLink}}{{php}}{{Category:Extensions created with Template:Extension}}
  * VideoSectionLink extension - An extension to enable users to link to defined sections of video. Made with [http://www.organicdesign.co.nz/Template:Extension Template:Extension]
+
  * VideoSectionLink extension - An extension to enable users to link to or embed user-defined sections of video. Made with [http://www.organicdesign.co.nz/Template:Extension Template:Extension]
 
  *
 
  *
 
  * See http://www.mediawiki.org/wiki/Extension:VideoSectionLink for installation and usage details
 
  * See http://www.mediawiki.org/wiki/Extension:VideoSectionLink for installation and usage details
Line 7: Line 7:
 
  * @package MediaWiki
 
  * @package MediaWiki
 
  * @subpackage Extensions
 
  * @subpackage Extensions
  * @author [http://www.mediawiki.org/wiki/User:Jack User:Jack]
+
  * @author [http://www.mediawiki.org/wiki/User:Jacknz User:Jacknz]
  * @copyright © 2008 [http://www.mediawiki.org/wiki/User:Jack User:Jack]
+
  * @copyright © 2008 [http://www.flashkiwi.com/ Jack Henderson]
 
  * @licence GNU General Public Licence 2.0 or later
 
  * @licence GNU General Public Licence 2.0 or later
 
  */
 
  */
 
if (!defined('MEDIAWIKI')) die('Not an entry point.');
 
if (!defined('MEDIAWIKI')) die('Not an entry point.');
+
 
 
define('VIDEOSECTIONLINK_VERSION', '0.0.1, 2008-10-31');
 
define('VIDEOSECTIONLINK_VERSION', '0.0.1, 2008-10-31');
+
 
$egVideoSectionLinkMagic             = 'videosection';
+
$egVideoSectionLinkMagic       = 'videosection';
 
$wgExtensionFunctions[]        = 'efSetupVideoSectionLink';
 
$wgExtensionFunctions[]        = 'efSetupVideoSectionLink';
 
$wgHooks['LanguageGetMagic'][] = 'efVideoSectionLinkLanguageGetMagic';
 
$wgHooks['LanguageGetMagic'][] = 'efVideoSectionLinkLanguageGetMagic';
Line 22: Line 22:
 
$wgExtensionCredits['parserhook'][] = array(
 
$wgExtensionCredits['parserhook'][] = array(
 
'name'        => 'VideoSectionLink',
 
'name'        => 'VideoSectionLink',
'author'      => '[http://www.mediawiki.org/wiki/User:Jack User:Jack]',
+
'author'      => '[http://www.mediawiki.org/wiki/User:Jacknz User:Jacknz]',
'description' => 'An extension to enable users to link to defined sections of video. Made with [http://www.organicdesign.co.nz/Template:Extension Template:Extension]',
+
'description' => 'An extension to enable users to link to or embed user-defined sections of video. Made with [http://www.organicdesign.co.nz/Template:Extension Template:Extension]',
 
'url'        => 'http://www.organicdesign.co.nz/Extension:VideoSectionLink',
 
'url'        => 'http://www.organicdesign.co.nz/Extension:VideoSectionLink',
 
'version'    => VIDEOSECTIONLINK_VERSION
 
'version'    => VIDEOSECTIONLINK_VERSION
);
+
);
+
 
 
class VideoSectionLink {
 
class VideoSectionLink {
+
 
 
/**
 
/**
 
* Constructor
 
* Constructor
Line 35: Line 35:
 
function __construct() {
 
function __construct() {
 
global $wgHooks, $wgParser, $egVideoSectionLinkMagic;
 
global $wgHooks, $wgParser, $egVideoSectionLinkMagic;
+
 
 
# Add the parser-function
 
# Add the parser-function
$wgParser->setFunctionHook($egVideoSectionLinkMagic, $this);
+
$wgParser->setFunctionHook($egVideoSectionLinkMagic, array($this,'magicVideosectionlink'));
 +
 
 
#Add the Unknownaction hook
 
#Add the Unknownaction hook
$wgHooks['UnknownAction'][] = 'onUnknownAction';
+
$wgHooks['UnknownAction'][] = $this;
#need to set up the new action here
 
 
}
 
}
+
 
 
/**
 
/**
 
* Expand the videosection-magic
 
* Expand the videosection-magic
 
*/
 
*/
function magicVideosectionlink(&$parser, $param1 = '', $param2 = '',$param3 = '') {
+
function magicVideosectionlink (&$parser, $url = '', $start = '', $duration = '', $ext = '', $width = '', $height = '', $wtext = 'Click to download video') {
 +
global $egVideoSectionLinkMagic, $wgScript, $wgUploadPath, $wgUploadDirectory, $wgServer;
 +
if ($ext == '' || $ext != "embed") {
 +
$text = "<a href='$wgServer$wgScript?action=videosection&url=" . urlencode($url) . "&start=$start&duration=$duration&ext=$ext'>$wtext</a>";
 +
 
 +
# Return result with available parser flags
 +
 +
return array(
 +
$text,
 +
'found'  => true,
 +
'nowiki'  => false,
 +
'noparse' => true,
 +
'noargs'  => false,
 +
'isHTML'  => true
 +
);
 +
}
 +
else {
 +
# Get components of url, hash the first part
 +
$dest = preg_replace('%(.+?\.)(\w+$)%', '$1', $url);
 +
$ext = "flv";
 +
$movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;
 +
 +
# Execute the ffmpeg command
 +
if (!file_exists($movieOut)) {
 +
$movieStr = "ffmpeg -i $url -ss $start -t $duration -ar 22050 $wgUploadDirectory/$movieOut";
 +
$success = shell_exec($movieStr);
 +
}
 +
 +
# Create the embed string to return
 +
if ($width == '') $width = "320";
 +
if ($height == '') $height = "240";
 +
$embedText =
 +
"<html><object id=\"FlowPlayer\" width=\"$width\" height=\"$height\" data=\"$wgServer$wgUploadPath/FlowPlayer.swf\" type=\"application/x-shockwave-flash\">"
 +
. "<param name=\"allowScriptAccess\" value=\"sameDomain\"/>"
 +
. "<param name=\"movie\" value=\"$wgServer$wgUploadPath/FlowPlayer.swf\"/>"
 +
. "<param name=\"quality\" value=\"high\"/>"
 +
. "<param name=\"scale\" value=\"noScale\"/>"
 +
. "<param name=\"wmode\" value=\"transparent\"/>"
 +
. "<param name=\"flashvars\" value=\"videoFile=$wgUploadPath/$movieOut&baseURL=$wgServer\"/>"
 +
. "</object></html>";
 +
 +
return array(
 +
$embedText,
 +
'noparse' => true,
 +
'isHTML'  => true
 +
);
 +
}
 +
}
 +
 
 +
/**
 +
* Callback method executes a shell command returning the section of the movie requested
 +
*/
 +
function onUnknownAction ($action, $article) {
 +
global $wgOut, $action, $article, $wgRequest, $wgUploadDirectory;
 +
 
 +
# Get the parameters from the title
 +
# $url is the url of the originating file and can be local or Internet
 +
# $start is the start time expressed in HH:MM:SS
 +
# $duration is the desired duration of clip expressed in HH:MM:SS
 +
# $ext is the desired extension, can be mpg, avi, flv, or embed, which is an flv returned as embed code.
 +
 +
$url = $wgRequest->getText('url');
 +
$start = $wgRequest->getText('start');
 +
$duration = $wgRequest->getText('duration');
 +
$ext = $wgRequest->getText('ext');
 +
 
 +
 +
# Get components of url, hash the first part
 +
$dest = preg_replace('%(.+?\.)(\w+$)%', '$1', $url);
 +
 +
# Identify the extension for naming the decoded file
 +
if ($ext == "mpg" || $ext == "avi" || $ext == "flv") {
 +
  $movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;
 +
}
 +
else {
 +
$ext = preg_replace('%(.+?\.)(\w+$)%', '$2', $url);
 +
if ($ext == "mpg" || $ext == "avi" || $ext == "flv") {
 +
$movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;
 +
}
 +
else {
 +
$ext = "mpg";
 +
$movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;
 +
}
 +
}
 +
 
 +
# Execute the ffmpeg command
 +
if (!file_exists($movieOut)) {
 +
if ($ext == "flv") {
 +
$movieStr = "ffmpeg -i $url -ss $start -t $duration -ar 22050 $wgUploadDirectory/$movieOut";
 +
}
 +
else {
 +
$movieStr = "ffmpeg -i $url -ss $start -t $duration $wgUploadDirectory/$movieOut";
 +
}
 +
$success = shell_exec($movieStr);
 +
}
 +
 +
# Set headers to video
 +
$wgOut->disable();
 +
header("Content-Type: video/mpeg");
 +
$wgHfile = "Content-Disposition: attachment; filename=\"$wgUploadDirectory/$movieOut\"";
 +
header($wgHfile);
  
global $egVideoSectionLinkMagic;
+
# Return the file as binary back to the client
 
+
readfile("$wgUploadDirectory/$movieOut");
  $text="{{SERVER}}/" . $param1 . "?action=videosection&param2=" . $param2 . "&param3=" .$param3;
+
 
# Return result with available parser flags
+
return true;
return array(
 
$text,
 
'found'  => true,
 
'nowiki'  => false,
 
'noparse' => false,
 
'noargs'  => false,
 
'isHTML'  => false
 
);
 
 
 
}
 
}
+
 
 
/**
 
/**
 
* Needed in some versions to prevent Special:Version from breaking
 
* Needed in some versions to prevent Special:Version from breaking
Line 68: Line 159:
 
function __toString() { return __CLASS__; }
 
function __toString() { return __CLASS__; }
 
  }
 
  }
+
 
 
/**
 
/**
 
  * Called from $wgExtensionFunctions array when initialising extensions
 
  * Called from $wgExtensionFunctions array when initialising extensions
Line 75: Line 166:
 
global $egVideoSectionLink;
 
global $egVideoSectionLink;
 
$egVideoSectionLink = new VideoSectionLink();
 
$egVideoSectionLink = new VideoSectionLink();
+
 
 
}
 
}
+
 
 
/**
 
/**
 
  * Needed in MediaWiki >1.8.0 for magic word hooks to work properly
 
  * Needed in MediaWiki >1.8.0 for magic word hooks to work properly
 
  */
 
  */
 
 
function efVideoSectionLinkLanguageGetMagic(&$magicWords, $langCode = 0) {
 
function efVideoSectionLinkLanguageGetMagic(&$magicWords, $langCode = 0) {
 
global $egVideoSectionLinkMagic;
 
global $egVideoSectionLinkMagic;
 
$magicWords[$egVideoSectionLinkMagic] = array($langCode, $egVideoSectionLinkMagic);
 
$magicWords[$egVideoSectionLinkMagic] = array($langCode, $egVideoSectionLinkMagic);
return true;
 
}
 
 
function onUnknownAction($action, $article) {
 
 
#here we test for the action=videosection and extract the parameters from the query string
 
   
 
    #param1 = Extract the title name here
 
   
 
    #The following is not going to work because I'm not doing anything with out1.mpg and I'm not sure if I can assign all that to $movie anyway
 
$movie = `ffmpeg -i $param1 -ss $param2 -t $param3 out1.mpg`;
 
 
$wgOut->disable();
 
header("Content-Type: video/mpeg");
 
header("Content-Disposition: attachment; filename=\"$movie.mpeg\"");
 
#And I suppose I'd better find a way to make sure the readfile does something on the page.
 
readfile($movie);
 
 
return true;
 
return true;
 
}
 
}

Latest revision as of 04:34, 28 November 2008

<?php /**

Info.svg These are the MediaWiki extensions we're using and/or developing. Please refer to the information on the mediawiki.org wiki for installation and usage details. Extensions here which have no corresponding mediawiki article are either not ready for use or have been superseded. You can also browse our extension code in our local Subversion repository or our GitHub mirror.

Template:PhpCategory:Extensions created with Template:Extension

* VideoSectionLink extension - An extension to enable users to link to or embed user-defined sections of video. Made with Template:Extension
*
* See http://www.mediawiki.org/wiki/Extension:VideoSectionLink for installation and usage details
*
* @package MediaWiki
* @subpackage Extensions
* @author User:Jacknz
* @copyright © 2008 Jack Henderson
* @licence GNU General Public Licence 2.0 or later
*/

if (!defined('MEDIAWIKI')) die('Not an entry point.');

define('VIDEOSECTIONLINK_VERSION', '0.0.1, 2008-10-31');

$egVideoSectionLinkMagic = 'videosection'; $wgExtensionFunctions[] = 'efSetupVideoSectionLink'; $wgHooks['LanguageGetMagic'][] = 'efVideoSectionLinkLanguageGetMagic';


$wgExtensionCredits['parserhook'][] = array( 'name' => 'VideoSectionLink', 'author' => 'User:Jacknz', 'description' => 'An extension to enable users to link to or embed user-defined sections of video. Made with Template:Extension', 'url' => 'http://www.organicdesign.co.nz/Extension:VideoSectionLink', 'version' => VIDEOSECTIONLINK_VERSION );

class VideoSectionLink {

/** * Constructor */ function __construct() { global $wgHooks, $wgParser, $egVideoSectionLinkMagic;

# Add the parser-function $wgParser->setFunctionHook($egVideoSectionLinkMagic, array($this,'magicVideosectionlink'));

#Add the Unknownaction hook $wgHooks['UnknownAction'][] = $this; }

/** * Expand the videosection-magic */ function magicVideosectionlink (&$parser, $url = , $start = , $duration = , $ext = , $width = , $height = , $wtext = 'Click to download video') { global $egVideoSectionLinkMagic, $wgScript, $wgUploadPath, $wgUploadDirectory, $wgServer; if ($ext == || $ext != "embed") { $text = "<a href='$wgServer$wgScript?action=videosection&url=" . urlencode($url) . "&start=$start&duration=$duration&ext=$ext'>$wtext</a>";

# Return result with available parser flags

return array( $text, 'found' => true, 'nowiki' => false, 'noparse' => true, 'noargs' => false, 'isHTML' => true ); } else { # Get components of url, hash the first part $dest = preg_replace('%(.+?\.)(\w+$)%', '$1', $url); $ext = "flv"; $movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;

# Execute the ffmpeg command if (!file_exists($movieOut)) { $movieStr = "ffmpeg -i $url -ss $start -t $duration -ar 22050 $wgUploadDirectory/$movieOut"; $success = shell_exec($movieStr); }

# Create the embed string to return if ($width == ) $width = "320"; if ($height == ) $height = "240"; $embedText = "" . "" . "" . "" . "" . "" . "" . "";

return array( $embedText, 'noparse' => true, 'isHTML' => true ); } }

/** * Callback method executes a shell command returning the section of the movie requested */ function onUnknownAction ($action, $article) { global $wgOut, $action, $article, $wgRequest, $wgUploadDirectory;

# Get the parameters from the title # $url is the url of the originating file and can be local or Internet # $start is the start time expressed in HH:MM:SS

		# $duration is the desired duration of clip expressed in HH:MM:SS
		# $ext is the desired extension, can be mpg, avi, flv, or embed, which is an flv returned as embed code.
		

$url = $wgRequest->getText('url'); $start = $wgRequest->getText('start');

		$duration = $wgRequest->getText('duration');
		$ext = $wgRequest->getText('ext');


		# Get components of url, hash the first part 		
		$dest = preg_replace('%(.+?\.)(\w+$)%', '$1', $url);
		
		# Identify the extension for naming the decoded file
		if ($ext == "mpg" || $ext == "avi" || $ext == "flv") {
 			$movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;
		}
		else {
			$ext = preg_replace('%(.+?\.)(\w+$)%', '$2', $url);
			if ($ext == "mpg" || $ext == "avi" || $ext == "flv") {
				$movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext;

} else { $ext = "mpg"; $movieOut = md5($dest.$start.$duration.$ext.$width.$height) . "." . $ext; } }

		# Execute the ffmpeg command
		if (!file_exists($movieOut)) {
			if ($ext == "flv") {

$movieStr = "ffmpeg -i $url -ss $start -t $duration -ar 22050 $wgUploadDirectory/$movieOut"; } else { $movieStr = "ffmpeg -i $url -ss $start -t $duration $wgUploadDirectory/$movieOut"; }

			$success = shell_exec($movieStr);

}

# Set headers to video $wgOut->disable(); header("Content-Type: video/mpeg"); $wgHfile = "Content-Disposition: attachment; filename=\"$wgUploadDirectory/$movieOut\""; header($wgHfile);

# Return the file as binary back to the client readfile("$wgUploadDirectory/$movieOut");

return true; }

/** * Needed in some versions to prevent Special:Version from breaking */ function __toString() { return __CLASS__; }

}

/**

* Called from $wgExtensionFunctions array when initialising extensions
*/

function efSetupVideoSectionLink() { global $egVideoSectionLink; $egVideoSectionLink = new VideoSectionLink();

}

/**

* Needed in MediaWiki >1.8.0 for magic word hooks to work properly
*/

function efVideoSectionLinkLanguageGetMagic(&$magicWords, $langCode = 0) { global $egVideoSectionLinkMagic; $magicWords[$egVideoSectionLinkMagic] = array($langCode, $egVideoSectionLinkMagic); return true; }