1.0.0
This commit is contained in:
		
							
								
								
									
										7
									
								
								public/css/bootstrap.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								public/css/bootstrap.min.css
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										163
									
								
								public/css/xterm.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										163
									
								
								public/css/xterm.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,163 @@ | ||||
| /** | ||||
|  * Copyright (c) 2014 The xterm.js authors. All rights reserved. | ||||
|  * Copyright (c) 2012-2013, Christopher Jeffrey (MIT License) | ||||
|  * https://github.com/chjj/term.js | ||||
|  * @license MIT | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  * | ||||
|  * Originally forked from (with the author's permission): | ||||
|  *   Fabrice Bellard's javascript vt100 for jslinux: | ||||
|  *   http://bellard.org/jslinux/ | ||||
|  *   Copyright (c) 2011 Fabrice Bellard | ||||
|  *   The original design remains. The terminal itself | ||||
|  *   has been extended to include xterm CSI codes, among | ||||
|  *   other features. | ||||
|  */ | ||||
|  | ||||
| /** | ||||
|  *  Default styles for xterm.js | ||||
|  */ | ||||
|  | ||||
| .xterm { | ||||
|     font-feature-settings: "liga" 0; | ||||
|     position: relative; | ||||
|     user-select: none; | ||||
|     -ms-user-select: none; | ||||
|     -webkit-user-select: none; | ||||
| } | ||||
|  | ||||
| .xterm.focus, | ||||
| .xterm:focus { | ||||
|     outline: none; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-helpers { | ||||
|     position: absolute; | ||||
|     top: 0; | ||||
|     /** | ||||
|      * The z-index of the helpers must be higher than the canvases in order for | ||||
|      * IMEs to appear on top. | ||||
|      */ | ||||
|     z-index: 10; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-helper-textarea { | ||||
|     /* | ||||
|      * HACK: to fix IE's blinking cursor | ||||
|      * Move textarea out of the screen to the far left, so that the cursor is not visible. | ||||
|      */ | ||||
|     position: absolute; | ||||
|     opacity: 0; | ||||
|     left: -9999em; | ||||
|     top: 0; | ||||
|     width: 0; | ||||
|     height: 0; | ||||
|     z-index: -10; | ||||
|     /** Prevent wrapping so the IME appears against the textarea at the correct position */ | ||||
|     white-space: nowrap; | ||||
|     overflow: hidden; | ||||
|     resize: none; | ||||
| } | ||||
|  | ||||
| .xterm .composition-view { | ||||
|     /* TODO: Composition position got messed up somewhere */ | ||||
|     background: #000; | ||||
|     color: #FFF; | ||||
|     display: none; | ||||
|     position: absolute; | ||||
|     white-space: nowrap; | ||||
|     z-index: 1; | ||||
| } | ||||
|  | ||||
| .xterm .composition-view.active { | ||||
|     display: block; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-viewport { | ||||
|     /* On OS X this is required in order for the scroll bar to appear fully opaque */ | ||||
|     background-color: #000; | ||||
|     overflow-y: scroll; | ||||
|     cursor: default; | ||||
|     position: absolute; | ||||
|     right: 0; | ||||
|     left: 0; | ||||
|     top: 0; | ||||
|     bottom: 0; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-screen { | ||||
|     position: relative; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-screen canvas { | ||||
|     position: absolute; | ||||
|     left: 0; | ||||
|     top: 0; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-scroll-area { | ||||
|     visibility: hidden; | ||||
| } | ||||
|  | ||||
| .xterm-char-measure-element { | ||||
|     display: inline-block; | ||||
|     visibility: hidden; | ||||
|     position: absolute; | ||||
|     top: 0; | ||||
|     left: -9999em; | ||||
|     line-height: normal; | ||||
| } | ||||
|  | ||||
| .xterm { | ||||
|     cursor: text; | ||||
| } | ||||
|  | ||||
| .xterm.enable-mouse-events { | ||||
|     /* When mouse events are enabled (eg. tmux), revert to the standard pointer cursor */ | ||||
|     cursor: default; | ||||
| } | ||||
|  | ||||
| .xterm.xterm-cursor-pointer { | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .xterm.column-select.focus { | ||||
|     /* Column selection mode */ | ||||
|     cursor: crosshair; | ||||
| } | ||||
|  | ||||
| .xterm .xterm-accessibility, | ||||
| .xterm .xterm-message { | ||||
|     position: absolute; | ||||
|     left: 0; | ||||
|     top: 0; | ||||
|     bottom: 0; | ||||
|     right: 0; | ||||
|     z-index: 100; | ||||
|     color: transparent; | ||||
| } | ||||
|  | ||||
| .xterm .live-region { | ||||
|     position: absolute; | ||||
|     left: -9999px; | ||||
|     width: 1px; | ||||
|     height: 1px; | ||||
|     overflow: hidden; | ||||
| } | ||||
							
								
								
									
										
											BIN
										
									
								
								public/icon.ico
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/icon.ico
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 264 KiB | 
							
								
								
									
										78
									
								
								public/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								public/index.html
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | ||||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
|  | ||||
| <head> | ||||
|   <meta charset="UTF-8"> | ||||
|   <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|   <meta http-equiv="X-UA-Compatible" content="ie=edge"> | ||||
|   <title>Electron Distribution</title> | ||||
|   <link rel="stylesheet" href="css/bootstrap.min.css"> | ||||
|   <link rel="stylesheet" href="css/xterm.css"> | ||||
|   <script> | ||||
|     if (!document.querySelectorAll || !window.localStorage || !self.fetch) { | ||||
|       alert('Upgrade your browser, Thank you.') | ||||
|     } | ||||
|   </script> | ||||
|   <style> | ||||
|   body { | ||||
|     padding: 10px; | ||||
|   } | ||||
|  | ||||
|   .out { | ||||
|     margin-top: 10px; | ||||
|     background-color: black; | ||||
|     padding: 10px; | ||||
|   } | ||||
|  | ||||
|   #no-auth, #auth { | ||||
|     display: none; | ||||
|   } | ||||
|  | ||||
|   #terminal { | ||||
|     width: 100%; | ||||
|     min-height: 428px; | ||||
|   } | ||||
|  | ||||
|   #table { | ||||
|     max-height: 300px; | ||||
|     overflow: auto; | ||||
|     margin: 5px 0; | ||||
|   } | ||||
|   </style> | ||||
| </head> | ||||
|  | ||||
| <body> | ||||
|   <div id="no-auth"> | ||||
|     Just for developers debugging, this page is very simple, sorry. | ||||
|     <input type="password" size="128" placeholder="Please input the token and press enter key" id="tokenInput"> | ||||
|   </div> | ||||
|  | ||||
|   <div id="auth"> | ||||
|     <div class="menu"> | ||||
|       <input type="button" value="Docker Initialize" id="dockerInitBtn"> | ||||
|       <input type="button" value="Release Log" id="listReleaseBtn"> | ||||
|       <input type="button" value="Build Log" id="listBuildBtn"> | ||||
|       <input type="button" value="Git Pull" id="gitPullBtn"> | ||||
|       <input type="button" value="Build Linux" id="buildLinuxBtn"> | ||||
|       <input type="button" value="Build Windows" id="buildWindowsBtn"> | ||||
|       <input type="button" value="Build Mac" id="buildMacBtn"> | ||||
|       <input type="button" value="Logout" id="logoutBtn"> | ||||
|     </div> | ||||
|  | ||||
|     <div id="table"></div> | ||||
|  | ||||
|     <div class="out"> | ||||
|       <div id="terminal"></div> | ||||
|     </div> | ||||
|   </div> | ||||
|  | ||||
|   <script src="js/sha.js"></script> | ||||
|   <script src="js/xterm.js"></script> | ||||
|   <script src="js/addons/fit/fit.js"></script> | ||||
|   <script src="js/addons/attach/attach.js"></script> | ||||
|   <script src="js/socket.io.js"></script> | ||||
|   <script src="js/jsonToTable.js"></script> | ||||
|   <script src="js/main.js"></script> | ||||
| </body> | ||||
|  | ||||
| </html> | ||||
							
								
								
									
										104
									
								
								public/js/addons/attach/attach.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								public/js/addons/attach/attach.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,104 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.attach = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| function attach(term, socket, bidirectional, buffered) { | ||||
|     var addonTerminal = term; | ||||
|     bidirectional = (typeof bidirectional === 'undefined') ? true : bidirectional; | ||||
|     addonTerminal.__socket = socket; | ||||
|     addonTerminal.__flushBuffer = function () { | ||||
|         addonTerminal.write(addonTerminal.__attachSocketBuffer); | ||||
|         addonTerminal.__attachSocketBuffer = null; | ||||
|     }; | ||||
|     addonTerminal.__pushToBuffer = function (data) { | ||||
|         if (addonTerminal.__attachSocketBuffer) { | ||||
|             addonTerminal.__attachSocketBuffer += data; | ||||
|         } | ||||
|         else { | ||||
|             addonTerminal.__attachSocketBuffer = data; | ||||
|             setTimeout(addonTerminal.__flushBuffer, 10); | ||||
|         } | ||||
|     }; | ||||
|     var myTextDecoder; | ||||
|     addonTerminal.__getMessage = function (ev) { | ||||
|         var str; | ||||
|         if (typeof ev.data === 'object') { | ||||
|             if (!myTextDecoder) { | ||||
|                 myTextDecoder = new TextDecoder(); | ||||
|             } | ||||
|             if (ev.data instanceof ArrayBuffer) { | ||||
|                 str = myTextDecoder.decode(ev.data); | ||||
|                 displayData(str); | ||||
|             } | ||||
|             else { | ||||
|                 var fileReader_1 = new FileReader(); | ||||
|                 fileReader_1.addEventListener('load', function () { | ||||
|                     str = myTextDecoder.decode(fileReader_1.result); | ||||
|                     displayData(str); | ||||
|                 }); | ||||
|                 fileReader_1.readAsArrayBuffer(ev.data); | ||||
|             } | ||||
|         } | ||||
|         else if (typeof ev.data === 'string') { | ||||
|             displayData(ev.data); | ||||
|         } | ||||
|         else { | ||||
|             throw Error("Cannot handle \"" + typeof ev.data + "\" websocket message."); | ||||
|         } | ||||
|     }; | ||||
|     function displayData(str, data) { | ||||
|         if (buffered) { | ||||
|             addonTerminal.__pushToBuffer(str || data); | ||||
|         } | ||||
|         else { | ||||
|             addonTerminal.write(str || data); | ||||
|         } | ||||
|     } | ||||
|     addonTerminal.__sendData = function (data) { | ||||
|         if (socket.readyState !== 1) { | ||||
|             return; | ||||
|         } | ||||
|         socket.send(data); | ||||
|     }; | ||||
|     addonTerminal._core.register(addSocketListener(socket, 'message', addonTerminal.__getMessage)); | ||||
|     if (bidirectional) { | ||||
|         addonTerminal._core.register(addonTerminal.addDisposableListener('data', addonTerminal.__sendData)); | ||||
|     } | ||||
|     addonTerminal._core.register(addSocketListener(socket, 'close', function () { return detach(addonTerminal, socket); })); | ||||
|     addonTerminal._core.register(addSocketListener(socket, 'error', function () { return detach(addonTerminal, socket); })); | ||||
| } | ||||
| exports.attach = attach; | ||||
| function addSocketListener(socket, type, handler) { | ||||
|     socket.addEventListener(type, handler); | ||||
|     return { | ||||
|         dispose: function () { | ||||
|             if (!handler) { | ||||
|                 return; | ||||
|             } | ||||
|             socket.removeEventListener(type, handler); | ||||
|             handler = null; | ||||
|         } | ||||
|     }; | ||||
| } | ||||
| function detach(term, socket) { | ||||
|     var addonTerminal = term; | ||||
|     addonTerminal.off('data', addonTerminal.__sendData); | ||||
|     socket = (typeof socket === 'undefined') ? addonTerminal.__socket : socket; | ||||
|     if (socket) { | ||||
|         socket.removeEventListener('message', addonTerminal.__getMessage); | ||||
|     } | ||||
|     delete addonTerminal.__socket; | ||||
| } | ||||
| exports.detach = detach; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.attach = function (socket, bidirectional, buffered) { | ||||
|         attach(this, socket, bidirectional, buffered); | ||||
|     }; | ||||
|     terminalConstructor.prototype.detach = function (socket) { | ||||
|         detach(this, socket); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=attach.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/attach/attach.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/attach/attach.js.map
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										51
									
								
								public/js/addons/fit/fit.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								public/js/addons/fit/fit.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,51 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.fit = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| function proposeGeometry(term) { | ||||
|     if (!term.element.parentElement) { | ||||
|         return null; | ||||
|     } | ||||
|     var parentElementStyle = window.getComputedStyle(term.element.parentElement); | ||||
|     var parentElementHeight = parseInt(parentElementStyle.getPropertyValue('height')); | ||||
|     var parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue('width'))); | ||||
|     var elementStyle = window.getComputedStyle(term.element); | ||||
|     var elementPadding = { | ||||
|         top: parseInt(elementStyle.getPropertyValue('padding-top')), | ||||
|         bottom: parseInt(elementStyle.getPropertyValue('padding-bottom')), | ||||
|         right: parseInt(elementStyle.getPropertyValue('padding-right')), | ||||
|         left: parseInt(elementStyle.getPropertyValue('padding-left')) | ||||
|     }; | ||||
|     var elementPaddingVer = elementPadding.top + elementPadding.bottom; | ||||
|     var elementPaddingHor = elementPadding.right + elementPadding.left; | ||||
|     var availableHeight = parentElementHeight - elementPaddingVer; | ||||
|     var availableWidth = parentElementWidth - elementPaddingHor - term._core.viewport.scrollBarWidth; | ||||
|     var geometry = { | ||||
|         cols: Math.floor(availableWidth / term._core.renderer.dimensions.actualCellWidth), | ||||
|         rows: Math.floor(availableHeight / term._core.renderer.dimensions.actualCellHeight) | ||||
|     }; | ||||
|     return geometry; | ||||
| } | ||||
| exports.proposeGeometry = proposeGeometry; | ||||
| function fit(term) { | ||||
|     var geometry = proposeGeometry(term); | ||||
|     if (geometry) { | ||||
|         if (term.rows !== geometry.rows || term.cols !== geometry.cols) { | ||||
|             term._core.renderer.clear(); | ||||
|             term.resize(geometry.cols, geometry.rows); | ||||
|         } | ||||
|     } | ||||
| } | ||||
| exports.fit = fit; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.proposeGeometry = function () { | ||||
|         return proposeGeometry(this); | ||||
|     }; | ||||
|     terminalConstructor.prototype.fit = function () { | ||||
|         fit(this); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=fit.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/fit/fit.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/fit/fit.js.map
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"fit.js","sources":["../../../src/addons/fit/fit.ts","../../../node_modules/browser-pack/_prelude.js"],"sourcesContent":["/**\n * Copyright (c) 2014 The xterm.js authors. All rights reserved.\n * @license MIT\n *\n * Fit terminal columns and rows to the dimensions of its DOM element.\n *\n * ## Approach\n *\n *    Rows: Truncate the division of the terminal parent element height by the\n *          terminal row height.\n * Columns: Truncate the division of the terminal parent element width by the\n *          terminal character width (apply display: inline at the terminal\n *          row and truncate its width with the current number of columns).\n */\n\nimport { Terminal } from 'xterm';\n\nexport interface IGeometry {\n  rows: number;\n  cols: number;\n}\n\nexport function proposeGeometry(term: Terminal): IGeometry {\n  if (!term.element.parentElement) {\n    return null;\n  }\n  const parentElementStyle = window.getComputedStyle(term.element.parentElement);\n  const parentElementHeight = parseInt(parentElementStyle.getPropertyValue('height'));\n  const parentElementWidth = Math.max(0, parseInt(parentElementStyle.getPropertyValue('width')));\n  const elementStyle = window.getComputedStyle(term.element);\n  const elementPadding = {\n    top: parseInt(elementStyle.getPropertyValue('padding-top')),\n    bottom: parseInt(elementStyle.getPropertyValue('padding-bottom')),\n    right: parseInt(elementStyle.getPropertyValue('padding-right')),\n    left: parseInt(elementStyle.getPropertyValue('padding-left'))\n  };\n  const elementPaddingVer = elementPadding.top + elementPadding.bottom;\n  const elementPaddingHor = elementPadding.right + elementPadding.left;\n  const availableHeight = parentElementHeight - elementPaddingVer;\n  const availableWidth = parentElementWidth - elementPaddingHor - (<any>term)._core.viewport.scrollBarWidth;\n  const geometry = {\n    cols: Math.floor(availableWidth / (<any>term)._core.renderer.dimensions.actualCellWidth),\n    rows: Math.floor(availableHeight / (<any>term)._core.renderer.dimensions.actualCellHeight)\n  };\n  return geometry;\n}\n\nexport function fit(term: Terminal): void {\n  const geometry = proposeGeometry(term);\n  if (geometry) {\n    // Force a full render\n    if (term.rows !== geometry.rows || term.cols !== geometry.cols) {\n      (<any>term)._core.renderer.clear();\n      term.resize(geometry.cols, geometry.rows);\n    }\n  }\n}\n\nexport function apply(terminalConstructor: typeof Terminal): void {\n  (<any>terminalConstructor.prototype).proposeGeometry = function (): IGeometry {\n    return proposeGeometry(this);\n  };\n\n  (<any>terminalConstructor.prototype).fit = function (): void {\n    fit(this);\n  };\n}\n",null],"names":[],"mappings":"ACAA;;;ADsBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAvBA;AAyBA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AATA;AAWA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AARA;"} | ||||
							
								
								
									
										10
									
								
								public/js/addons/fullscreen/fullscreen.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								public/js/addons/fullscreen/fullscreen.css
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,10 @@ | ||||
| .xterm.fullscreen { | ||||
|     position: fixed; | ||||
|     top: 0; | ||||
|     bottom: 0; | ||||
|     left: 0; | ||||
|     right: 0; | ||||
|     width: auto; | ||||
|     height: auto; | ||||
|     z-index: 255; | ||||
| } | ||||
							
								
								
									
										29
									
								
								public/js/addons/fullscreen/fullscreen.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								public/js/addons/fullscreen/fullscreen.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.fullscreen = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| function toggleFullScreen(term, fullscreen) { | ||||
|     var fn; | ||||
|     if (typeof fullscreen === 'undefined') { | ||||
|         fn = (term.element.classList.contains('fullscreen')) ? | ||||
|             term.element.classList.remove : term.element.classList.add; | ||||
|     } | ||||
|     else if (!fullscreen) { | ||||
|         fn = term.element.classList.remove; | ||||
|     } | ||||
|     else { | ||||
|         fn = term.element.classList.add; | ||||
|     } | ||||
|     fn = fn.bind(term.element.classList); | ||||
|     fn('fullscreen'); | ||||
| } | ||||
| exports.toggleFullScreen = toggleFullScreen; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.toggleFullScreen = function (fullscreen) { | ||||
|         toggleFullScreen(this, fullscreen); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=fullscreen.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/fullscreen/fullscreen.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/fullscreen/fullscreen.js.map
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"fullscreen.js","sources":["../../../src/addons/fullscreen/fullscreen.ts","../../../node_modules/browser-pack/_prelude.js"],"sourcesContent":["/**\n * Copyright (c) 2014 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal } from 'xterm';\n\n/**\n * Toggle the given terminal's fullscreen mode.\n * @param term The terminal to toggle full screen mode\n * @param fullscreen Toggle fullscreen on (true) or off (false)\n */\nexport function toggleFullScreen(term: Terminal, fullscreen: boolean): void {\n  let fn: (...tokens: string[]) => void;\n\n  if (typeof fullscreen === 'undefined') {\n    fn = (term.element.classList.contains('fullscreen')) ?\n      term.element.classList.remove : term.element.classList.add;\n  } else if (!fullscreen) {\n    fn = term.element.classList.remove;\n  } else {\n    fn = term.element.classList.add;\n  }\n\n  fn = fn.bind(term.element.classList);\n  fn('fullscreen');\n}\n\nexport function apply(terminalConstructor: typeof Terminal): void {\n  (<any>terminalConstructor.prototype).toggleFullScreen = function (fullscreen: boolean): void {\n    toggleFullScreen(this, fullscreen);\n  };\n}\n",null],"names":[],"mappings":"ACAA;;;ADYA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AAAA;AACA;AACA;AAEA;AACA;AACA;AAdA;AAgBA;AACA;AACA;AACA;AACA;AAJA;"} | ||||
							
								
								
									
										235
									
								
								public/js/addons/search/search.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										235
									
								
								public/js/addons/search/search.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,235 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.search = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var NON_WORD_CHARACTERS = ' ~!@#$%^&*()+`-=[]{}|\;:"\',./<>?'; | ||||
| var LINES_CACHE_TIME_TO_LIVE = 15 * 1000; | ||||
| var SearchHelper = (function () { | ||||
|     function SearchHelper(_terminal) { | ||||
|         this._terminal = _terminal; | ||||
|         this._linesCache = null; | ||||
|         this._linesCacheTimeoutId = 0; | ||||
|         this._destroyLinesCache = this._destroyLinesCache.bind(this); | ||||
|     } | ||||
|     SearchHelper.prototype.findNext = function (term, searchOptions) { | ||||
|         var selectionManager = this._terminal._core.selectionManager; | ||||
|         var incremental = searchOptions.incremental; | ||||
|         var result; | ||||
|         if (!term || term.length === 0) { | ||||
|             selectionManager.clearSelection(); | ||||
|             return false; | ||||
|         } | ||||
|         var startCol = 0; | ||||
|         var startRow = this._terminal._core.buffer.ydisp; | ||||
|         if (selectionManager.selectionEnd) { | ||||
|             if (this._terminal.getSelection().length !== 0) { | ||||
|                 startRow = incremental ? selectionManager.selectionStart[1] : selectionManager.selectionEnd[1]; | ||||
|                 startCol = incremental ? selectionManager.selectionStart[0] : selectionManager.selectionEnd[0]; | ||||
|             } | ||||
|         } | ||||
|         this._initLinesCache(); | ||||
|         result = this._findInLine(term, startRow, startCol, searchOptions); | ||||
|         if (!result) { | ||||
|             for (var y = startRow + 1; y < this._terminal._core.buffer.ybase + this._terminal.rows; y++) { | ||||
|                 result = this._findInLine(term, y, 0, searchOptions); | ||||
|                 if (result) { | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (!result) { | ||||
|             for (var y = 0; y <= startRow; y++) { | ||||
|                 result = this._findInLine(term, y, 0, searchOptions); | ||||
|                 if (result) { | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return this._selectResult(result); | ||||
|     }; | ||||
|     SearchHelper.prototype.findPrevious = function (term, searchOptions) { | ||||
|         var selectionManager = this._terminal._core.selectionManager; | ||||
|         var result; | ||||
|         if (!term || term.length === 0) { | ||||
|             selectionManager.clearSelection(); | ||||
|             return false; | ||||
|         } | ||||
|         var isReverseSearch = true; | ||||
|         var startRow = this._terminal._core.buffer.ydisp; | ||||
|         var startCol = this._terminal._core.buffer.lines.get(startRow).length; | ||||
|         if (selectionManager.selectionStart) { | ||||
|             if (this._terminal.getSelection().length !== 0) { | ||||
|                 startRow = selectionManager.selectionStart[1]; | ||||
|                 startCol = selectionManager.selectionStart[0]; | ||||
|             } | ||||
|         } | ||||
|         this._initLinesCache(); | ||||
|         result = this._findInLine(term, startRow, startCol, searchOptions, isReverseSearch); | ||||
|         if (!result) { | ||||
|             for (var y = startRow - 1; y >= 0; y--) { | ||||
|                 result = this._findInLine(term, y, this._terminal._core.buffer.lines.get(y).length, searchOptions, isReverseSearch); | ||||
|                 if (result) { | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         if (!result) { | ||||
|             var searchFrom = this._terminal._core.buffer.ybase + this._terminal.rows - 1; | ||||
|             for (var y = searchFrom; y >= startRow; y--) { | ||||
|                 result = this._findInLine(term, y, this._terminal._core.buffer.lines.get(y).length, searchOptions, isReverseSearch); | ||||
|                 if (result) { | ||||
|                     break; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         return this._selectResult(result); | ||||
|     }; | ||||
|     SearchHelper.prototype._initLinesCache = function () { | ||||
|         var _this = this; | ||||
|         if (!this._linesCache) { | ||||
|             this._linesCache = new Array(this._terminal._core.buffer.length); | ||||
|             this._terminal.on('cursormove', this._destroyLinesCache); | ||||
|         } | ||||
|         window.clearTimeout(this._linesCacheTimeoutId); | ||||
|         this._linesCacheTimeoutId = window.setTimeout(function () { return _this._destroyLinesCache(); }, LINES_CACHE_TIME_TO_LIVE); | ||||
|     }; | ||||
|     SearchHelper.prototype._destroyLinesCache = function () { | ||||
|         this._linesCache = null; | ||||
|         this._terminal.off('cursormove', this._destroyLinesCache); | ||||
|         if (this._linesCacheTimeoutId) { | ||||
|             window.clearTimeout(this._linesCacheTimeoutId); | ||||
|             this._linesCacheTimeoutId = 0; | ||||
|         } | ||||
|     }; | ||||
|     SearchHelper.prototype._isWholeWord = function (searchIndex, line, term) { | ||||
|         return (((searchIndex === 0) || (NON_WORD_CHARACTERS.indexOf(line[searchIndex - 1]) !== -1)) && | ||||
|             (((searchIndex + term.length) === line.length) || (NON_WORD_CHARACTERS.indexOf(line[searchIndex + term.length]) !== -1))); | ||||
|     }; | ||||
|     SearchHelper.prototype._findInLine = function (term, row, col, searchOptions, isReverseSearch) { | ||||
|         if (searchOptions === void 0) { searchOptions = {}; } | ||||
|         if (isReverseSearch === void 0) { isReverseSearch = false; } | ||||
|         if (this._terminal._core.buffer.lines.get(row).isWrapped) { | ||||
|             return; | ||||
|         } | ||||
|         var stringLine = this._linesCache ? this._linesCache[row] : void 0; | ||||
|         if (stringLine === void 0) { | ||||
|             stringLine = this.translateBufferLineToStringWithWrap(row, true); | ||||
|             if (this._linesCache) { | ||||
|                 this._linesCache[row] = stringLine; | ||||
|             } | ||||
|         } | ||||
|         var searchTerm = searchOptions.caseSensitive ? term : term.toLowerCase(); | ||||
|         var searchStringLine = searchOptions.caseSensitive ? stringLine : stringLine.toLowerCase(); | ||||
|         var resultIndex = -1; | ||||
|         if (searchOptions.regex) { | ||||
|             var searchRegex = RegExp(searchTerm, 'g'); | ||||
|             var foundTerm = void 0; | ||||
|             if (isReverseSearch) { | ||||
|                 while (foundTerm = searchRegex.exec(searchStringLine.slice(0, col))) { | ||||
|                     resultIndex = searchRegex.lastIndex - foundTerm[0].length; | ||||
|                     term = foundTerm[0]; | ||||
|                     searchRegex.lastIndex -= (term.length - 1); | ||||
|                 } | ||||
|             } | ||||
|             else { | ||||
|                 foundTerm = searchRegex.exec(searchStringLine.slice(col)); | ||||
|                 if (foundTerm && foundTerm[0].length > 0) { | ||||
|                     resultIndex = col + (searchRegex.lastIndex - foundTerm[0].length); | ||||
|                     term = foundTerm[0]; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             if (isReverseSearch) { | ||||
|                 if (col - searchTerm.length >= 0) { | ||||
|                     resultIndex = searchStringLine.lastIndexOf(searchTerm, col - searchTerm.length); | ||||
|                 } | ||||
|             } | ||||
|             else { | ||||
|                 resultIndex = searchStringLine.indexOf(searchTerm, col); | ||||
|             } | ||||
|         } | ||||
|         if (resultIndex >= 0) { | ||||
|             if (resultIndex >= this._terminal.cols) { | ||||
|                 row += Math.floor(resultIndex / this._terminal.cols); | ||||
|                 resultIndex = resultIndex % this._terminal.cols; | ||||
|             } | ||||
|             if (searchOptions.wholeWord && !this._isWholeWord(resultIndex, searchStringLine, term)) { | ||||
|                 return; | ||||
|             } | ||||
|             var line = this._terminal._core.buffer.lines.get(row); | ||||
|             for (var i = 0; i < resultIndex; i++) { | ||||
|                 var charData = line.get(i); | ||||
|                 var char = charData[1]; | ||||
|                 if (char.length > 1) { | ||||
|                     resultIndex -= char.length - 1; | ||||
|                 } | ||||
|                 var charWidth = charData[2]; | ||||
|                 if (charWidth === 0) { | ||||
|                     resultIndex++; | ||||
|                 } | ||||
|             } | ||||
|             return { | ||||
|                 term: term, | ||||
|                 col: resultIndex, | ||||
|                 row: row | ||||
|             }; | ||||
|         } | ||||
|     }; | ||||
|     SearchHelper.prototype.translateBufferLineToStringWithWrap = function (lineIndex, trimRight) { | ||||
|         var lineString = ''; | ||||
|         var lineWrapsToNext; | ||||
|         do { | ||||
|             var nextLine = this._terminal._core.buffer.lines.get(lineIndex + 1); | ||||
|             lineWrapsToNext = nextLine ? nextLine.isWrapped : false; | ||||
|             lineString += this._terminal._core.buffer.translateBufferLineToString(lineIndex, !lineWrapsToNext && trimRight).substring(0, this._terminal.cols); | ||||
|             lineIndex++; | ||||
|         } while (lineWrapsToNext); | ||||
|         return lineString; | ||||
|     }; | ||||
|     SearchHelper.prototype._selectResult = function (result) { | ||||
|         if (!result) { | ||||
|             this._terminal.clearSelection(); | ||||
|             return false; | ||||
|         } | ||||
|         this._terminal._core.selectionManager.setSelection(result.col, result.row, result.term.length); | ||||
|         this._terminal.scrollLines(result.row - this._terminal._core.buffer.ydisp); | ||||
|         return true; | ||||
|     }; | ||||
|     return SearchHelper; | ||||
| }()); | ||||
| exports.SearchHelper = SearchHelper; | ||||
|  | ||||
| },{}],2:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var SearchHelper_1 = require("./SearchHelper"); | ||||
| function findNext(terminal, term, searchOptions) { | ||||
|     if (searchOptions === void 0) { searchOptions = {}; } | ||||
|     var addonTerminal = terminal; | ||||
|     if (!addonTerminal.__searchHelper) { | ||||
|         addonTerminal.__searchHelper = new SearchHelper_1.SearchHelper(addonTerminal); | ||||
|     } | ||||
|     return addonTerminal.__searchHelper.findNext(term, searchOptions); | ||||
| } | ||||
| exports.findNext = findNext; | ||||
| function findPrevious(terminal, term, searchOptions) { | ||||
|     var addonTerminal = terminal; | ||||
|     if (!addonTerminal.__searchHelper) { | ||||
|         addonTerminal.__searchHelper = new SearchHelper_1.SearchHelper(addonTerminal); | ||||
|     } | ||||
|     return addonTerminal.__searchHelper.findPrevious(term, searchOptions); | ||||
| } | ||||
| exports.findPrevious = findPrevious; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.findNext = function (term, searchOptions) { | ||||
|         return findNext(this, term, searchOptions); | ||||
|     }; | ||||
|     terminalConstructor.prototype.findPrevious = function (term, searchOptions) { | ||||
|         return findPrevious(this, term, searchOptions); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{"./SearchHelper":1}]},{},[2])(2) | ||||
| }); | ||||
| //# sourceMappingURL=search.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/search/search.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/search/search.js.map
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										69
									
								
								public/js/addons/terminado/terminado.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								public/js/addons/terminado/terminado.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,69 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.terminado = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| function terminadoAttach(term, socket, bidirectional, buffered) { | ||||
|     var addonTerminal = term; | ||||
|     bidirectional = (typeof bidirectional === 'undefined') ? true : bidirectional; | ||||
|     addonTerminal.__socket = socket; | ||||
|     addonTerminal.__flushBuffer = function () { | ||||
|         addonTerminal.write(addonTerminal.__attachSocketBuffer); | ||||
|         addonTerminal.__attachSocketBuffer = null; | ||||
|     }; | ||||
|     addonTerminal.__pushToBuffer = function (data) { | ||||
|         if (addonTerminal.__attachSocketBuffer) { | ||||
|             addonTerminal.__attachSocketBuffer += data; | ||||
|         } | ||||
|         else { | ||||
|             addonTerminal.__attachSocketBuffer = data; | ||||
|             setTimeout(addonTerminal.__flushBuffer, 10); | ||||
|         } | ||||
|     }; | ||||
|     addonTerminal.__getMessage = function (ev) { | ||||
|         var data = JSON.parse(ev.data); | ||||
|         if (data[0] === 'stdout') { | ||||
|             if (buffered) { | ||||
|                 addonTerminal.__pushToBuffer(data[1]); | ||||
|             } | ||||
|             else { | ||||
|                 addonTerminal.write(data[1]); | ||||
|             } | ||||
|         } | ||||
|     }; | ||||
|     addonTerminal.__sendData = function (data) { | ||||
|         socket.send(JSON.stringify(['stdin', data])); | ||||
|     }; | ||||
|     addonTerminal.__setSize = function (size) { | ||||
|         socket.send(JSON.stringify(['set_size', size.rows, size.cols])); | ||||
|     }; | ||||
|     socket.addEventListener('message', addonTerminal.__getMessage); | ||||
|     if (bidirectional) { | ||||
|         addonTerminal.on('data', addonTerminal.__sendData); | ||||
|     } | ||||
|     addonTerminal.on('resize', addonTerminal.__setSize); | ||||
|     socket.addEventListener('close', function () { return terminadoDetach(addonTerminal, socket); }); | ||||
|     socket.addEventListener('error', function () { return terminadoDetach(addonTerminal, socket); }); | ||||
| } | ||||
| exports.terminadoAttach = terminadoAttach; | ||||
| function terminadoDetach(term, socket) { | ||||
|     var addonTerminal = term; | ||||
|     addonTerminal.off('data', addonTerminal.__sendData); | ||||
|     socket = (typeof socket === 'undefined') ? addonTerminal.__socket : socket; | ||||
|     if (socket) { | ||||
|         socket.removeEventListener('message', addonTerminal.__getMessage); | ||||
|     } | ||||
|     delete addonTerminal.__socket; | ||||
| } | ||||
| exports.terminadoDetach = terminadoDetach; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.terminadoAttach = function (socket, bidirectional, buffered) { | ||||
|         return terminadoAttach(this, socket, bidirectional, buffered); | ||||
|     }; | ||||
|     terminalConstructor.prototype.terminadoDetach = function (socket) { | ||||
|         return terminadoDetach(this, socket); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=terminado.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/terminado/terminado.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/terminado/terminado.js.map
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"terminado.js","sources":["../../../src/addons/terminado/terminado.ts","../../../node_modules/browser-pack/_prelude.js"],"sourcesContent":["/**\n * Copyright (c) 2016 The xterm.js authors. All rights reserved.\n * @license MIT\n *\n * This module provides methods for attaching a terminal to a terminado\n * WebSocket stream.\n */\n\nimport { Terminal } from 'xterm';\nimport { ITerminadoAddonTerminal } from './Interfaces';\n\n/**\n * Attaches the given terminal to the given socket.\n *\n * @param term The terminal to be attached to the given socket.\n * @param socket The socket to attach the current terminal.\n * @param bidirectional Whether the terminal should send data to the socket as well.\n * @param buffered Whether the rendering of incoming data should happen instantly or at a maximum\n * frequency of 1 rendering per 10ms.\n */\nexport function terminadoAttach(term: Terminal, socket: WebSocket, bidirectional: boolean, buffered: boolean): void {\n  const addonTerminal = <ITerminadoAddonTerminal>term;\n  bidirectional = (typeof bidirectional === 'undefined') ? true : bidirectional;\n  addonTerminal.__socket = socket;\n\n  addonTerminal.__flushBuffer = () => {\n    addonTerminal.write(addonTerminal.__attachSocketBuffer);\n    addonTerminal.__attachSocketBuffer = null;\n  };\n\n  addonTerminal.__pushToBuffer = (data: string) => {\n    if (addonTerminal.__attachSocketBuffer) {\n      addonTerminal.__attachSocketBuffer += data;\n    } else {\n      addonTerminal.__attachSocketBuffer = data;\n      setTimeout(addonTerminal.__flushBuffer, 10);\n    }\n  };\n\n  addonTerminal.__getMessage = (ev: MessageEvent) => {\n    const data = JSON.parse(ev.data);\n    if (data[0] === 'stdout') {\n      if (buffered) {\n        addonTerminal.__pushToBuffer(data[1]);\n      } else {\n        addonTerminal.write(data[1]);\n      }\n    }\n  };\n\n  addonTerminal.__sendData = (data: string) => {\n    socket.send(JSON.stringify(['stdin', data]));\n  };\n\n  addonTerminal.__setSize = (size: {rows: number, cols: number}) => {\n    socket.send(JSON.stringify(['set_size', size.rows, size.cols]));\n  };\n\n  socket.addEventListener('message', addonTerminal.__getMessage);\n\n  if (bidirectional) {\n    addonTerminal.on('data', addonTerminal.__sendData);\n  }\n  addonTerminal.on('resize', addonTerminal.__setSize);\n\n  socket.addEventListener('close', () => terminadoDetach(addonTerminal, socket));\n  socket.addEventListener('error', () => terminadoDetach(addonTerminal, socket));\n}\n\n/**\n * Detaches the given terminal from the given socket\n *\n * @param term The terminal to be detached from the given socket.\n * @param socket The socket from which to detach the current terminal.\n */\nexport function terminadoDetach(term: Terminal, socket: WebSocket): void {\n  const addonTerminal = <ITerminadoAddonTerminal>term;\n  addonTerminal.off('data', addonTerminal.__sendData);\n\n  socket = (typeof socket === 'undefined') ? addonTerminal.__socket : socket;\n\n  if (socket) {\n    socket.removeEventListener('message', addonTerminal.__getMessage);\n  }\n\n  delete addonTerminal.__socket;\n}\n\nexport function apply(terminalConstructor: typeof Terminal): void {\n  /**\n   * Attaches the current terminal to the given socket\n   *\n   * @param socket - The socket to attach the current terminal.\n   * @param bidirectional - Whether the terminal should send data to the socket as well.\n   * @param buffered - Whether the rendering of incoming data should happen instantly or at a\n   * maximum frequency of 1 rendering per 10ms.\n   */\n  (<any>terminalConstructor.prototype).terminadoAttach = function (socket: WebSocket, bidirectional: boolean, buffered: boolean): void {\n    return terminadoAttach(this, socket, bidirectional, buffered);\n  };\n\n  /**\n   * Detaches the current terminal from the given socket.\n   *\n   * @param socket The socket from which to detach the current terminal.\n   */\n  (<any>terminalConstructor.prototype).terminadoDetach = function (socket: WebSocket): void {\n    return terminadoDetach(this, socket);\n  };\n}\n",null],"names":[],"mappings":"ACAA;;;ADoBA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AACA;AAEA;AAEA;AACA;AACA;AACA;AAEA;AACA;AACA;AA/CA;AAuDA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AAXA;AAaA;AASA;AACA;AACA;AAOA;AACA;AACA;AACA;AArBA;"} | ||||
							
								
								
									
										41
									
								
								public/js/addons/webLinks/webLinks.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								public/js/addons/webLinks/webLinks.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,41 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.webLinks = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var protocolClause = '(https?:\\/\\/)'; | ||||
| var domainCharacterSet = '[\\da-z\\.-]+'; | ||||
| var negatedDomainCharacterSet = '[^\\da-z\\.-]+'; | ||||
| var domainBodyClause = '(' + domainCharacterSet + ')'; | ||||
| var tldClause = '([a-z\\.]{2,6})'; | ||||
| var ipClause = '((\\d{1,3}\\.){3}\\d{1,3})'; | ||||
| var localHostClause = '(localhost)'; | ||||
| var portClause = '(:\\d{1,5})'; | ||||
| var hostClause = '((' + domainBodyClause + '\\.' + tldClause + ')|' + ipClause + '|' + localHostClause + ')' + portClause + '?'; | ||||
| var pathClause = '(\\/[\\/\\w\\.\\-%~:]*)*([^:"\'\\s])'; | ||||
| var queryStringHashFragmentCharacterSet = '[0-9\\w\\[\\]\\(\\)\\/\\?\\!#@$%&\'*+,:;~\\=\\.\\-]*'; | ||||
| var queryStringClause = '(\\?' + queryStringHashFragmentCharacterSet + ')?'; | ||||
| var hashFragmentClause = '(#' + queryStringHashFragmentCharacterSet + ')?'; | ||||
| var negatedPathCharacterSet = '[^\\/\\w\\.\\-%]+'; | ||||
| var bodyClause = hostClause + pathClause + queryStringClause + hashFragmentClause; | ||||
| var start = '(?:^|' + negatedDomainCharacterSet + ')('; | ||||
| var end = ')($|' + negatedPathCharacterSet + ')'; | ||||
| var strictUrlRegex = new RegExp(start + protocolClause + bodyClause + end); | ||||
| function handleLink(event, uri) { | ||||
|     window.open(uri, '_blank'); | ||||
| } | ||||
| function webLinksInit(term, handler, options) { | ||||
|     if (handler === void 0) { handler = handleLink; } | ||||
|     if (options === void 0) { options = {}; } | ||||
|     options.matchIndex = 1; | ||||
|     term.registerLinkMatcher(strictUrlRegex, handler, options); | ||||
| } | ||||
| exports.webLinksInit = webLinksInit; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.webLinksInit = function (handler, options) { | ||||
|         webLinksInit(this, handler, options); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=webLinks.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/webLinks/webLinks.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/webLinks/webLinks.js.map
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"webLinks.js","sources":["../../../src/addons/webLinks/webLinks.ts","../../../node_modules/browser-pack/_prelude.js"],"sourcesContent":["/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal, ILinkMatcherOptions } from 'xterm';\n\nconst protocolClause = '(https?:\\\\/\\\\/)';\nconst domainCharacterSet = '[\\\\da-z\\\\.-]+';\nconst negatedDomainCharacterSet = '[^\\\\da-z\\\\.-]+';\nconst domainBodyClause = '(' + domainCharacterSet + ')';\nconst tldClause = '([a-z\\\\.]{2,6})';\nconst ipClause = '((\\\\d{1,3}\\\\.){3}\\\\d{1,3})';\nconst localHostClause = '(localhost)';\nconst portClause = '(:\\\\d{1,5})';\nconst hostClause = '((' + domainBodyClause + '\\\\.' + tldClause + ')|' + ipClause + '|' + localHostClause + ')' + portClause + '?';\nconst pathClause = '(\\\\/[\\\\/\\\\w\\\\.\\\\-%~:]*)*([^:\"\\'\\\\s])';\nconst queryStringHashFragmentCharacterSet = '[0-9\\\\w\\\\[\\\\]\\\\(\\\\)\\\\/\\\\?\\\\!#@$%&\\'*+,:;~\\\\=\\\\.\\\\-]*';\nconst queryStringClause = '(\\\\?' + queryStringHashFragmentCharacterSet + ')?';\nconst hashFragmentClause = '(#' + queryStringHashFragmentCharacterSet + ')?';\nconst negatedPathCharacterSet = '[^\\\\/\\\\w\\\\.\\\\-%]+';\nconst bodyClause = hostClause + pathClause + queryStringClause + hashFragmentClause;\nconst start = '(?:^|' + negatedDomainCharacterSet + ')(';\nconst end = ')($|' + negatedPathCharacterSet + ')';\nconst strictUrlRegex = new RegExp(start + protocolClause + bodyClause + end);\n\nfunction handleLink(event: MouseEvent, uri: string): void {\n  window.open(uri, '_blank');\n}\n\n/**\n * Initialize the web links addon, registering the link matcher.\n * @param term The terminal to use web links within.\n * @param handler A custom handler to use.\n * @param options Custom options to use, matchIndex will always be ignored.\n */\nexport function webLinksInit(term: Terminal, handler: (event: MouseEvent, uri: string) => void = handleLink, options: ILinkMatcherOptions = {}): void {\n  options.matchIndex = 1;\n  term.registerLinkMatcher(strictUrlRegex, handler, options);\n}\n\nexport function apply(terminalConstructor: typeof Terminal): void {\n  (<any>terminalConstructor.prototype).webLinksInit = function (handler?: (event: MouseEvent, uri: string) => void, options?: ILinkMatcherOptions): void {\n    webLinksInit(this, handler, options);\n  };\n}\n",null],"names":[],"mappings":"ACAA;;;ADOA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAQA;AAAA;AAAA;AACA;AACA;AACA;AAHA;AAKA;AACA;AACA;AACA;AACA;AAJA;"} | ||||
							
								
								
									
										33
									
								
								public/js/addons/winptyCompat/winptyCompat.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								public/js/addons/winptyCompat/winptyCompat.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.winptyCompat = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var CHAR_DATA_CODE_INDEX = 3; | ||||
| var NULL_CELL_CODE = 0; | ||||
| var WHITESPACE_CELL_CODE = 32; | ||||
| function winptyCompatInit(terminal) { | ||||
|     var addonTerminal = terminal; | ||||
|     var isWindows = ['Windows', 'Win16', 'Win32', 'WinCE'].indexOf(navigator.platform) >= 0; | ||||
|     if (!isWindows) { | ||||
|         return; | ||||
|     } | ||||
|     addonTerminal._core.isWinptyCompatEnabled = true; | ||||
|     addonTerminal.on('linefeed', function () { | ||||
|         var line = addonTerminal._core.buffer.lines.get(addonTerminal._core.buffer.ybase + addonTerminal._core.buffer.y - 1); | ||||
|         var lastChar = line.get(addonTerminal.cols - 1); | ||||
|         if (lastChar[CHAR_DATA_CODE_INDEX] !== NULL_CELL_CODE && lastChar[CHAR_DATA_CODE_INDEX] !== WHITESPACE_CELL_CODE) { | ||||
|             var nextLine = addonTerminal._core.buffer.lines.get(addonTerminal._core.buffer.ybase + addonTerminal._core.buffer.y); | ||||
|             nextLine.isWrapped = true; | ||||
|         } | ||||
|     }); | ||||
| } | ||||
| exports.winptyCompatInit = winptyCompatInit; | ||||
| function apply(terminalConstructor) { | ||||
|     terminalConstructor.prototype.winptyCompatInit = function () { | ||||
|         winptyCompatInit(this); | ||||
|     }; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=winptyCompat.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/winptyCompat/winptyCompat.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/winptyCompat/winptyCompat.js.map
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"winptyCompat.js","sources":["../../../src/addons/winptyCompat/winptyCompat.ts","../../../node_modules/browser-pack/_prelude.js"],"sourcesContent":["/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal } from 'xterm';\nimport { IWinptyCompatAddonTerminal } from './Interfaces';\n\nconst CHAR_DATA_CODE_INDEX = 3;\nconst NULL_CELL_CODE = 0;\nconst WHITESPACE_CELL_CODE = 32;\n\nexport function winptyCompatInit(terminal: Terminal): void {\n  const addonTerminal = <IWinptyCompatAddonTerminal>terminal;\n\n  // Don't do anything when the platform is not Windows\n  const isWindows = ['Windows', 'Win16', 'Win32', 'WinCE'].indexOf(navigator.platform) >= 0;\n  if (!isWindows) {\n    return;\n  }\n\n  (addonTerminal._core as any).isWinptyCompatEnabled = true;\n\n  // Winpty does not support wraparound mode which means that lines will never\n  // be marked as wrapped. This causes issues for things like copying a line\n  // retaining the wrapped new line characters or if consumers are listening\n  // in on the data stream.\n  //\n  // The workaround for this is to listen to every incoming line feed and mark\n  // the line as wrapped if the last character in the previous line is not a\n  // space. This is certainly not without its problems, but generally on\n  // Windows when text reaches the end of the terminal it's likely going to be\n  // wrapped.\n  addonTerminal.on('linefeed', () => {\n    const line = addonTerminal._core.buffer.lines.get(addonTerminal._core.buffer.ybase + addonTerminal._core.buffer.y - 1);\n    const lastChar = line.get(addonTerminal.cols - 1);\n\n    if (lastChar[CHAR_DATA_CODE_INDEX] !== NULL_CELL_CODE && lastChar[CHAR_DATA_CODE_INDEX] !== WHITESPACE_CELL_CODE) {\n      const nextLine = addonTerminal._core.buffer.lines.get(addonTerminal._core.buffer.ybase + addonTerminal._core.buffer.y);\n      nextLine.isWrapped = true;\n    }\n  });\n}\n\nexport function apply(terminalConstructor: typeof Terminal): void {\n  (<any>terminalConstructor.prototype).winptyCompatInit = function (): void {\n    winptyCompatInit(this);\n  };\n}\n",null],"names":[],"mappings":"ACAA;;;ADQA;AACA;AACA;AAEA;AACA;AAGA;AACA;AACA;AACA;AAEA;AAYA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AA9BA;AAgCA;AACA;AACA;AACA;AACA;AAJA;"} | ||||
							
								
								
									
										45
									
								
								public/js/addons/zmodem/zmodem.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								public/js/addons/zmodem/zmodem.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | ||||
| (function(f){if(typeof exports==="object"&&typeof module!=="undefined"){module.exports=f()}else if(typeof define==="function"&&define.amd){define([],f)}else{var g;if(typeof window!=="undefined"){g=window}else if(typeof global!=="undefined"){g=global}else if(typeof self!=="undefined"){g=self}else{g=this}g.zmodem = f()}})(function(){var define,module,exports;return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof require&&require;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t)}return n[i].exports}for(var u="function"==typeof require&&require,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(require,module,exports){ | ||||
| "use strict"; | ||||
| Object.defineProperty(exports, "__esModule", { value: true }); | ||||
| var zmodem; | ||||
| function zmodemAttach(ws, opts) { | ||||
|     if (opts === void 0) { opts = {}; } | ||||
|     var term = this; | ||||
|     var senderFunc = function (octets) { return ws.send(new Uint8Array(octets)); }; | ||||
|     var zsentry; | ||||
|     function shouldWrite() { | ||||
|         return !!zsentry.get_confirmed_session() || !opts.noTerminalWriteOutsideSession; | ||||
|     } | ||||
|     zsentry = new zmodem.Sentry({ | ||||
|         to_terminal: function (octets) { | ||||
|             if (shouldWrite()) { | ||||
|                 term.write(String.fromCharCode.apply(String, octets)); | ||||
|             } | ||||
|         }, | ||||
|         sender: senderFunc, | ||||
|         on_retract: function () { return term.emit('zmodemRetract'); }, | ||||
|         on_detect: function (detection) { return term.emit('zmodemDetect', detection); } | ||||
|     }); | ||||
|     function handleWSMessage(evt) { | ||||
|         if (typeof evt.data === 'string') { | ||||
|             if (shouldWrite()) { | ||||
|                 term.write(evt.data); | ||||
|             } | ||||
|         } | ||||
|         else { | ||||
|             zsentry.consume(evt.data); | ||||
|         } | ||||
|     } | ||||
|     ws.binaryType = 'arraybuffer'; | ||||
|     ws.addEventListener('message', handleWSMessage); | ||||
| } | ||||
| function apply(terminalConstructor) { | ||||
|     zmodem = (typeof window === 'object') ? window.Zmodem : { Browser: null }; | ||||
|     terminalConstructor.prototype.zmodemAttach = zmodemAttach; | ||||
|     terminalConstructor.prototype.zmodemBrowser = zmodem.Browser; | ||||
| } | ||||
| exports.apply = apply; | ||||
|  | ||||
| },{}]},{},[1])(1) | ||||
| }); | ||||
| //# sourceMappingURL=zmodem.js.map | ||||
							
								
								
									
										1
									
								
								public/js/addons/zmodem/zmodem.js.map
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								public/js/addons/zmodem/zmodem.js.map
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1 @@ | ||||
| {"version":3,"file":"zmodem.js","sources":["../../../src/addons/zmodem/zmodem.ts","../../../node_modules/browser-pack/_prelude.js"],"sourcesContent":["/**\n * Copyright (c) 2017 The xterm.js authors. All rights reserved.\n * @license MIT\n */\n\nimport { Terminal } from 'xterm';\n\n/**\n *\n * Allow xterm.js to handle ZMODEM uploads and downloads.\n *\n * This addon is a wrapper around zmodem.js. It adds the following to the\n *  Terminal class:\n *\n * - function `zmodemAttach(<WebSocket>, <Object>)` - creates a Zmodem.Sentry\n *      on the passed WebSocket object. The Object passed is optional and\n *      can contain:\n *          - noTerminalWriteOutsideSession: Suppress writes from the Sentry\n *            object to the Terminal while there is no active Session. This\n *            is necessary for compatibility with, for example, the\n *            `attach.js` addon.\n *\n * - event `zmodemDetect` - fired on Zmodem.Sentry’s `on_detect` callback.\n *      Passes the zmodem.js Detection object.\n *\n * - event `zmodemRetract` - fired on Zmodem.Sentry’s `on_retract` callback.\n *\n * You’ll need to provide logic to handle uploads and downloads.\n * See zmodem.js’s documentation for more details.\n *\n * **IMPORTANT:** After you confirm() a zmodem.js Detection, if you have\n *  used the `attach` or `terminado` addons, you’ll need to suspend their\n *  operation for the duration of the ZMODEM session. (The demo does this\n *  via `detach()` and a re-`attach()`.)\n */\n\nlet zmodem: any;\n\nexport interface IZmodemOptions {\n  noTerminalWriteOutsideSession?: boolean;\n}\n\nfunction zmodemAttach(ws: WebSocket, opts: IZmodemOptions = {}): void {\n  const term = this;\n  const senderFunc = (octets: ArrayLike<number>) => ws.send(new Uint8Array(octets));\n\n  let zsentry: any;\n\n  function shouldWrite(): boolean {\n    return !!zsentry.get_confirmed_session() || !opts.noTerminalWriteOutsideSession;\n  }\n\n  zsentry = new zmodem.Sentry({\n    to_terminal: (octets: ArrayLike<number>) => {\n      if (shouldWrite()) {\n        term.write(\n          String.fromCharCode.apply(String, octets)\n        );\n      }\n    },\n    sender: senderFunc,\n    on_retract: () => (<any>term).emit('zmodemRetract'),\n    on_detect: (detection: any) => (<any>term).emit('zmodemDetect', detection)\n  });\n\n  function handleWSMessage(evt: MessageEvent): void {\n\n    // In testing with xterm.js’s demo the first message was\n    // always text even if the rest were binary. While that\n    // may be specific to xterm.js’s demo, ultimately we\n    // should reject anything that isn’t binary.\n    if (typeof evt.data === 'string') {\n      if (shouldWrite()) {\n        term.write(evt.data);\n      }\n    }\n    else {\n      zsentry.consume(evt.data);\n    }\n  }\n\n  ws.binaryType = 'arraybuffer';\n  ws.addEventListener('message', handleWSMessage);\n}\n\nexport function apply(terminalConstructor: typeof Terminal): void {\n  zmodem = (typeof window === 'object') ? (<any>window).Zmodem : {Browser: null};  // Nullify browser for tests\n\n  (<any>terminalConstructor.prototype).zmodemAttach = zmodemAttach;\n  (<any>terminalConstructor.prototype).zmodemBrowser = zmodem.Browser;\n}\n",null],"names":[],"mappings":"ACAA;;;ADoCA;AAMA;AAAA;AACA;AACA;AAEA;AAEA;AACA;AACA;AAEA;AACA;AACA;AACA;AAGA;AACA;AACA;AACA;AACA;AACA;AAEA;AAMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA;AACA;AACA;AAEA;AACA;AAEA;AACA;AACA;AALA;"} | ||||
							
								
								
									
										187
									
								
								public/js/jsonToTable.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										187
									
								
								public/js/jsonToTable.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,187 @@ | ||||
| /* eslint-disable no-extend-native */ | ||||
| // https://github.com/afshinm/Json-to-HTML-Table/blob/master/json-to-table.js | ||||
| /** | ||||
|  * JavaScript format string function | ||||
|  * | ||||
|  */ | ||||
| String.prototype.format = function () { | ||||
|   var args = arguments | ||||
|   return this.replace(/{(\d+)}/g, function (match, number) { | ||||
|     return typeof args[number] !== 'undefined' ? args[number] | ||||
|       : '{' + number + '}' | ||||
|   }) | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Return just the keys from the input array, optionally only for the specified search_value | ||||
|  * version: 1109.2015 | ||||
|  *  discuss at: http://phpjs.org/functions/arrayKeys | ||||
|  *  +   original by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||||
|  *  +      input by: Brett Zamir (http://brett-zamir.me) | ||||
|  *  +   bugfixed by: Kevin van Zonneveld (http://kevin.vanzonneveld.net) | ||||
|  *  +   improved by: jd | ||||
|  *  +   improved by: Brett Zamir (http://brett-zamir.me) | ||||
|  *  +   input by: P | ||||
|  *  +   bugfixed by: Brett Zamir (http://brett-zamir.me) | ||||
|  *  *     example 1: arrayKeys( {firstname: 'Kevin', surname: 'van Zonneveld'} ); | ||||
|  *  *     returns 1: {0: 'firstname', 1: 'surname'} | ||||
|  */ | ||||
| const arrayKeys = (input, searchValue, argStrict) => { | ||||
|   var search = typeof searchValue !== 'undefined' | ||||
|   var tmpArr = [] | ||||
|   var strict = !!argStrict | ||||
|   var include = true | ||||
|   var key = '' | ||||
|  | ||||
|   if (input && typeof input === 'object' && input.change_key_case) { // Duck-type check for our own array()-created PHPJS_Array | ||||
|     return input.keys(searchValue, argStrict) | ||||
|   } | ||||
|  | ||||
|   for (key in input) { | ||||
|     if (input.hasOwnProperty(key)) { | ||||
|       include = true | ||||
|       if (search) { | ||||
|         if (strict && input[key] !== searchValue) { | ||||
|           include = false | ||||
|         } else if (input[key] !== searchValue) { | ||||
|           include = false | ||||
|         } | ||||
|       } | ||||
|       if (include) { | ||||
|         tmpArr[tmpArr.length] = key | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   return tmpArr | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Convert a Javascript Oject array or String array to an HTML table | ||||
|  * JSON parsing has to be made before function call | ||||
|  * It allows use of other JSON parsing methods like jQuery.parseJSON | ||||
|  * http(s)://, ftp://, file:// and javascript:; links are automatically computed | ||||
|  * | ||||
|  * JSON data samples that should be parsed and then can be converted to an HTML table | ||||
|  *     var objectArray = '[{"Total":"34","Version":"1.0.4","Office":"New York"},{"Total":"67","Version":"1.1.0","Office":"Paris"}]'; | ||||
|  *     var stringArray = '["New York","Berlin","Paris","Marrakech","Moscow"]'; | ||||
|  *     var nestedTable = '[{ key1: "val1", key2: "val2", key3: { tableId: "tblIdNested1", tableClassName: "clsNested", linkText: "Download", data: [{ subkey1: "subval1", subkey2: "subval2", subkey3: "subval3" }] } }]'; | ||||
|  * | ||||
|  * Code sample to create a HTML table Javascript String | ||||
|  *     var jsonHtmlTable = ConvertJsonToTable(eval(dataString), 'jsonTable', null, 'Download'); | ||||
|  * | ||||
|  * Code sample explaned | ||||
|  *  - eval is used to parse a JSON dataString | ||||
|  *  - table HTML id attribute will be 'jsonTable' | ||||
|  *  - table HTML class attribute will not be added | ||||
|  *  - 'Download' text will be displayed instead of the link itself | ||||
|  * | ||||
|  * @author Afshin Mehrabani <afshin dot meh at gmail dot com> | ||||
|  * | ||||
|  * @class ConvertJsonToTable | ||||
|  * | ||||
|  * @method ConvertJsonToTable | ||||
|  * | ||||
|  * @param parsedJson object Parsed JSON data | ||||
|  * @param tableId string Optional table id | ||||
|  * @param tableClassName string Optional table css class name | ||||
|  * @param linkText string Optional text replacement for link pattern | ||||
|  * | ||||
|  * @return string Converted JSON to HTML table | ||||
|  */ | ||||
|  | ||||
| const convertJsonToTable = (parsedJson, tableId, tableClassName, linkText) => { | ||||
|   // Patterns for links and NULL value | ||||
|   let italic = '<i>{0}</i>' | ||||
|   let link = linkText ? '<a href="{0}">' + linkText + '</a>' | ||||
|     : '<a href="{0}">{0}</a>' | ||||
|   let log = '<a href="javascript:showLog(\'{0}\')">{0}</a>' | ||||
|  | ||||
|   // Pattern for table | ||||
|   let idMarkup = tableId ? ' id="' + tableId + '"' | ||||
|     : '' | ||||
|  | ||||
|   let classMarkup = tableClassName ? ' class="' + tableClassName + '"' | ||||
|     : '' | ||||
|  | ||||
|   let tbl = '<table border="1" cellpadding="1" cellspacing="1"' + idMarkup + classMarkup + '>{0}{1}</table>' | ||||
|  | ||||
|   // Patterns for table content | ||||
|   let th = '<thead>{0}</thead>' | ||||
|   let tb = '<tbody>{0}</tbody>' | ||||
|   let tr = '<tr>{0}</tr>' | ||||
|   let thRow = '<th>{0}</th>' | ||||
|   let tdRow = '<td>{0}</td>' | ||||
|   let thCon = '' | ||||
|   let tbCon = '' | ||||
|   let trCon = '' | ||||
|  | ||||
|   if (parsedJson) { | ||||
|     let isStringArray = typeof (parsedJson[0]) === 'string' | ||||
|     let headers | ||||
|  | ||||
|     // Create table headers from JSON data | ||||
|     // If JSON data is a simple string array we create a single table header | ||||
|     if (isStringArray) { | ||||
|       thCon += thRow.format('value') | ||||
|     } else { | ||||
|       // If JSON data is an object array, headers are automatically computed | ||||
|       if (typeof (parsedJson[0]) === 'object') { | ||||
|         headers = arrayKeys(parsedJson[0]) | ||||
|  | ||||
|         for (let i = 0; i < headers.length; i++) { | ||||
|           thCon += thRow.format(headers[i]) | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     th = th.format(tr.format(thCon)) | ||||
|  | ||||
|     // Create table rows from Json data | ||||
|     if (isStringArray) { | ||||
|       for (let i = 0; i < parsedJson.length; i++) { | ||||
|         tbCon += tdRow.format(parsedJson[i]) | ||||
|         trCon += tr.format(tbCon) | ||||
|         tbCon = '' | ||||
|       } | ||||
|     } else { | ||||
|       if (headers) { | ||||
|         let urlRegExp = new RegExp(/(\b(https?|ftp|file):\/\/[-A-Z0-9+&@#\/%?=~_|!:,.;]*[-A-Z0-9+&@#\/%=~_|])/ig) // eslint-disable-line | ||||
|         let javascriptRegExp = new RegExp(/(^javascript:[\s\S]*;$)/ig) | ||||
|         let logRegExp = new RegExp(/(.log$)/ig) | ||||
|  | ||||
|         for (let i = 0; i < parsedJson.length; i++) { | ||||
|           for (let j = 0; j < headers.length; j++) { | ||||
|             let value = parsedJson[i][headers[j]] | ||||
|             let isUrl = urlRegExp.test(value) || javascriptRegExp.test(value) | ||||
|             let isLog = logRegExp.test(value) | ||||
|  | ||||
|             if (isUrl) { // If value is URL we auto-create a link | ||||
|               tbCon += tdRow.format(link.format(value)) | ||||
|             } else if (isLog) { | ||||
|               tbCon += tdRow.format(log.format(value)) | ||||
|             } else { | ||||
|               if (value) { | ||||
|                 if (typeof (value) === 'object') { | ||||
|                   // for supporting nested tables | ||||
|                   tbCon += tdRow.format(convertJsonToTable(eval(value.data), value.tableId, value.tableClassName, value.linkText)) // eslint-disable-line | ||||
|                 } else { | ||||
|                   tbCon += tdRow.format(value) | ||||
|                 } | ||||
|               } else { // If value == null we format it like PhpMyAdmin NULL values | ||||
|                 tbCon += tdRow.format(italic.format(value).toUpperCase()) | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|           trCon += tr.format(tbCon) | ||||
|           tbCon = '' | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     tb = tb.format(trCon) | ||||
|     tbl = tbl.format(th, tb) | ||||
|  | ||||
|     return tbl | ||||
|   } | ||||
|   return null | ||||
| } | ||||
|  | ||||
| window.convertJsonToTable = convertJsonToTable | ||||
							
								
								
									
										252
									
								
								public/js/main.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										252
									
								
								public/js/main.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,252 @@ | ||||
| window.onload = function () { | ||||
|   let buildType = null; | ||||
|   Terminal.applyAddon(attach); | ||||
|   Terminal.applyAddon(fit); | ||||
|   const term = new Terminal({ | ||||
|     useStyle: true, | ||||
|     convertEol: true, | ||||
|     screenKeys: true, | ||||
|     cursorBlink: false, | ||||
|     visualBell: true, | ||||
|     colors: Terminal.xtermColors | ||||
|   }); | ||||
|   window.term = term; | ||||
|   const terminalDom = document.getElementById('terminal'); | ||||
|   const socket = io(); | ||||
|  | ||||
|   // 对Date的扩展,将 Date 转化为指定格式的String | ||||
|   // 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符, | ||||
|   // 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字) | ||||
|   // 例子: | ||||
|   // (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423 | ||||
|   // (new Date()).Format("yyyy-M-d h:m:s.S")      ==> 2006-7-2 8:9:4.18 | ||||
|   Date.prototype.Format = function (fmt) { //author: meizz | ||||
|     var o = {    | ||||
|       "M+" : this.getMonth()+1,                 //月份 | ||||
|       "d+" : this.getDate(),                    //日 | ||||
|       "h+" : this.getHours(),                   //小时 | ||||
|       "m+" : this.getMinutes(),                 //分 | ||||
|       "s+" : this.getSeconds(),                 //秒 | ||||
|       "q+" : Math.floor((this.getMonth()+3)/3), //季度 | ||||
|       "S"  : this.getMilliseconds()             //毫秒 | ||||
|     };    | ||||
|     if(/(y+)/.test(fmt))    | ||||
|       fmt=fmt.replace(RegExp.$1, (this.getFullYear()+"").substr(4 - RegExp.$1.length));    | ||||
|     for(var k in o)    | ||||
|       if(new RegExp("("+ k +")").test(fmt))    | ||||
|     fmt = fmt.replace(RegExp.$1, (RegExp.$1.length==1) ? (o[k]) : (("00"+ o[k]).substr((""+ o[k]).length)));    | ||||
|     return fmt;    | ||||
|   } | ||||
|  | ||||
|   const checkToken = () => { | ||||
|     if (window.localStorage.token) { | ||||
|       document.querySelector('#no-auth').style.display = 'none'; | ||||
|       document.querySelector('#auth').style.display = 'block'; | ||||
|       return true; | ||||
|     } else { | ||||
|       document.querySelector('#no-auth').style.display = 'block'; | ||||
|       document.querySelector('#auth').style.display = 'none'; | ||||
|       return false; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   const dockerInitailize = () => { | ||||
|     socket.emit('pull', 'win'); | ||||
|     socket.emit('pull', 'linux'); | ||||
|     term.on('data', (data) => { | ||||
|       socket.emit('cmd', data); | ||||
|     }) | ||||
|   } | ||||
|  | ||||
|   const showLog = (path) => { | ||||
|     term.clear(); | ||||
|     term.writeln('Loading...'); | ||||
|     socket.emit('log', encodeURI(path)); | ||||
|   } | ||||
|  | ||||
|   const getHash = () => { | ||||
|     try { | ||||
|       const shaObj = new jsSHA("SHA-512", "TEXT"); | ||||
|       shaObj.update(window.localStorage.token); | ||||
|       return shaObj.getHash("HEX"); | ||||
|     } catch (err) { | ||||
|       console.error(err); | ||||
|       alert(err.toString()); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   const checkAuth = async () => { | ||||
|     try { | ||||
|       const hash = getHash(); | ||||
|       const response = await fetch('/app/auth?token=' + hash); | ||||
|       const data = await response.json(); | ||||
|       if (data.status === 1) { | ||||
|         buildType = data.result.buildType; | ||||
|         if (!buildType.includes('linux')) document.getElementById('buildLinuxBtn').style.display = 'none'; | ||||
|         if (!buildType.includes('win')) document.getElementById('buildWindowsBtn').style.display = 'none'; | ||||
|         if (!buildType.includes('mac')) document.getElementById('buildMacBtn').style.display = 'none'; | ||||
|       } else { | ||||
|         alert(data.msg); | ||||
|         window.localStorage.removeItem('token'); | ||||
|         window.location.reload(); | ||||
|         return false; | ||||
|       } | ||||
|  | ||||
|       socket.on('requireAuth', (data) => { | ||||
|         if (data === 'distribution') { | ||||
|           socket.emit('auth', hash); | ||||
|         } | ||||
|       }) | ||||
|  | ||||
|       socket.on('auth', (data) => { | ||||
|         if (data === 'success') { | ||||
|           term.clear(); | ||||
|           term.write('Welcome \x1B[1;3;31mElectron Distribution\x1B[0m ! \n'); | ||||
|         } else { | ||||
|           term.clear(); | ||||
|           term.write('Auth fail. \n'); | ||||
|         } | ||||
|       }) | ||||
|  | ||||
|       return true; | ||||
|     } catch (e) { | ||||
|       console.error(e); | ||||
|       alert('Network Error.'); | ||||
|       return false; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   const gitPull = () => { | ||||
|     socket.emit('gitPull', ''); | ||||
|   } | ||||
|  | ||||
|   const buildApp = async (type) => { | ||||
|     document.getElementById('table').innerHTML = ''; | ||||
|     term.clear(); | ||||
|     term.writeln('Loading...'); | ||||
|  | ||||
|     try { | ||||
|       const hash = getHash(); | ||||
|       const response = await fetch('/build/' + type + '?token=' + hash); | ||||
|       const data = await response.json(); | ||||
|       if (data.status === 1) { | ||||
|         term.clear(); | ||||
|         term.write('Runing yarn... \n'); | ||||
|         socket.emit('logs', data.result); | ||||
|       } else { | ||||
|         alert(data.msg); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       console.error(e); | ||||
|       alert('Network Error.'); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   const getLocalTime = (nS) => {      | ||||
|     return new Date(Number(nS)).Format("yyyy-MM-dd hh:mm:ss"); | ||||
|   } | ||||
|  | ||||
|   const getList = async (type) => { | ||||
|     try { | ||||
|       const hash = getHash(); | ||||
|       const response = await fetch('/app/list/' + type + '?token=' + hash); | ||||
|       const data = await response.json(); | ||||
|       if (data.status === 1) { | ||||
|         if (data.result.list && data.result.list.length) { | ||||
|           for (const n in data.result.list) { | ||||
|             if (data.result.list[n].startDate) { | ||||
|               data.result.list[n].startDate = getLocalTime(data.result.list[n].startDate) | ||||
|             } else if (data.result.list[n].releaseDate) { | ||||
|               data.result.list[n].releaseDate = getLocalTime(data.result.list[n].releaseDate) | ||||
|             } | ||||
|           } | ||||
|           document.getElementById('table').innerHTML = convertJsonToTable(data.result.list); | ||||
|         } else { | ||||
|           document.getElementById('table').innerHTML = 'No data.'; | ||||
|         } | ||||
|       } else { | ||||
|         alert(data.msg); | ||||
|       } | ||||
|     } catch (e) { | ||||
|       console.error(e); | ||||
|       alert('Network Error.'); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   const init = async () => { | ||||
|     if (!checkToken()) return; | ||||
|  | ||||
|     if (!(await checkAuth())) return; | ||||
|  | ||||
|     window.showLog = showLog; | ||||
|  | ||||
|     socket.on('show', (data) => { | ||||
|       term.write(data); | ||||
|     }) | ||||
|  | ||||
|     socket.on('progress', (data) => { | ||||
|       term.clear(); | ||||
|       term.write(data); | ||||
|     }) | ||||
|  | ||||
|     socket.on('end', (data) => { | ||||
|       term.write(data); | ||||
|     }) | ||||
|  | ||||
|     socket.on('err', (data) => { | ||||
|       term.write(data); | ||||
|     }) | ||||
|  | ||||
|     term.open(terminalDom); | ||||
|     term.fit(); | ||||
|     term.write('Verifying... Please wait ...\n'); | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#tokenInput').onkeyup = function (e) { | ||||
|     if (e && e.keyCode == 13) { | ||||
|       window.localStorage.token = document.querySelector('#tokenInput').value; | ||||
|       window.location.reload(); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#logoutBtn').onclick = function () { | ||||
|     window.localStorage.removeItem('token'); | ||||
|     window.location.reload(); | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#listReleaseBtn').onclick = function () { | ||||
|     getList('release') | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#listBuildBtn').onclick = function () { | ||||
|     getList('build') | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#dockerInitBtn').onclick = function () { | ||||
|     document.getElementById('table').innerHTML = ''; | ||||
|     term.clear(); | ||||
|     term.writeln('Loading...'); | ||||
|     dockerInitailize(); | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#gitPullBtn').onclick = function () { | ||||
|     document.getElementById('table').innerHTML = ''; | ||||
|     term.clear(); | ||||
|     term.writeln('Loading...'); | ||||
|     gitPull(); | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#buildLinuxBtn').onclick = function () { | ||||
|     buildApp('linux'); | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#buildWindowsBtn').onclick = function () { | ||||
|     buildApp('win'); | ||||
|   } | ||||
|  | ||||
|   document.querySelector('#buildMacBtn').onclick = function () { | ||||
|     buildApp('mac'); | ||||
|   } | ||||
|  | ||||
|   init(); | ||||
| } | ||||
							
								
								
									
										42
									
								
								public/js/sha.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								public/js/sha.js
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,42 @@ | ||||
| /* | ||||
|  A JavaScript implementation of the SHA family of hashes, as | ||||
|  defined in FIPS PUB 180-4 and FIPS PUB 202, as well as the corresponding | ||||
|  HMAC implementation as defined in FIPS PUB 198a | ||||
|  Copyright 2008-2018 Brian Turek, 1998-2009 Paul Johnston & Contributors | ||||
|  Distributed under the BSD License | ||||
|  See http://caligatio.github.com/jsSHA/ for more information | ||||
| */ | ||||
| 'use strict';(function(Y){function C(c,a,b){var e=0,h=[],n=0,g,l,d,f,m,q,u,r,I=!1,v=[],w=[],t,y=!1,z=!1,x=-1;b=b||{};g=b.encoding||"UTF8";t=b.numRounds||1;if(t!==parseInt(t,10)||1>t)throw Error("numRounds must a integer >= 1");if("SHA-1"===c)m=512,q=K,u=Z,f=160,r=function(a){return a.slice()};else if(0===c.lastIndexOf("SHA-",0))if(q=function(a,b){return L(a,b,c)},u=function(a,b,h,e){var k,f;if("SHA-224"===c||"SHA-256"===c)k=(b+65>>>9<<4)+15,f=16;else if("SHA-384"===c||"SHA-512"===c)k=(b+129>>>10<< | ||||
|   5)+31,f=32;else throw Error("Unexpected error in SHA-2 implementation");for(;a.length<=k;)a.push(0);a[b>>>5]|=128<<24-b%32;b=b+h;a[k]=b&4294967295;a[k-1]=b/4294967296|0;h=a.length;for(b=0;b<h;b+=f)e=L(a.slice(b,b+f),e,c);if("SHA-224"===c)a=[e[0],e[1],e[2],e[3],e[4],e[5],e[6]];else if("SHA-256"===c)a=e;else if("SHA-384"===c)a=[e[0].a,e[0].b,e[1].a,e[1].b,e[2].a,e[2].b,e[3].a,e[3].b,e[4].a,e[4].b,e[5].a,e[5].b];else if("SHA-512"===c)a=[e[0].a,e[0].b,e[1].a,e[1].b,e[2].a,e[2].b,e[3].a,e[3].b,e[4].a, | ||||
|   e[4].b,e[5].a,e[5].b,e[6].a,e[6].b,e[7].a,e[7].b];else throw Error("Unexpected error in SHA-2 implementation");return a},r=function(a){return a.slice()},"SHA-224"===c)m=512,f=224;else if("SHA-256"===c)m=512,f=256;else if("SHA-384"===c)m=1024,f=384;else if("SHA-512"===c)m=1024,f=512;else throw Error("Chosen SHA variant is not supported");else if(0===c.lastIndexOf("SHA3-",0)||0===c.lastIndexOf("SHAKE",0)){var F=6;q=D;r=function(a){var c=[],e;for(e=0;5>e;e+=1)c[e]=a[e].slice();return c};x=1;if("SHA3-224"=== | ||||
|   c)m=1152,f=224;else if("SHA3-256"===c)m=1088,f=256;else if("SHA3-384"===c)m=832,f=384;else if("SHA3-512"===c)m=576,f=512;else if("SHAKE128"===c)m=1344,f=-1,F=31,z=!0;else if("SHAKE256"===c)m=1088,f=-1,F=31,z=!0;else throw Error("Chosen SHA variant is not supported");u=function(a,c,e,b,h){e=m;var k=F,f,g=[],n=e>>>5,l=0,d=c>>>5;for(f=0;f<d&&c>=e;f+=n)b=D(a.slice(f,f+n),b),c-=e;a=a.slice(f);for(c%=e;a.length<n;)a.push(0);f=c>>>3;a[f>>2]^=k<<f%4*8;a[n-1]^=2147483648;for(b=D(a,b);32*g.length<h;){a=b[l% | ||||
|   5][l/5|0];g.push(a.b);if(32*g.length>=h)break;g.push(a.a);l+=1;0===64*l%e&&D(null,b)}return g}}else throw Error("Chosen SHA variant is not supported");d=M(a,g,x);l=A(c);this.setHMACKey=function(a,b,h){var k;if(!0===I)throw Error("HMAC key already set");if(!0===y)throw Error("Cannot set HMAC key after calling update");if(!0===z)throw Error("SHAKE is not supported for HMAC");g=(h||{}).encoding||"UTF8";b=M(b,g,x)(a);a=b.binLen;b=b.value;k=m>>>3;h=k/4-1;if(k<a/8){for(b=u(b,a,0,A(c),f);b.length<=h;)b.push(0); | ||||
|   b[h]&=4294967040}else if(k>a/8){for(;b.length<=h;)b.push(0);b[h]&=4294967040}for(a=0;a<=h;a+=1)v[a]=b[a]^909522486,w[a]=b[a]^1549556828;l=q(v,l);e=m;I=!0};this.update=function(a){var c,b,k,f=0,g=m>>>5;c=d(a,h,n);a=c.binLen;b=c.value;c=a>>>5;for(k=0;k<c;k+=g)f+m<=a&&(l=q(b.slice(k,k+g),l),f+=m);e+=f;h=b.slice(f>>>5);n=a%m;y=!0};this.getHash=function(a,b){var k,g,d,m;if(!0===I)throw Error("Cannot call getHash after setting HMAC key");d=N(b);if(!0===z){if(-1===d.shakeLen)throw Error("shakeLen must be specified in options"); | ||||
|   f=d.shakeLen}switch(a){case "HEX":k=function(a){return O(a,f,x,d)};break;case "B64":k=function(a){return P(a,f,x,d)};break;case "BYTES":k=function(a){return Q(a,f,x)};break;case "ARRAYBUFFER":try{g=new ArrayBuffer(0)}catch(p){throw Error("ARRAYBUFFER not supported by this environment");}k=function(a){return R(a,f,x)};break;default:throw Error("format must be HEX, B64, BYTES, or ARRAYBUFFER");}m=u(h.slice(),n,e,r(l),f);for(g=1;g<t;g+=1)!0===z&&0!==f%32&&(m[m.length-1]&=16777215>>>24-f%32),m=u(m,f, | ||||
|   0,A(c),f);return k(m)};this.getHMAC=function(a,b){var k,g,d,p;if(!1===I)throw Error("Cannot call getHMAC without first setting HMAC key");d=N(b);switch(a){case "HEX":k=function(a){return O(a,f,x,d)};break;case "B64":k=function(a){return P(a,f,x,d)};break;case "BYTES":k=function(a){return Q(a,f,x)};break;case "ARRAYBUFFER":try{k=new ArrayBuffer(0)}catch(v){throw Error("ARRAYBUFFER not supported by this environment");}k=function(a){return R(a,f,x)};break;default:throw Error("outputFormat must be HEX, B64, BYTES, or ARRAYBUFFER"); | ||||
|   }g=u(h.slice(),n,e,r(l),f);p=q(w,A(c));p=u(g,f,m,p,f);return k(p)}}function b(c,a){this.a=c;this.b=a}function O(c,a,b,e){var h="";a/=8;var n,g,d;d=-1===b?3:0;for(n=0;n<a;n+=1)g=c[n>>>2]>>>8*(d+n%4*b),h+="0123456789abcdef".charAt(g>>>4&15)+"0123456789abcdef".charAt(g&15);return e.outputUpper?h.toUpperCase():h}function P(c,a,b,e){var h="",n=a/8,g,d,p,f;f=-1===b?3:0;for(g=0;g<n;g+=3)for(d=g+1<n?c[g+1>>>2]:0,p=g+2<n?c[g+2>>>2]:0,p=(c[g>>>2]>>>8*(f+g%4*b)&255)<<16|(d>>>8*(f+(g+1)%4*b)&255)<<8|p>>>8*(f+ | ||||
|   (g+2)%4*b)&255,d=0;4>d;d+=1)8*g+6*d<=a?h+="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".charAt(p>>>6*(3-d)&63):h+=e.b64Pad;return h}function Q(c,a,b){var e="";a/=8;var h,d,g;g=-1===b?3:0;for(h=0;h<a;h+=1)d=c[h>>>2]>>>8*(g+h%4*b)&255,e+=String.fromCharCode(d);return e}function R(c,a,b){a/=8;var e,h=new ArrayBuffer(a),d,g;g=new Uint8Array(h);d=-1===b?3:0;for(e=0;e<a;e+=1)g[e]=c[e>>>2]>>>8*(d+e%4*b)&255;return h}function N(c){var a={outputUpper:!1,b64Pad:"=",shakeLen:-1};c=c||{}; | ||||
|   a.outputUpper=c.outputUpper||!1;!0===c.hasOwnProperty("b64Pad")&&(a.b64Pad=c.b64Pad);if(!0===c.hasOwnProperty("shakeLen")){if(0!==c.shakeLen%8)throw Error("shakeLen must be a multiple of 8");a.shakeLen=c.shakeLen}if("boolean"!==typeof a.outputUpper)throw Error("Invalid outputUpper formatting option");if("string"!==typeof a.b64Pad)throw Error("Invalid b64Pad formatting option");return a}function M(c,a,b){switch(a){case "UTF8":case "UTF16BE":case "UTF16LE":break;default:throw Error("encoding must be UTF8, UTF16BE, or UTF16LE"); | ||||
|   }switch(c){case "HEX":c=function(a,c,d){var g=a.length,l,p,f,m,q,u;if(0!==g%2)throw Error("String of HEX type must be in byte increments");c=c||[0];d=d||0;q=d>>>3;u=-1===b?3:0;for(l=0;l<g;l+=2){p=parseInt(a.substr(l,2),16);if(isNaN(p))throw Error("String of HEX type contains invalid characters");m=(l>>>1)+q;for(f=m>>>2;c.length<=f;)c.push(0);c[f]|=p<<8*(u+m%4*b)}return{value:c,binLen:4*g+d}};break;case "TEXT":c=function(c,h,d){var g,l,p=0,f,m,q,u,r,t;h=h||[0];d=d||0;q=d>>>3;if("UTF8"===a)for(t=-1=== | ||||
|   b?3:0,f=0;f<c.length;f+=1)for(g=c.charCodeAt(f),l=[],128>g?l.push(g):2048>g?(l.push(192|g>>>6),l.push(128|g&63)):55296>g||57344<=g?l.push(224|g>>>12,128|g>>>6&63,128|g&63):(f+=1,g=65536+((g&1023)<<10|c.charCodeAt(f)&1023),l.push(240|g>>>18,128|g>>>12&63,128|g>>>6&63,128|g&63)),m=0;m<l.length;m+=1){r=p+q;for(u=r>>>2;h.length<=u;)h.push(0);h[u]|=l[m]<<8*(t+r%4*b);p+=1}else if("UTF16BE"===a||"UTF16LE"===a)for(t=-1===b?2:0,l="UTF16LE"===a&&1!==b||"UTF16LE"!==a&&1===b,f=0;f<c.length;f+=1){g=c.charCodeAt(f); | ||||
|   !0===l&&(m=g&255,g=m<<8|g>>>8);r=p+q;for(u=r>>>2;h.length<=u;)h.push(0);h[u]|=g<<8*(t+r%4*b);p+=2}return{value:h,binLen:8*p+d}};break;case "B64":c=function(a,c,d){var g=0,l,p,f,m,q,u,r,t;if(-1===a.search(/^[a-zA-Z0-9=+\/]+$/))throw Error("Invalid character in base-64 string");p=a.indexOf("=");a=a.replace(/\=/g,"");if(-1!==p&&p<a.length)throw Error("Invalid '=' found in base-64 string");c=c||[0];d=d||0;u=d>>>3;t=-1===b?3:0;for(p=0;p<a.length;p+=4){q=a.substr(p,4);for(f=m=0;f<q.length;f+=1)l="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".indexOf(q[f]), | ||||
|   m|=l<<18-6*f;for(f=0;f<q.length-1;f+=1){r=g+u;for(l=r>>>2;c.length<=l;)c.push(0);c[l]|=(m>>>16-8*f&255)<<8*(t+r%4*b);g+=1}}return{value:c,binLen:8*g+d}};break;case "BYTES":c=function(a,c,d){var g,l,p,f,m,q;c=c||[0];d=d||0;p=d>>>3;q=-1===b?3:0;for(l=0;l<a.length;l+=1)g=a.charCodeAt(l),m=l+p,f=m>>>2,c.length<=f&&c.push(0),c[f]|=g<<8*(q+m%4*b);return{value:c,binLen:8*a.length+d}};break;case "ARRAYBUFFER":try{c=new ArrayBuffer(0)}catch(e){throw Error("ARRAYBUFFER not supported by this environment");}c= | ||||
|   function(a,c,d){var g,l,p,f,m,q;c=c||[0];d=d||0;l=d>>>3;m=-1===b?3:0;q=new Uint8Array(a);for(g=0;g<a.byteLength;g+=1)f=g+l,p=f>>>2,c.length<=p&&c.push(0),c[p]|=q[g]<<8*(m+f%4*b);return{value:c,binLen:8*a.byteLength+d}};break;default:throw Error("format must be HEX, TEXT, B64, BYTES, or ARRAYBUFFER");}return c}function y(c,a){return c<<a|c>>>32-a}function S(c,a){return 32<a?(a-=32,new b(c.b<<a|c.a>>>32-a,c.a<<a|c.b>>>32-a)):0!==a?new b(c.a<<a|c.b>>>32-a,c.b<<a|c.a>>>32-a):c}function w(c,a){return c>>> | ||||
|   a|c<<32-a}function t(c,a){var k=null,k=new b(c.a,c.b);return k=32>=a?new b(k.a>>>a|k.b<<32-a&4294967295,k.b>>>a|k.a<<32-a&4294967295):new b(k.b>>>a-32|k.a<<64-a&4294967295,k.a>>>a-32|k.b<<64-a&4294967295)}function T(c,a){var k=null;return k=32>=a?new b(c.a>>>a,c.b>>>a|c.a<<32-a&4294967295):new b(0,c.a>>>a-32)}function aa(c,a,b){return c&a^~c&b}function ba(c,a,k){return new b(c.a&a.a^~c.a&k.a,c.b&a.b^~c.b&k.b)}function U(c,a,b){return c&a^c&b^a&b}function ca(c,a,k){return new b(c.a&a.a^c.a&k.a^a.a& | ||||
|   k.a,c.b&a.b^c.b&k.b^a.b&k.b)}function da(c){return w(c,2)^w(c,13)^w(c,22)}function ea(c){var a=t(c,28),k=t(c,34);c=t(c,39);return new b(a.a^k.a^c.a,a.b^k.b^c.b)}function fa(c){return w(c,6)^w(c,11)^w(c,25)}function ga(c){var a=t(c,14),k=t(c,18);c=t(c,41);return new b(a.a^k.a^c.a,a.b^k.b^c.b)}function ha(c){return w(c,7)^w(c,18)^c>>>3}function ia(c){var a=t(c,1),k=t(c,8);c=T(c,7);return new b(a.a^k.a^c.a,a.b^k.b^c.b)}function ja(c){return w(c,17)^w(c,19)^c>>>10}function ka(c){var a=t(c,19),k=t(c,61); | ||||
|   c=T(c,6);return new b(a.a^k.a^c.a,a.b^k.b^c.b)}function G(c,a){var b=(c&65535)+(a&65535);return((c>>>16)+(a>>>16)+(b>>>16)&65535)<<16|b&65535}function la(c,a,b,e){var h=(c&65535)+(a&65535)+(b&65535)+(e&65535);return((c>>>16)+(a>>>16)+(b>>>16)+(e>>>16)+(h>>>16)&65535)<<16|h&65535}function H(c,a,b,e,h){var d=(c&65535)+(a&65535)+(b&65535)+(e&65535)+(h&65535);return((c>>>16)+(a>>>16)+(b>>>16)+(e>>>16)+(h>>>16)+(d>>>16)&65535)<<16|d&65535}function ma(c,a){var d,e,h;d=(c.b&65535)+(a.b&65535);e=(c.b>>>16)+ | ||||
|   (a.b>>>16)+(d>>>16);h=(e&65535)<<16|d&65535;d=(c.a&65535)+(a.a&65535)+(e>>>16);e=(c.a>>>16)+(a.a>>>16)+(d>>>16);return new b((e&65535)<<16|d&65535,h)}function na(c,a,d,e){var h,n,g;h=(c.b&65535)+(a.b&65535)+(d.b&65535)+(e.b&65535);n=(c.b>>>16)+(a.b>>>16)+(d.b>>>16)+(e.b>>>16)+(h>>>16);g=(n&65535)<<16|h&65535;h=(c.a&65535)+(a.a&65535)+(d.a&65535)+(e.a&65535)+(n>>>16);n=(c.a>>>16)+(a.a>>>16)+(d.a>>>16)+(e.a>>>16)+(h>>>16);return new b((n&65535)<<16|h&65535,g)}function oa(c,a,d,e,h){var n,g,l;n=(c.b& | ||||
|   65535)+(a.b&65535)+(d.b&65535)+(e.b&65535)+(h.b&65535);g=(c.b>>>16)+(a.b>>>16)+(d.b>>>16)+(e.b>>>16)+(h.b>>>16)+(n>>>16);l=(g&65535)<<16|n&65535;n=(c.a&65535)+(a.a&65535)+(d.a&65535)+(e.a&65535)+(h.a&65535)+(g>>>16);g=(c.a>>>16)+(a.a>>>16)+(d.a>>>16)+(e.a>>>16)+(h.a>>>16)+(n>>>16);return new b((g&65535)<<16|n&65535,l)}function B(c,a){return new b(c.a^a.a,c.b^a.b)}function A(c){var a=[],d;if("SHA-1"===c)a=[1732584193,4023233417,2562383102,271733878,3285377520];else if(0===c.lastIndexOf("SHA-",0))switch(a= | ||||
|   [3238371032,914150663,812702999,4144912697,4290775857,1750603025,1694076839,3204075428],d=[1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225],c){case "SHA-224":break;case "SHA-256":a=d;break;case "SHA-384":a=[new b(3418070365,a[0]),new b(1654270250,a[1]),new b(2438529370,a[2]),new b(355462360,a[3]),new b(1731405415,a[4]),new b(41048885895,a[5]),new b(3675008525,a[6]),new b(1203062813,a[7])];break;case "SHA-512":a=[new b(d[0],4089235720),new b(d[1],2227873595), | ||||
|   new b(d[2],4271175723),new b(d[3],1595750129),new b(d[4],2917565137),new b(d[5],725511199),new b(d[6],4215389547),new b(d[7],327033209)];break;default:throw Error("Unknown SHA variant");}else if(0===c.lastIndexOf("SHA3-",0)||0===c.lastIndexOf("SHAKE",0))for(c=0;5>c;c+=1)a[c]=[new b(0,0),new b(0,0),new b(0,0),new b(0,0),new b(0,0)];else throw Error("No SHA variants supported");return a}function K(c,a){var b=[],e,d,n,g,l,p,f;e=a[0];d=a[1];n=a[2];g=a[3];l=a[4];for(f=0;80>f;f+=1)b[f]=16>f?c[f]:y(b[f- | ||||
|   3]^b[f-8]^b[f-14]^b[f-16],1),p=20>f?H(y(e,5),d&n^~d&g,l,1518500249,b[f]):40>f?H(y(e,5),d^n^g,l,1859775393,b[f]):60>f?H(y(e,5),U(d,n,g),l,2400959708,b[f]):H(y(e,5),d^n^g,l,3395469782,b[f]),l=g,g=n,n=y(d,30),d=e,e=p;a[0]=G(e,a[0]);a[1]=G(d,a[1]);a[2]=G(n,a[2]);a[3]=G(g,a[3]);a[4]=G(l,a[4]);return a}function Z(c,a,b,e){var d;for(d=(a+65>>>9<<4)+15;c.length<=d;)c.push(0);c[a>>>5]|=128<<24-a%32;a+=b;c[d]=a&4294967295;c[d-1]=a/4294967296|0;a=c.length;for(d=0;d<a;d+=16)e=K(c.slice(d,d+16),e);return e}function L(c, | ||||
|   a,k){var e,h,n,g,l,p,f,m,q,u,r,t,v,w,y,A,z,x,F,B,C,D,E=[],J;if("SHA-224"===k||"SHA-256"===k)u=64,t=1,D=Number,v=G,w=la,y=H,A=ha,z=ja,x=da,F=fa,C=U,B=aa,J=d;else if("SHA-384"===k||"SHA-512"===k)u=80,t=2,D=b,v=ma,w=na,y=oa,A=ia,z=ka,x=ea,F=ga,C=ca,B=ba,J=V;else throw Error("Unexpected error in SHA-2 implementation");k=a[0];e=a[1];h=a[2];n=a[3];g=a[4];l=a[5];p=a[6];f=a[7];for(r=0;r<u;r+=1)16>r?(q=r*t,m=c.length<=q?0:c[q],q=c.length<=q+1?0:c[q+1],E[r]=new D(m,q)):E[r]=w(z(E[r-2]),E[r-7],A(E[r-15]),E[r- | ||||
|   16]),m=y(f,F(g),B(g,l,p),J[r],E[r]),q=v(x(k),C(k,e,h)),f=p,p=l,l=g,g=v(n,m),n=h,h=e,e=k,k=v(m,q);a[0]=v(k,a[0]);a[1]=v(e,a[1]);a[2]=v(h,a[2]);a[3]=v(n,a[3]);a[4]=v(g,a[4]);a[5]=v(l,a[5]);a[6]=v(p,a[6]);a[7]=v(f,a[7]);return a}function D(c,a){var d,e,h,n,g=[],l=[];if(null!==c)for(e=0;e<c.length;e+=2)a[(e>>>1)%5][(e>>>1)/5|0]=B(a[(e>>>1)%5][(e>>>1)/5|0],new b(c[e+1],c[e]));for(d=0;24>d;d+=1){n=A("SHA3-");for(e=0;5>e;e+=1){h=a[e][0];var p=a[e][1],f=a[e][2],m=a[e][3],q=a[e][4];g[e]=new b(h.a^p.a^f.a^ | ||||
|   m.a^q.a,h.b^p.b^f.b^m.b^q.b)}for(e=0;5>e;e+=1)l[e]=B(g[(e+4)%5],S(g[(e+1)%5],1));for(e=0;5>e;e+=1)for(h=0;5>h;h+=1)a[e][h]=B(a[e][h],l[e]);for(e=0;5>e;e+=1)for(h=0;5>h;h+=1)n[h][(2*e+3*h)%5]=S(a[e][h],W[e][h]);for(e=0;5>e;e+=1)for(h=0;5>h;h+=1)a[e][h]=B(n[e][h],new b(~n[(e+1)%5][h].a&n[(e+2)%5][h].a,~n[(e+1)%5][h].b&n[(e+2)%5][h].b));a[0][0]=B(a[0][0],X[d])}return a}var d,V,W,X;d=[1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278, | ||||
|   1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815, | ||||
|   2227730452,2361852424,2428436474,2756734187,3204031479,3329325298];V=[new b(d[0],3609767458),new b(d[1],602891725),new b(d[2],3964484399),new b(d[3],2173295548),new b(d[4],4081628472),new b(d[5],3053834265),new b(d[6],2937671579),new b(d[7],3664609560),new b(d[8],2734883394),new b(d[9],1164996542),new b(d[10],1323610764),new b(d[11],3590304994),new b(d[12],4068182383),new b(d[13],991336113),new b(d[14],633803317),new b(d[15],3479774868),new b(d[16],2666613458),new b(d[17],944711139),new b(d[18],2341262773), | ||||
|   new b(d[19],2007800933),new b(d[20],1495990901),new b(d[21],1856431235),new b(d[22],3175218132),new b(d[23],2198950837),new b(d[24],3999719339),new b(d[25],766784016),new b(d[26],2566594879),new b(d[27],3203337956),new b(d[28],1034457026),new b(d[29],2466948901),new b(d[30],3758326383),new b(d[31],168717936),new b(d[32],1188179964),new b(d[33],1546045734),new b(d[34],1522805485),new b(d[35],2643833823),new b(d[36],2343527390),new b(d[37],1014477480),new b(d[38],1206759142),new b(d[39],344077627), | ||||
|   new b(d[40],1290863460),new b(d[41],3158454273),new b(d[42],3505952657),new b(d[43],106217008),new b(d[44],3606008344),new b(d[45],1432725776),new b(d[46],1467031594),new b(d[47],851169720),new b(d[48],3100823752),new b(d[49],1363258195),new b(d[50],3750685593),new b(d[51],3785050280),new b(d[52],3318307427),new b(d[53],3812723403),new b(d[54],2003034995),new b(d[55],3602036899),new b(d[56],1575990012),new b(d[57],1125592928),new b(d[58],2716904306),new b(d[59],442776044),new b(d[60],593698344),new b(d[61], | ||||
|   3733110249),new b(d[62],2999351573),new b(d[63],3815920427),new b(3391569614,3928383900),new b(3515267271,566280711),new b(3940187606,3454069534),new b(4118630271,4000239992),new b(116418474,1914138554),new b(174292421,2731055270),new b(289380356,3203993006),new b(460393269,320620315),new b(685471733,587496836),new b(852142971,1086792851),new b(1017036298,365543100),new b(1126000580,2618297676),new b(1288033470,3409855158),new b(1501505948,4234509866),new b(1607167915,987167468),new b(1816402316, | ||||
|   1246189591)];X=[new b(0,1),new b(0,32898),new b(2147483648,32906),new b(2147483648,2147516416),new b(0,32907),new b(0,2147483649),new b(2147483648,2147516545),new b(2147483648,32777),new b(0,138),new b(0,136),new b(0,2147516425),new b(0,2147483658),new b(0,2147516555),new b(2147483648,139),new b(2147483648,32905),new b(2147483648,32771),new b(2147483648,32770),new b(2147483648,128),new b(0,32778),new b(2147483648,2147483658),new b(2147483648,2147516545),new b(2147483648,32896),new b(0,2147483649), | ||||
|   new b(2147483648,2147516424)];W=[[0,36,3,41,18],[1,44,10,45,2],[62,6,43,15,61],[28,55,25,21,56],[27,20,39,8,14]];"function"===typeof define&&define.amd?define(function(){return C}):"undefined"!==typeof exports?("undefined"!==typeof module&&module.exports&&(module.exports=C),exports=C):Y.jsSHA=C})(this);   | ||||
							
								
								
									
										9
									
								
								public/js/socket.io.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9
									
								
								public/js/socket.io.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										9640
									
								
								public/js/xterm.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										9640
									
								
								public/js/xterm.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Reference in New Issue
	
	Block a user