canopy/www/doc/server/commandPreprocessor.html

1255 lines
18 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>JSDoc: Class: commandPreprocessor</title>
<script src="scripts/prettify/prettify.js"> </script>
<script src="scripts/prettify/lang-css.js"> </script>
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
</head>
<body>
<div id="main">
<h1 class="page-title">Class: commandPreprocessor</h1>
<section>
<header>
<h2><span class="attribs"><span class="type-signature"></span></span>commandPreprocessor<span class="signature">(server, chatHandler)</span><span class="type-signature"></span></h2>
<div class="class-description">Class containing global server-side chat/command pre-processing logic</div>
</header>
<article>
<div class="container-overview">
<h2>Constructor</h2>
<h4 class="name" id="commandPreprocessor"><span class="type-signature"></span>new commandPreprocessor<span class="signature">(server, chatHandler)</span><span class="type-signature"></span></h4>
<div class="description">
Instantiates a commandPreprocessor object
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>server</code></td>
<td class="type">
<span class="param-type"><a href="channelManager.html">channelManager</a></span>
</td>
<td class="description last">Parent Server Object</td>
</tr>
<tr>
<td class="name"><code>chatHandler</code></td>
<td class="type">
<span class="param-type"><a href="chatHandler.html">chatHandler</a></span>
</td>
<td class="description last">Parent Chat Handler Object</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line29">line 29</a>
</li></ul></dd>
</dl>
</div>
<h3 class="subsection-title">Methods</h3>
<h4 class="name" id="markLinks"><span class="type-signature">(async) </span>markLinks<span class="signature">(commandObj)</span><span class="type-signature"></span></h4>
<div class="description">
Iterates through links in message and marks them by link type for later use by client-side post-processing
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>commandObj</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Object representing a single given command/chat request</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line126">line 126</a>
</li></ul></dd>
</dl>
<h4 class="name" id="prepMessage"><span class="type-signature">(async) </span>prepMessage<span class="signature">(commandObj)</span><span class="type-signature"></span></h4>
<div class="description">
Re-creates message string from processed Command Array
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>commandObj</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Object representing a single given command/chat request</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line142">line 142</a>
</li></ul></dd>
</dl>
<h4 class="name" id="preprocess"><span class="type-signature">(async) </span>preprocess<span class="signature">(socket, data)</span><span class="type-signature"></span></h4>
<div class="description">
Ingests a command/chat request from Chat Handler and pre-processes and processes it accordingly
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>socket</code></td>
<td class="type">
<span class="param-type">Socket</span>
</td>
<td class="description last">Socket we're receiving the request from</td>
</tr>
<tr>
<td class="name"><code>data</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Event payload</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line47">line 47</a>
</li></ul></dd>
</dl>
<h4 class="name" id="processServerCommand"><span class="type-signature">(async) </span>processServerCommand<span class="signature">(commandObj)</span><span class="type-signature"></span></h4>
<div class="description">
Uses the server's Command Processor object to process the chat/command request.
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>commandObj</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Object representing a single given command/chat request</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line105">line 105</a>
</li></ul></dd>
</dl>
<h4 class="name" id="sanatizeCommand"><span class="type-signature"></span>sanatizeCommand<span class="signature">(commandObj)</span><span class="type-signature"> &rarr; {Boolean}</span></h4>
<div class="description">
Sanatizes and Validates a single user chat message/command
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>commandObj</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Object representing a single given command/chat request</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line82">line 82</a>
</li></ul></dd>
</dl>
<h5>Returns:</h5>
<div class="param-desc">
false if Command/Message is too long to send
</div>
<dl>
<dt>
Type
</dt>
<dd>
<span class="param-type">Boolean</span>
</dd>
</dl>
<h4 class="name" id="sendChat"><span class="type-signature"></span>sendChat<span class="signature">(commandObj)</span><span class="type-signature"></span></h4>
<div class="description">
Relays chat to channel via parent Chat Handler object
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>commandObj</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Object representing a single given command/chat request</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line153">line 153</a>
</li></ul></dd>
</dl>
<h4 class="name" id="splitCommand"><span class="type-signature"></span>splitCommand<span class="signature">(commandObj)</span><span class="type-signature"></span></h4>
<div class="description">
Splits raw chat/command data into seperate arrays, one by word-borders and words surrounded by word-borders
These arrays are used to handle further command/chat processing
</div>
<h5>Parameters:</h5>
<table class="params">
<thead>
<tr>
<th>Name</th>
<th>Type</th>
<th class="last">Description</th>
</tr>
</thead>
<tbody>
<tr>
<td class="name"><code>commandObj</code></td>
<td class="type">
<span class="param-type">Object</span>
</td>
<td class="description last">Object representing a single given command/chat request</td>
</tr>
</tbody>
</table>
<dl class="details">
<dt class="tag-source">Source:</dt>
<dd class="tag-source"><ul class="dummy"><li>
<a href="app_channel_commandPreprocessor.js.html">app/channel/commandPreprocessor.js</a>, <a href="app_channel_commandPreprocessor.js.html#line95">line 95</a>
</li></ul></dd>
</dl>
</article>
</section>
</div>
<nav>
<h2><a href="index.html">Home</a></h2><h3>Classes</h3><ul><li><a href="activeChannel.html">activeChannel</a></li><li><a href="channelManager.html">channelManager</a></li><li><a href="chat.html">chat</a></li><li><a href="chatBuffer.html">chatBuffer</a></li><li><a href="chatHandler.html">chatHandler</a></li><li><a href="commandPreprocessor.html">commandPreprocessor</a></li><li><a href="commandProcessor.html">commandProcessor</a></li><li><a href="connectedUser.html">connectedUser</a></li><li><a href="media.html">media</a></li><li><a href="playlistHandler.html">playlistHandler</a></li><li><a href="queue.html">queue</a></li><li><a href="queuedMedia.html">queuedMedia</a></li><li><a href="tokebot.html">tokebot</a></li></ul><h3>Global</h3><ul><li><a href="global.html#authenticateSession">authenticateSession</a></li><li><a href="global.html#cache">cache</a></li><li><a href="global.html#channelBanSchema">channelBanSchema</a></li><li><a href="global.html#channelPermissionSchema">channelPermissionSchema</a></li><li><a href="global.html#channelSchema">channelSchema</a></li><li><a href="global.html#chatSchema">chatSchema</a></li><li><a href="global.html#comparePassword">comparePassword</a></li><li><a href="global.html#consoleWarn">consoleWarn</a></li><li><a href="global.html#daysToExpire">daysToExpire</a></li><li><a href="global.html#emailChangeSchema">emailChangeSchema</a></li><li><a href="global.html#emoteSchema">emoteSchema</a></li><li><a href="global.html#errorHandler">errorHandler</a></li><li><a href="global.html#errorMiddleware">errorMiddleware</a></li><li><a href="global.html#escapeRegex">escapeRegex</a></li><li><a href="global.html#exceptionHandler">exceptionHandler</a></li><li><a href="global.html#exceptionSmith">exceptionSmith</a></li><li><a href="global.html#failedAttempts">failedAttempts</a></li><li><a href="global.html#fetchMetadata">fetchMetadata</a></li><li><a href="global.html#fetchVideoMetadata">fetchVideoMetadata</a></li><li><a href="global.html#fetchYoutubeMetadata">fetchYoutubeMetadata</a></li><li><a href="global.html#fetchYoutubePlaylistMetadata">fetchYoutubePlaylistMetadata</a></li><li><a href="global.html#flairSchema">flairSchema</a></li><li><a href="global.html#genCaptcha">genCaptcha</a></li><li><a href="global.html#getLoginAttempts">getLoginAttempts</a></li><li><a href="global.html#getMediaType">getMediaType</a></li><li><a href="global.html#hashIP">hashIP</a></li><li><a href="global.html#hashPassword">hashPassword</a></li><li><a href="global.html#kickoff">kickoff</a></li><li><a href="global.html#killSession">killSession</a></li><li><a href="global.html#lifetime">lifetime</a></li><li><a href="global.html#localExceptionHandler">localExceptionHandler</a></li><li><a href="global.html#mailem">mailem</a></li><li><a href="global.html#markLink">markLink</a></li><li><a href="global.html#maxAttempts">maxAttempts</a></li><li><a href="global.html#mediaSchema">mediaSchema</a></li><li><a href="global.html#passwordResetSchema">passwordResetSchema</a></li><li><a href="global.html#permissionSchema">permissionSchema</a></li><li><a href="global.html#playlistMediaProperties">playlistMediaProperties</a></li><li><a href="global.html#playlistSchema">playlistSchema</a></li><li><a href="global.html#processExpiredAttempts">processExpiredAttempts</a></li><li><a href="global.html#queuedProperties">queuedProperties</a></li><li><a href="global.html#rankEnum">rankEnum</a></li><li><a href="global.html#refreshRawLink">refreshRawLink</a></li><li><a href="global.html#schedule">schedule</a></li><li><a href="global.html#securityCheck">securityCheck</a></li><li><a href="global.html#sendAddressVerification">sendAddressVerification</a></li><li><a href="global.html#socketCriticalExceptionHandler">socketCriticalExceptionHandler</a></li><li><a href="global.html#socketErrorHandler">socketErrorHandler</a></li><li><a href="global.html#socketExceptionHandler">socketExceptionHandler</a></li><li><a href="global.html#spent">spent</a></li><li><a href="global.html#statSchema">statSchema</a></li><li><a href="global.html#throttleAttempts">throttleAttempts</a></li><li><a href="global.html#tokeCommandSchema">tokeCommandSchema</a></li><li><a href="global.html#transporter">transporter</a></li><li><a href="global.html#typeEnum">typeEnum</a></li><li><a href="global.html#userBanSchema">userBanSchema</a></li><li><a href="global.html#userSchema">userSchema</a></li><li><a href="global.html#verify">verify</a></li><li><a href="global.html#yankMedia">yankMedia</a></li><li><a href="global.html#ytdlpFetch">ytdlpFetch</a></li></ul>
</nav>
<br class="clear">
<footer>
Documentation generated by <a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.4</a> on Tue Sep 02 2025 07:43:33 GMT-0400 (Eastern Daylight Time)
</footer>
<script> prettyPrint(); </script>
<script src="scripts/linenumber.js"> </script>
</body>
</html>