Browse Source

Merge remote-tracking branch 'refs/remotes/upstream/master'

Conflicts:
	build/prod/cyberchef.htm
	build/prod/index.html
	build/prod/scripts.js
	src/static/stats.txt
Matt C 8 years ago
parent
commit
4101152c73

+ 33 - 4
Gruntfile.js

@@ -9,7 +9,8 @@ module.exports = function(grunt) {
         
         
     grunt.registerTask("prod",
     grunt.registerTask("prod",
         "Creates a production-ready build. Use the --msg flag to add a compile message.",
         "Creates a production-ready build. Use the --msg flag to add a compile message.",
-        ["jshint", "exec:stats", "clean", "jsdoc", "concat", "copy", "cssmin", "uglify:prod", "inline", "htmlmin", "chmod"]);
+        ["jshint", "exec:stats", "clean", "jsdoc", "concat", "copy:html_dev", "copy:html_prod", "copy:html_inline",
+         "copy:static_dev", "copy:static_prod", "cssmin", "uglify:prod", "inline", "htmlmin", "chmod"]);
         
         
     grunt.registerTask("docs",
     grunt.registerTask("docs",
         "Compiles documentation in the /docs directory.",
         "Compiles documentation in the /docs directory.",
@@ -18,6 +19,10 @@ module.exports = function(grunt) {
     grunt.registerTask("stats",
     grunt.registerTask("stats",
         "Provides statistics about the code base such as how many lines there are as well as details of file sizes before and after compression.",
         "Provides statistics about the code base such as how many lines there are as well as details of file sizes before and after compression.",
         ["concat:js", "uglify:prod", "exec:stats", "exec:repo_size", "exec:display_stats"]);
         ["concat:js", "uglify:prod", "exec:stats", "exec:repo_size", "exec:display_stats"]);
+
+    grunt.registerTask("release",
+        "Prepares and deploys a production version of CyberChef to the gh-pages branch.",
+        ["copy:gh_pages", "exec:deploy_gh_pages"]);
     
     
     grunt.registerTask("default",
     grunt.registerTask("default",
         "Lints the code base and shows stats",
         "Lints the code base and shows stats",
@@ -258,7 +263,7 @@ module.exports = function(grunt) {
                     process: function(content, srcpath) {
                     process: function(content, srcpath) {
                         // TODO: Do all this in Jade
                         // TODO: Do all this in Jade
                         content = content.replace(
                         content = content.replace(
-                            '<a href="cyberchef.htm" style="float: left; margin-left: 10px; margin-right: 80px;" download>Download CyberChef<img src="images/cloud_computing_download-plain-24x24.png" /></a>',
+                            '<a href="cyberchef.htm" style="float: left; margin-left: 10px; margin-right: 80px;" download>Download CyberChef<img src="images/download-24x24.png" /></a>',
                             '<span style="float: left; margin-left: 10px;">Compile time: ' + grunt.template.today("dd/mm/yyyy HH:MM:ss") + ' UTC</span>');
                             '<span style="float: left; margin-left: 10px;">Compile time: ' + grunt.template.today("dd/mm/yyyy HH:MM:ss") + ' UTC</span>');
                         return grunt.template.process(content, template_options);
                         return grunt.template.process(content, template_options);
                     }
                     }
@@ -274,7 +279,8 @@ module.exports = function(grunt) {
                         src: [
                         src: [
                             "**/*",
                             "**/*",
                             "**/.*",
                             "**/.*",
-                            "!stats.txt"
+                            "!stats.txt",
+                            "!ga.html"
                         ],
                         ],
                         dest: "build/dev/"
                         dest: "build/dev/"
                     }
                     }
@@ -288,11 +294,24 @@ module.exports = function(grunt) {
                         src: [
                         src: [
                             "**/*",
                             "**/*",
                             "**/.*",
                             "**/.*",
-                            "!stats.txt"
+                            "!stats.txt",
+                            "!ga.html"
                         ],
                         ],
                         dest: "build/prod/"
                         dest: "build/prod/"
                     }
                     }
                 ]
                 ]
+            },
+            gh_pages: {
+                options: {
+                    process: function(content, srcpath) {
+                        // Add Google Analytics code to index.html
+                        content = content.replace("</body></html>",
+                            grunt.file.read("src/static/ga.html") + "</body></html>");
+                        return grunt.template.process(content, template_options);
+                    }
+                },
+                src: "build/prod/index.html",
+                dest: "build/prod/index.html"
             }
             }
         },
         },
         uglify: {
         uglify: {
@@ -423,6 +442,16 @@ module.exports = function(grunt) {
             clean_git: {
             clean_git: {
                 command: "git gc --prune=now --aggressive"
                 command: "git gc --prune=now --aggressive"
             },
             },
+            deploy_gh_pages: {
+                command: [
+                        "git add build/prod/index.html -v",
+                        "COMMIT_HASH=$(git rev-parse HEAD)",
+                        "git commit -m \"GitHub Pages release for ${COMMIT_HASH}\"",
+                        "git push origin `git subtree split --prefix build/prod master`:gh-pages --force",
+                        "git reset HEAD~",
+                        "git checkout build/prod/index.html"
+                ].join(";")
+            }
         },
         },
         watch: {
         watch: {
             css: {
             css: {

File diff suppressed because it is too large
+ 0 - 0
build/prod/cyberchef.htm


File diff suppressed because it is too large
+ 0 - 0
build/prod/index.html


File diff suppressed because it is too large
+ 0 - 0
build/prod/scripts.js


+ 6 - 6
src/js/config/OperationConfig.js

@@ -209,7 +209,7 @@ var OperationConfig = {
         ]
         ]
     },
     },
     "XOR": {
     "XOR": {
-        description: "XOR the input with the given key.<br>e.g. <code>fe023da5</code><br><br><strong>Options</strong><br><u>Null preserving:</u> If the current byte is 0x00 or the same as the key, skip it.<br><br><u>Differential:</u> Set the key to the value of the previously decoded byte.",
+        description: "XOR the input with the given key.<br>e.g. <code>fe023da5</code><br><br><strong>Options</strong><br><u>Null preserving:</u> If the current byte is 0x00 or the same as the key, skip it.<br><br><u>Scheme:</u><ul><li>Standard - key is unchanged after each round</li><li>Input differential - key is set to the value of the previous unprocessed byte</li><li>Output differential - key is set to the value of the previous processed byte</li></ul>",
         run: BitwiseOp.run_xor,
         run: BitwiseOp.run_xor,
         highlight: true,
         highlight: true,
         highlight_reverse: true,
         highlight_reverse: true,
@@ -223,14 +223,14 @@ var OperationConfig = {
                 toggle_values: BitwiseOp.KEY_FORMAT
                 toggle_values: BitwiseOp.KEY_FORMAT
             },
             },
             {
             {
-                name: "Null preserving",
-                type: "boolean",
-                value: BitwiseOp.XOR_PRESERVE_NULLS
+                name: "Scheme",
+                type: "option",
+                value: BitwiseOp.XOR_SCHEME
             },
             },
             {
             {
-                name: "Differential",
+                name: "Null preserving",
                 type: "boolean",
                 type: "boolean",
-                value: BitwiseOp.XOR_DIFFERENTIAL
+                value: BitwiseOp.XOR_PRESERVE_NULLS
             }
             }
         ]
         ]
     },
     },

+ 15 - 8
src/js/operations/BitwiseOp.js

@@ -19,10 +19,10 @@ var BitwiseOp = {
      * @param {byte_array} key
      * @param {byte_array} key
      * @param {function} func - The bitwise calculation to carry out
      * @param {function} func - The bitwise calculation to carry out
      * @param {boolean} null_preserving
      * @param {boolean} null_preserving
-     * @param {boolean} differential
+     * @param {string} scheme
      * @returns {byte_array}
      * @returns {byte_array}
      */
      */
-    _bit_op: function (input, key, func, null_preserving, differential) {
+    _bit_op: function (input, key, func, null_preserving, scheme) {
         if (!key || !key.length) key = [0];
         if (!key || !key.length) key = [0];
         var result = [],
         var result = [],
             x = null,
             x = null,
@@ -34,8 +34,15 @@ var BitwiseOp = {
             o = input[i];
             o = input[i];
             x = null_preserving && (o === 0 || o == k) ? o : func(o, k);
             x = null_preserving && (o === 0 || o == k) ? o : func(o, k);
             result.push(x);
             result.push(x);
-            if (differential && !(null_preserving && (o === 0 || o == k))) {
-                key[i % key.length] = x;
+            if (scheme != "Standard" && !(null_preserving && (o === 0 || o == k))) {
+                switch (scheme) {
+                    case "Input differential":
+                        key[i % key.length] = x;
+                        break;
+                    case "Output differential":
+                        key[i % key.length] = o;
+                        break;
+                }
             }
             }
         }
         }
         
         
@@ -52,7 +59,7 @@ var BitwiseOp = {
      * @constant
      * @constant
      * @default
      * @default
      */
      */
-    XOR_DIFFERENTIAL: false,
+    XOR_SCHEME: ["Standard", "Input differential", "Output differential"],
     /**
     /**
      * @constant
      * @constant
      * @default
      * @default
@@ -68,12 +75,12 @@ var BitwiseOp = {
      */
      */
     run_xor: function (input, args) {
     run_xor: function (input, args) {
         var key = Utils.format[args[0].option].parse(args[0].string || ""),
         var key = Utils.format[args[0].option].parse(args[0].string || ""),
-            null_preserving = args[1],
-            differential = args[2];
+            scheme = args[1],
+            null_preserving = args[2];
         
         
         key = Utils.word_array_to_byte_array(key);
         key = Utils.word_array_to_byte_array(key);
             
             
-        return BitwiseOp._bit_op(input, key, BitwiseOp._xor, null_preserving, differential);
+        return BitwiseOp._bit_op(input, key, BitwiseOp._xor, null_preserving, scheme);
     },
     },
     
     
     
     

+ 2 - 0
src/js/operations/Code.js

@@ -64,6 +64,7 @@ var Code = {
      */
      */
     run_json_beautify: function(input, args) {
     run_json_beautify: function(input, args) {
         var indent_str = args[0];
         var indent_str = args[0];
+        if (!input) return "";
         return vkbeautify.json(input, indent_str);
         return vkbeautify.json(input, indent_str);
     },
     },
     
     
@@ -121,6 +122,7 @@ var Code = {
      * @returns {string}
      * @returns {string}
      */
      */
     run_json_minify: function(input, args) {
     run_json_minify: function(input, args) {
+        if (!input) return "";
         return vkbeautify.jsonmin(input);
         return vkbeautify.jsonmin(input);
     },
     },
     
     

+ 18 - 0
src/static/ga.html

@@ -0,0 +1,18 @@
+
+
+<!-- Begin Google Analytics -->
+<script>
+  (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
+  (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
+  m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
+  })(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
+
+  ga('create', 'UA-85682716-2', 'auto');
+
+  // Specifying location.pathname here overrides the default URL which would include arguments.
+  // This method prevents Google Analytics from logging any recipe or input data in the URL.
+  ga('send', 'pageview', location.pathname);
+
+</script>
+<!-- End Google Analytics -->
+

+ 15 - 0
src/static/stats.txt

@@ -1,3 +1,4 @@
+<<<<<<< HEAD
 202	source files
 202	source files
 104241	lines
 104241	lines
 	size
 	size
@@ -5,14 +6,28 @@
 136	JavaScript source files
 136	JavaScript source files
 95169	lines
 95169	lines
 3.5M	size
 3.5M	size
+=======
+203	source files
+104218	lines
+4.0M	size
+
+136	JavaScript source files
+95128	lines
+3.4M	size
+>>>>>>> master
 
 
 78	third party JavaScript source files
 78	third party JavaScript source files
 76377	lines
 76377	lines
 2.8M	size
 2.8M	size
 
 
 58	first party JavaScript source files
 58	first party JavaScript source files
+<<<<<<< HEAD
 18792	lines
 18792	lines
 736K	size
 736K	size
+=======
+18751	lines
+724K	size
+>>>>>>> master
 
 
 3.2M	uncompressed JavaScript size
 3.2M	uncompressed JavaScript size
 1.7M	compressed JavaScript size
 1.7M	compressed JavaScript size

Some files were not shown because too many files changed in this diff