switch console javascript code to revealing module pattern to avoid global variables
This commit is contained in:
		
							parent
							
								
									bf7b58470a
								
							
						
					
					
						commit
						96f5d15811
					
				| @ -20,187 +20,208 @@ | |||||||
| var CONSOLE_PUSH_COUNT = 50; | var CONSOLE_PUSH_COUNT = 50; | ||||||
| var CONSOLE_PUSH_FREQ = 200; | var CONSOLE_PUSH_FREQ = 200; | ||||||
| 
 | 
 | ||||||
| (function initConsole() { | const Console = (function () { | ||||||
|     window.TerminalQueue = []; |  | ||||||
|     window.Terminal = $('#terminal').terminal(function (command, term) { |  | ||||||
|         Socket.emit('send command', command); |  | ||||||
|     }, { |  | ||||||
|         greetings: '', |  | ||||||
|         name: Pterodactyl.server.uuid, |  | ||||||
|         height: 450, |  | ||||||
|         exit: false, |  | ||||||
|         prompt: Pterodactyl.server.username + ':~$ ', |  | ||||||
|         scrollOnEcho: false, |  | ||||||
|         scrollBottomOffset: 5, |  | ||||||
|         onBlur: function (terminal) { |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| 
 | 
 | ||||||
|     Socket.on('initial status', function (data) { |     var terminalQueue; | ||||||
|         Terminal.clear(); |     var terminal; | ||||||
|         if (data.status === 1 || data.status === 2) { |  | ||||||
|             Socket.emit('send server log'); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| })(); |  | ||||||
| 
 | 
 | ||||||
| (function pushOutputQueue() { |     function initConsole() { | ||||||
|     if (TerminalQueue.length > CONSOLE_PUSH_COUNT) { |         termianlQueue = []; | ||||||
|         // console throttled warning show
 |         terminal = $('#terminal').terminal(function (command, term) { | ||||||
|  |             Socket.emit('send command', command); | ||||||
|  |         }, { | ||||||
|  |             greetings: '', | ||||||
|  |             name: Pterodactyl.server.uuid, | ||||||
|  |             height: 450, | ||||||
|  |             exit: false, | ||||||
|  |             prompt: Pterodactyl.server.username + ':~$ ', | ||||||
|  |             scrollOnEcho: false, | ||||||
|  |             scrollBottomOffset: 5, | ||||||
|  |             onBlur: function (terminal) { | ||||||
|  |                 return false; | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         Socket.on('initial status', function (data) { | ||||||
|  |             terminal.clear(); | ||||||
|  |             if (data.status === 1 || data.status === 2) { | ||||||
|  |                 Socket.emit('send server log'); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (TerminalQueue.length > 0) { |     function pushOutputQueue() { | ||||||
|         for (var i = 0; i < CONSOLE_PUSH_COUNT && TerminalQueue.length > 0; i++) { |         if (termianlQueue.length > CONSOLE_PUSH_COUNT) { | ||||||
|             Terminal.echo(TerminalQueue[0]); |             // console throttled warning show
 | ||||||
|             TerminalQueue.shift(); |  | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|  |         if (termianlQueue.length > 0) { | ||||||
|  |             for (var i = 0; i < CONSOLE_PUSH_COUNT && termianlQueue.length > 0; i++) { | ||||||
|  |                 terminal.echo(termianlQueue[0]); | ||||||
|  |                 termianlQueue.shift(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         window.setTimeout(pushOutputQueue, CONSOLE_PUSH_FREQ); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     window.setTimeout(pushOutputQueue, CONSOLE_PUSH_FREQ); |     return { | ||||||
| })(); |         init: function () { | ||||||
|  |             $('[data-attr="power"]').click(function (event) { | ||||||
|  |                 if (! $(this).hasClass('disabled')) { | ||||||
|  |                     Socket.emit('set status', $(this).data('action')); | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             var ctc = $('#chart_cpu'); | ||||||
|  |             var timeLabels = []; | ||||||
|  |             var cpuData = []; | ||||||
|  |             var CPUChart = new Chart(ctc, { | ||||||
|  |                 type: 'line', | ||||||
|  |                 data: { | ||||||
|  |                     labels: timeLabels, | ||||||
|  |                     datasets: [ | ||||||
|  |                         { | ||||||
|  |                             label: "Percent Use", | ||||||
|  |                             fill: false, | ||||||
|  |                             lineTension: 0.03, | ||||||
|  |                             backgroundColor: "#00A1CB", | ||||||
|  |                             borderColor: "#00A1CB", | ||||||
|  |                             borderCapStyle: 'butt', | ||||||
|  |                             borderDash: [], | ||||||
|  |                             borderDashOffset: 0.0, | ||||||
|  |                             borderJoinStyle: 'miter', | ||||||
|  |                             pointBorderColor: "rgba(75,192,192,1)", | ||||||
|  |                             pointBackgroundColor: "#fff", | ||||||
|  |                             pointBorderWidth: 1, | ||||||
|  |                             pointHoverRadius: 5, | ||||||
|  |                             pointHoverBackgroundColor: "rgba(75,192,192,1)", | ||||||
|  |                             pointHoverBorderColor: "rgba(220,220,220,1)", | ||||||
|  |                             pointHoverBorderWidth: 2, | ||||||
|  |                             pointRadius: 1, | ||||||
|  |                             pointHitRadius: 10, | ||||||
|  |                             data: cpuData, | ||||||
|  |                             spanGaps: false, | ||||||
|  |                         } | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 options: { | ||||||
|  |                     title: { | ||||||
|  |                         display: true, | ||||||
|  |                         text: 'CPU Usage (as Percent Total)' | ||||||
|  |                     }, | ||||||
|  |                     legend: { | ||||||
|  |                         display: false, | ||||||
|  |                     }, | ||||||
|  |                     animation: { | ||||||
|  |                         duration: 1, | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             var ctm = $('#chart_memory'); | ||||||
|  |             var memoryData = []; | ||||||
|  |             var MemoryChart = new Chart(ctm, { | ||||||
|  |                 type: 'line', | ||||||
|  |                 data: { | ||||||
|  |                     labels: timeLabels, | ||||||
|  |                     datasets: [ | ||||||
|  |                         { | ||||||
|  |                             label: "Memory Use", | ||||||
|  |                             fill: false, | ||||||
|  |                             lineTension: 0.03, | ||||||
|  |                             backgroundColor: "#01A4A4", | ||||||
|  |                             borderColor: "#01A4A4", | ||||||
|  |                             borderCapStyle: 'butt', | ||||||
|  |                             borderDash: [], | ||||||
|  |                             borderDashOffset: 0.0, | ||||||
|  |                             borderJoinStyle: 'miter', | ||||||
|  |                             pointBorderColor: "rgba(75,192,192,1)", | ||||||
|  |                             pointBackgroundColor: "#fff", | ||||||
|  |                             pointBorderWidth: 1, | ||||||
|  |                             pointHoverRadius: 5, | ||||||
|  |                             pointHoverBackgroundColor: "rgba(75,192,192,1)", | ||||||
|  |                             pointHoverBorderColor: "rgba(220,220,220,1)", | ||||||
|  |                             pointHoverBorderWidth: 2, | ||||||
|  |                             pointRadius: 1, | ||||||
|  |                             pointHitRadius: 10, | ||||||
|  |                             data: memoryData, | ||||||
|  |                             spanGaps: false, | ||||||
|  |                         } | ||||||
|  |                     ] | ||||||
|  |                 }, | ||||||
|  |                 options: { | ||||||
|  |                     title: { | ||||||
|  |                         display: true, | ||||||
|  |                         text: 'Memory Usage (in Megabytes)' | ||||||
|  |                     }, | ||||||
|  |                     legend: { | ||||||
|  |                         display: false, | ||||||
|  |                     }, | ||||||
|  |                     animation: { | ||||||
|  |                         duration: 1, | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |             Socket.on('proc', function (proc) { | ||||||
|  |                 if (cpuData.length > 10) { | ||||||
|  |                     cpuData.shift(); | ||||||
|  |                     memoryData.shift(); | ||||||
|  |                     timeLabels.shift(); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 var cpuUse = (Pterodactyl.server.cpu > 0) ? parseFloat(((proc.data.cpu.total / Pterodactyl.server.cpu) * 100).toFixed(3).toString()) : proc.data.cpu.total; | ||||||
|  |                 cpuData.push(cpuUse); | ||||||
|  |                 memoryData.push(parseInt(proc.data.memory.total / (1024 * 1024))); | ||||||
|  | 
 | ||||||
|  |                 var m = new Date(); | ||||||
|  |                 timeLabels.push($.format.date(new Date(), 'HH:mm:ss')); | ||||||
|  | 
 | ||||||
|  |                 CPUChart.update(); | ||||||
|  |                 MemoryChart.update(); | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             // Update Listings on Initial Status
 | ||||||
|  |             Socket.on('initial status', function (data) { | ||||||
|  |                 updateServerPowerControls(data.status); | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             // Update Listings on Status
 | ||||||
|  |             Socket.on('status', function (data) { | ||||||
|  |                 updateServerPowerControls(data.status); | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |             function updateServerPowerControls (data) { | ||||||
|  |                 // Server is On or Starting
 | ||||||
|  |                 if(data == 1 || data == 2) { | ||||||
|  |                     $('[data-attr="power"][data-action="start"]').addClass('disabled'); | ||||||
|  |                     $('[data-attr="power"][data-action="stop"], [data-attr="power"][data-action="restart"]').removeClass('disabled'); | ||||||
|  |                 } else { | ||||||
|  |                     if (data == 0) { | ||||||
|  |                         $('[data-attr="power"][data-action="start"]').removeClass('disabled'); | ||||||
|  |                     } | ||||||
|  |                     $('[data-attr="power"][data-action="stop"], [data-attr="power"][data-action="restart"]').addClass('disabled'); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 if(data !== 0) { | ||||||
|  |                     $('[data-attr="power"][data-action="kill"]').removeClass('disabled'); | ||||||
|  |                 } else { | ||||||
|  |                     $('[data-attr="power"][data-action="kill"]').addClass('disabled'); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         }, | ||||||
|  | 
 | ||||||
|  |         getTerminal: function() { | ||||||
|  |             return terminal | ||||||
|  |         }, | ||||||
|  | 
 | ||||||
|  |         getTerminalQueue: function() { | ||||||
|  |             return terminalQueue | ||||||
|  |         }, | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | }); | ||||||
| 
 | 
 | ||||||
| $(document).ready(function () { | $(document).ready(function () { | ||||||
|     $('[data-attr="power"]').click(function (event) { |     Console.init(); | ||||||
|         if (! $(this).hasClass('disabled')) { |  | ||||||
|             Socket.emit('set status', $(this).data('action')); |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     var ctc = $('#chart_cpu'); |  | ||||||
|     var timeLabels = []; |  | ||||||
|     var cpuData = []; |  | ||||||
|     var CPUChart = new Chart(ctc, { |  | ||||||
|         type: 'line', |  | ||||||
|         data: { |  | ||||||
|             labels: timeLabels, |  | ||||||
|             datasets: [ |  | ||||||
|                 { |  | ||||||
|                     label: "Percent Use", |  | ||||||
|                     fill: false, |  | ||||||
|                     lineTension: 0.03, |  | ||||||
|                     backgroundColor: "#00A1CB", |  | ||||||
|                     borderColor: "#00A1CB", |  | ||||||
|                     borderCapStyle: 'butt', |  | ||||||
|                     borderDash: [], |  | ||||||
|                     borderDashOffset: 0.0, |  | ||||||
|                     borderJoinStyle: 'miter', |  | ||||||
|                     pointBorderColor: "rgba(75,192,192,1)", |  | ||||||
|                     pointBackgroundColor: "#fff", |  | ||||||
|                     pointBorderWidth: 1, |  | ||||||
|                     pointHoverRadius: 5, |  | ||||||
|                     pointHoverBackgroundColor: "rgba(75,192,192,1)", |  | ||||||
|                     pointHoverBorderColor: "rgba(220,220,220,1)", |  | ||||||
|                     pointHoverBorderWidth: 2, |  | ||||||
|                     pointRadius: 1, |  | ||||||
|                     pointHitRadius: 10, |  | ||||||
|                     data: cpuData, |  | ||||||
|                     spanGaps: false, |  | ||||||
|                 } |  | ||||||
|             ] |  | ||||||
|         }, |  | ||||||
|         options: { |  | ||||||
|             title: { |  | ||||||
|                 display: true, |  | ||||||
|                 text: 'CPU Usage (as Percent Total)' |  | ||||||
|             }, |  | ||||||
|             legend: { |  | ||||||
|                 display: false, |  | ||||||
|             }, |  | ||||||
|             animation: { |  | ||||||
|                 duration: 1, |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     var ctm = $('#chart_memory'); |  | ||||||
|     var memoryData = []; |  | ||||||
|     var MemoryChart = new Chart(ctm, { |  | ||||||
|         type: 'line', |  | ||||||
|         data: { |  | ||||||
|             labels: timeLabels, |  | ||||||
|             datasets: [ |  | ||||||
|                 { |  | ||||||
|                     label: "Memory Use", |  | ||||||
|                     fill: false, |  | ||||||
|                     lineTension: 0.03, |  | ||||||
|                     backgroundColor: "#01A4A4", |  | ||||||
|                     borderColor: "#01A4A4", |  | ||||||
|                     borderCapStyle: 'butt', |  | ||||||
|                     borderDash: [], |  | ||||||
|                     borderDashOffset: 0.0, |  | ||||||
|                     borderJoinStyle: 'miter', |  | ||||||
|                     pointBorderColor: "rgba(75,192,192,1)", |  | ||||||
|                     pointBackgroundColor: "#fff", |  | ||||||
|                     pointBorderWidth: 1, |  | ||||||
|                     pointHoverRadius: 5, |  | ||||||
|                     pointHoverBackgroundColor: "rgba(75,192,192,1)", |  | ||||||
|                     pointHoverBorderColor: "rgba(220,220,220,1)", |  | ||||||
|                     pointHoverBorderWidth: 2, |  | ||||||
|                     pointRadius: 1, |  | ||||||
|                     pointHitRadius: 10, |  | ||||||
|                     data: memoryData, |  | ||||||
|                     spanGaps: false, |  | ||||||
|                 } |  | ||||||
|             ] |  | ||||||
|         }, |  | ||||||
|         options: { |  | ||||||
|             title: { |  | ||||||
|                 display: true, |  | ||||||
|                 text: 'Memory Usage (in Megabytes)' |  | ||||||
|             }, |  | ||||||
|             legend: { |  | ||||||
|                 display: false, |  | ||||||
|             }, |  | ||||||
|             animation: { |  | ||||||
|                 duration: 1, |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|     }); |  | ||||||
|     Socket.on('proc', function (proc) { |  | ||||||
|         if (cpuData.length > 10) { |  | ||||||
|             cpuData.shift(); |  | ||||||
|             memoryData.shift(); |  | ||||||
|             timeLabels.shift(); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         var cpuUse = (Pterodactyl.server.cpu > 0) ? parseFloat(((proc.data.cpu.total / Pterodactyl.server.cpu) * 100).toFixed(3).toString()) : proc.data.cpu.total; |  | ||||||
|         cpuData.push(cpuUse); |  | ||||||
|         memoryData.push(parseInt(proc.data.memory.total / (1024 * 1024))); |  | ||||||
| 
 |  | ||||||
|         var m = new Date(); |  | ||||||
|         timeLabels.push($.format.date(new Date(), 'HH:mm:ss')); |  | ||||||
| 
 |  | ||||||
|         CPUChart.update(); |  | ||||||
|         MemoryChart.update(); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // Update Listings on Initial Status
 |  | ||||||
|     Socket.on('initial status', function (data) { |  | ||||||
|         updateServerPowerControls(data.status); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     // Update Listings on Status
 |  | ||||||
|     Socket.on('status', function (data) { |  | ||||||
|         updateServerPowerControls(data.status); |  | ||||||
|     }); |  | ||||||
| 
 |  | ||||||
|     function updateServerPowerControls (data) { |  | ||||||
|         // Server is On or Starting
 |  | ||||||
|         if(data == 1 || data == 2) { |  | ||||||
|             $('[data-attr="power"][data-action="start"]').addClass('disabled'); |  | ||||||
|             $('[data-attr="power"][data-action="stop"], [data-attr="power"][data-action="restart"]').removeClass('disabled'); |  | ||||||
|         } else { |  | ||||||
|             if (data == 0) { |  | ||||||
|                 $('[data-attr="power"][data-action="start"]').removeClass('disabled'); |  | ||||||
|             } |  | ||||||
|             $('[data-attr="power"][data-action="stop"], [data-attr="power"][data-action="restart"]').addClass('disabled'); |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if(data !== 0) { |  | ||||||
|             $('[data-attr="power"][data-action="kill"]').removeClass('disabled'); |  | ||||||
|         } else { |  | ||||||
|             $('[data-attr="power"][data-action="kill"]').addClass('disabled'); |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| }); | }); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Jakob Schrettenbrunner
						Jakob Schrettenbrunner