mirror of https://github.com/docker/docs.git
Merge pull request #1322 from docker/latest-electron
Updated all electron calls for proper interactions - Tests pass 🎉
This commit is contained in:
commit
9c9452213b
|
|
@ -13,6 +13,7 @@ env:
|
||||||
node: true
|
node: true
|
||||||
es6: true
|
es6: true
|
||||||
browser: true
|
browser: true
|
||||||
|
jest: true
|
||||||
|
|
||||||
extends:
|
extends:
|
||||||
"eslint:recommended"
|
"eslint:recommended"
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,7 @@ sudo: false
|
||||||
|
|
||||||
language: node_js
|
language: node_js
|
||||||
node_js:
|
node_js:
|
||||||
- "4.1"
|
- "4.2.2"
|
||||||
|
|
||||||
cache:
|
cache:
|
||||||
directories:
|
directories:
|
||||||
|
|
@ -11,4 +11,3 @@ cache:
|
||||||
script:
|
script:
|
||||||
- npm install
|
- npm install
|
||||||
- npm test
|
- npm test
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,5 @@
|
||||||
|
module.exports = {
|
||||||
|
require: jest.genMockFunction(),
|
||||||
|
match: jest.genMockFunction(),
|
||||||
|
on: jest.genMockFunction()
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,7 @@
|
||||||
|
module.exports = {
|
||||||
|
require: jest.genMockFunction(),
|
||||||
|
match: jest.genMockFunction(),
|
||||||
|
app: jest.genMockFunction(),
|
||||||
|
remote: jest.genMockFunction(),
|
||||||
|
dialog: jest.genMockFunction()
|
||||||
|
};
|
||||||
|
|
@ -1,9 +1,9 @@
|
||||||
jest.dontMock('../src/utils/Util');
|
jest.dontMock('../src/utils/Util').dontMock('console');
|
||||||
var util = require('../src/utils/Util');
|
const util = require('../src/utils/Util');
|
||||||
|
|
||||||
describe('Util', function () {
|
describe('Util', () => {
|
||||||
describe('when removing sensitive data', function () {
|
describe('when removing sensitive data', () => {
|
||||||
it('filters ssh certificate data', function () {
|
it('filters ssh certificate data', () => {
|
||||||
var testdata = String.raw`time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost sudo mkdir -p /var/lib/boot2docker" time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo \"-----BEGIN CERTIFICATE-----\nMIIC+DCCAeKgAwIBAgIRANfIbsa2M94gDY+fBiBiQBkwCwYJKoZIhvcNAQELMBIx\nEDAOBgNVBAoTB2ptb3JnYW4wHhcNMTUwNDE4MDEzODAwWhcNMTgwNDAyMDEzODAw\nWjAPMQ0wCwYDVQQKEwRkZXYyMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC\nAQEA1yamWT0bk0pRU7eiStjiXe2jkzdeI0SdJZo+bjczkl6kzNW/FmR/OkcP8gHX\nCO3fUCWkR/+rBgz3nuM1Sy0BIUo0EMQGfx17OqIJPXO+BrpCHsXlphHmbQl5bE2Y\nF+bAsGc6WCippw/caNnIHRsb6zAZVYX2AHLYY0fwIDAQABo1AwTjAOBgNVHQ8BAf8EBAMCAKAwHQYD\nVR0lBBYwFAYIKwYBBQUHAwIGCCsGAQUFBwMBMAwGA1UdEwEB/wQCMAAwDwYDVR0R\nBAgwBocEwKhjZTALBgkqhkiG9w0BAQsDggEBAKBdD86+kl4X1VMjgGlNYnc42tWa\nbo1iDl/frxiLkfPSc2McAOm3AqX1ao+ynjqq1XTlBLPTQByu/oNZgA724LRJDfdG\nCKGUV8latW7rB1yhf/SZSmyhNjufuWlgCtbkw7Q/oPddzYuSOdDW8tVok9gMC0vL\naqKCWfVKkCmvGH+8/wPrkYmro/f0uwJ8ee+yrbBPlBE/qE+Lqcfr0YcXEDaS8CmL\nDjWg7KNFpA6M+/tFNQhplbjwRsCt7C4bzQu0aBIG5XH1Jr2HrKlLjWdmluPHWUL6\nX5Vh1bslYJzsSdBNZFWSKShZ+gtRpjtV7NynANDJPQNIRhDxAf4uDY9hA2c=\n-----END CERTIFICATE-----\n\" | sudo tee /var/lib/boot2docker/server.pem"
|
var testdata = String.raw`time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost sudo mkdir -p /var/lib/boot2docker" time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo \"-----BEGIN CERTIFICATE-----\nMIIC+DCCAeKgAwIBAgIRANfIbsa2M94gDY+fBiBiQBkwCwYJKoZIhvcNAQELMBIx\nEDAOBgNVBAoTB2ptb3JnYW4wHhcNMTUwNDE4MDEzODAwWhcNMTgwNDAyMDEzODAw\nWjAPMQ0wCwYDVQQKEwRkZXYyMIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKC\nAQEA1yamWT0bk0pRU7eiStjiXe2jkzdeI0SdJZo+bjczkl6kzNW/FmR/OkcP8gHX\nCO3fUCWkR/+rBgz3nuM1Sy0BIUo0EMQGfx17OqIJPXO+BrpCHsXlphHmbQl5bE2Y\nF+bAsGc6WCippw/caNnIHRsb6zAZVYX2AHLYY0fwIDAQABo1AwTjAOBgNVHQ8BAf8EBAMCAKAwHQYD\nVR0lBBYwFAYIKwYBBQUHAwIGCCsGAQUFBwMBMAwGA1UdEwEB/wQCMAAwDwYDVR0R\nBAgwBocEwKhjZTALBgkqhkiG9w0BAQsDggEBAKBdD86+kl4X1VMjgGlNYnc42tWa\nbo1iDl/frxiLkfPSc2McAOm3AqX1ao+ynjqq1XTlBLPTQByu/oNZgA724LRJDfdG\nCKGUV8latW7rB1yhf/SZSmyhNjufuWlgCtbkw7Q/oPddzYuSOdDW8tVok9gMC0vL\naqKCWfVKkCmvGH+8/wPrkYmro/f0uwJ8ee+yrbBPlBE/qE+Lqcfr0YcXEDaS8CmL\nDjWg7KNFpA6M+/tFNQhplbjwRsCt7C4bzQu0aBIG5XH1Jr2HrKlLjWdmluPHWUL6\nX5Vh1bslYJzsSdBNZFWSKShZ+gtRpjtV7NynANDJPQNIRhDxAf4uDY9hA2c=\n-----END CERTIFICATE-----\n\" | sudo tee /var/lib/boot2docker/server.pem"
|
||||||
time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: /usr/bin/VBoxManage showvminfo dev2 --machinereadable"`;
|
time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: /usr/bin/VBoxManage showvminfo dev2 --machinereadable"`;
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('CERTIFICATE')).toEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('CERTIFICATE')).toEqual(-1);
|
||||||
|
|
@ -11,7 +11,7 @@ describe('Util', function () {
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('<redacted>')).toNotEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('<redacted>')).toNotEqual(-1);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('filters ssh private key data', function () {
|
it('filters ssh private key data', () => {
|
||||||
var testdata = String.raw`hZbuxglOtQv2AQqOp/luhZ3Y8kDs4cqRzoA1o+k+LAyjEb+Nk\nGA8=\n-----END CERTIFICATE-----\n\" | sudo tee /var/lib/boot2docker/ca.pem"
|
var testdata = String.raw`hZbuxglOtQv2AQqOp/luhZ3Y8kDs4cqRzoA1o+k+LAyjEb+Nk\nGA8=\n-----END CERTIFICATE-----\n\" | sudo tee /var/lib/boot2docker/ca.pem"
|
||||||
time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo \"-----BEGIN RSA PRIVATE KEY-----\nMIIEpAIBAAKCAQEA1yamWT0bk0pRU7eiStjiXe2jkzdeI0SdJZo+bjczkl6kzNW/\nFmR/OkcP8gHXCO3fUCWkR/+rBgz3nuM1Sy0BIUo0EMQGfx17OqIJPXO+BrpCHsXl\nphHmbQl5bE2YF+bAsGc6WCippczQIu5bPweeAkR1WdlkhD08tHD4o1ESe09fXx5G\nXcZFfd2xQWdvAJX3fTuGBk3IMEF2fye5b69zUyVDGbTylyjKDOi9Xxdlc4y9cOPw\nzcwQFCOJiCBYlxDO0fbinA+KigCs29Dd5U3oXbloLr3JQTE/SkxFh9W5rkX8ysY4\n2h3EnR7YIBWt/caNnIHRsb6zAZVYX2AHLYY0fwIDAQABAoIBAQDKF3TTh/G59WnU\n4D2iXnyqy8gFRVG4gP+3TV3s+w8HIr1b5j6akwVqwUs5//5zVbSYPPNF6eJESbPi\nW/s4ROq10VR8lxSfHBsfJQrW3TwWZ6gp7atbxZ6Stv6F+5CsisReLmiAXJmVsn+j\nAA9Xchk6egFcxzWCfV7jAuaZyVI53cclepm/xkGjPwrfXr+nA+UMvO6DllC6IcBF\no4+O0jVtzdMecZnQk6nWxNJjurodTTQakrNAqSMgBshn48wf3N35b+p8RtTzLJ8L\nYuHkv6OKMITIazcHadjsN8icGgIGf2BJ1CRje7j0Yzow8jwY+Pet3yxKSfXED89B\nD34AEXl5AoGBANi17og+yPFOWURUrksO/QyzlOtXcQdQu8SmkUj4ACoqF0gegQIb\nC/DNMcYxJAsPPgw/t5Ws/af8DuatYguGukmekYREVjc7DS/hPWDZzeavPd95cOw0\nuMPgJE76HJ3BSYcp1f8WKcN+xDket9CF6Qz+VX5aQSUEc333V5h7D/nzAoGBAP4o\nVCvQu5eKYmDhMFSOA0+Qm3EECRqMLoH6kpEcbMjM8+kOeI0fUuE3CX8nzs7P4py/\n0IFj2Yxl578NHJOjCpbB1UKtxLkmDH42wXXzrWJXRaWXC93dh1sl0aB6qE25FtSD\nzjYh4y1DA/t6y95YRrIqC2WhIU7eigIoujmtOFJFAoGABSKiiWX7ewRhRyY+jxbG\n1lM3FzCWRBccq/dKgBEoZ9dhf9sBMZyUdttV751gfkaZMM8duZVE2YM2ky7OoPlL\nVs1EI38/D8X9dQIAY1gl8e57J92H2IETU8ju81Qn83EOHf7WzFmpGbHaUoQw1Ocn\nc6BfREQ9QPRPDFAdKkbYRRMCgYEAl44k4xvNQUhb8blWwJUOlFt+1Z26cAI3mXp5\n+94fYH4W1Fq0uDJ9kZ7oItLyF5EPaLlY9E8+YuJBl0OSTtdicROUv/Yu4Nk3ievM\n4TE1qvavqVaw1NRM6qVao3+A7Rf57S/Lv6vldBAKR+OpviSVw5gew7OZ0RYS5caz\nhcEtXKECgYAJb7t67nococm0PsRe8Xv1SQOQjetrhzwzD1PLOSC9TrzwA22/ZktZ\neu/qfvYgOPT4LkDGVCzn8J+TAcUVnIvAnJRQTsBu55uiL8YC5jZQ8E1hBf7kskMq\nh16WD19Djv3WhfBNXBxvnagDDWw5DxmiiKzSf0k3QDDoX7wjDAV1dQ==\n-----END RSA PRIVATE KEY-----\n\" | sudo tee /var/lib/boot2docker/server-key.pem"
|
time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo \"-----BEGIN RSA PRIVATE KEY-----\nMIIEpAIBAAKCAQEA1yamWT0bk0pRU7eiStjiXe2jkzdeI0SdJZo+bjczkl6kzNW/\nFmR/OkcP8gHXCO3fUCWkR/+rBgz3nuM1Sy0BIUo0EMQGfx17OqIJPXO+BrpCHsXl\nphHmbQl5bE2YF+bAsGc6WCippczQIu5bPweeAkR1WdlkhD08tHD4o1ESe09fXx5G\nXcZFfd2xQWdvAJX3fTuGBk3IMEF2fye5b69zUyVDGbTylyjKDOi9Xxdlc4y9cOPw\nzcwQFCOJiCBYlxDO0fbinA+KigCs29Dd5U3oXbloLr3JQTE/SkxFh9W5rkX8ysY4\n2h3EnR7YIBWt/caNnIHRsb6zAZVYX2AHLYY0fwIDAQABAoIBAQDKF3TTh/G59WnU\n4D2iXnyqy8gFRVG4gP+3TV3s+w8HIr1b5j6akwVqwUs5//5zVbSYPPNF6eJESbPi\nW/s4ROq10VR8lxSfHBsfJQrW3TwWZ6gp7atbxZ6Stv6F+5CsisReLmiAXJmVsn+j\nAA9Xchk6egFcxzWCfV7jAuaZyVI53cclepm/xkGjPwrfXr+nA+UMvO6DllC6IcBF\no4+O0jVtzdMecZnQk6nWxNJjurodTTQakrNAqSMgBshn48wf3N35b+p8RtTzLJ8L\nYuHkv6OKMITIazcHadjsN8icGgIGf2BJ1CRje7j0Yzow8jwY+Pet3yxKSfXED89B\nD34AEXl5AoGBANi17og+yPFOWURUrksO/QyzlOtXcQdQu8SmkUj4ACoqF0gegQIb\nC/DNMcYxJAsPPgw/t5Ws/af8DuatYguGukmekYREVjc7DS/hPWDZzeavPd95cOw0\nuMPgJE76HJ3BSYcp1f8WKcN+xDket9CF6Qz+VX5aQSUEc333V5h7D/nzAoGBAP4o\nVCvQu5eKYmDhMFSOA0+Qm3EECRqMLoH6kpEcbMjM8+kOeI0fUuE3CX8nzs7P4py/\n0IFj2Yxl578NHJOjCpbB1UKtxLkmDH42wXXzrWJXRaWXC93dh1sl0aB6qE25FtSD\nzjYh4y1DA/t6y95YRrIqC2WhIU7eigIoujmtOFJFAoGABSKiiWX7ewRhRyY+jxbG\n1lM3FzCWRBccq/dKgBEoZ9dhf9sBMZyUdttV751gfkaZMM8duZVE2YM2ky7OoPlL\nVs1EI38/D8X9dQIAY1gl8e57J92H2IETU8ju81Qn83EOHf7WzFmpGbHaUoQw1Ocn\nc6BfREQ9QPRPDFAdKkbYRRMCgYEAl44k4xvNQUhb8blWwJUOlFt+1Z26cAI3mXp5\n+94fYH4W1Fq0uDJ9kZ7oItLyF5EPaLlY9E8+YuJBl0OSTtdicROUv/Yu4Nk3ievM\n4TE1qvavqVaw1NRM6qVao3+A7Rf57S/Lv6vldBAKR+OpviSVw5gew7OZ0RYS5caz\nhcEtXKECgYAJb7t67nococm0PsRe8Xv1SQOQjetrhzwzD1PLOSC9TrzwA22/ZktZ\neu/qfvYgOPT4LkDGVCzn8J+TAcUVnIvAnJRQTsBu55uiL8YC5jZQ8E1hBf7kskMq\nh16WD19Djv3WhfBNXBxvnagDDWw5DxmiiKzSf0k3QDDoX7wjDAV1dQ==\n-----END RSA PRIVATE KEY-----\n\" | sudo tee /var/lib/boot2docker/server-key.pem"
|
||||||
time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo \"-----BEGIN CERTIFICATE-----\nMIIC+DCCAeKgAwIBAgIRANfIbsa2M94gDY+fBiBiQBkwCwYJKoZIhvcNAQELMBIx\nEDAOBg`;
|
time="2015-04-17T21:43:47-04:00" level="debug" msg="executing: ssh -o IdentitiesOnly=yes -o StrictHostKeyChecking=no -o UserKnownHostsFile=/dev/null -o ConnectionAttempts=30 -o LogLevel=quiet -p 50483 -i /Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo \"-----BEGIN CERTIFICATE-----\nMIIC+DCCAeKgAwIBAgIRANfIbsa2M94gDY+fBiBiQBkwCwYJKoZIhvcNAQELMBIx\nEDAOBg`;
|
||||||
|
|
@ -20,7 +20,7 @@ describe('Util', function () {
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('<redacted>')).toNotEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('<redacted>')).toNotEqual(-1);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('filters username data', function () {
|
it('filters username data', () => {
|
||||||
var testdata = String.raw`/Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo`;
|
var testdata = String.raw`/Users/johnappleseed/.docker/machine/machines/dev2/id_rsa docker@localhost echo`;
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('/Users/johnappleseed/')).toEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('/Users/johnappleseed/')).toEqual(-1);
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('/Users/<redacted>/')).toNotEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('/Users/<redacted>/')).toNotEqual(-1);
|
||||||
|
|
@ -30,20 +30,20 @@ describe('Util', function () {
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('/Users/<redacted>/.docker')).toNotEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('/Users/<redacted>/.docker')).toNotEqual(-1);
|
||||||
});
|
});
|
||||||
|
|
||||||
it('filters Windows username data', function () {
|
it('filters Windows username data', () => {
|
||||||
var testdata = String.raw`C:\\Users\\johnappleseed\\.docker\\machine`;
|
var testdata = String.raw`C:\\Users\\johnappleseed\\.docker\\machine`;
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('johnappleseed')).toEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('johnappleseed')).toEqual(-1);
|
||||||
expect(util.removeSensitiveData(testdata).indexOf('<redacted>')).toNotEqual(-1);
|
expect(util.removeSensitiveData(testdata).indexOf('<redacted>')).toNotEqual(-1);
|
||||||
});
|
});
|
||||||
|
|
||||||
it ('returns input if empty or not a string', function () {
|
it ('returns input if empty or not a string', () => {
|
||||||
expect(util.removeSensitiveData('')).toBe('');
|
expect(util.removeSensitiveData('')).toBe('');
|
||||||
expect(util.removeSensitiveData(1)).toBe(1);
|
expect(util.removeSensitiveData(1)).toBe(1);
|
||||||
expect(util.removeSensitiveData(undefined)).toBe(undefined);
|
expect(util.removeSensitiveData(undefined)).toBe(undefined);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('when verifying that a repo is official', function () {
|
describe('when verifying that a repo is official', () => {
|
||||||
it('accepts official repo', () => {
|
it('accepts official repo', () => {
|
||||||
expect(util.isOfficialRepo('redis')).toBe(true);
|
expect(util.isOfficialRepo('redis')).toBe(true);
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -55,7 +55,7 @@
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"babel": "^5.8.23",
|
"babel": "^5.8.23",
|
||||||
"babel-jest": "^5.2.0",
|
"babel-jest": "^5.2.0",
|
||||||
"electron-prebuilt": "^0.35.4",
|
"electron-prebuilt": "^0.36",
|
||||||
"eslint": "^1.3.1",
|
"eslint": "^1.3.1",
|
||||||
"eslint-plugin-react": "^3.3.0",
|
"eslint-plugin-react": "^3.3.0",
|
||||||
"grunt": "^0.4.5",
|
"grunt": "^0.4.5",
|
||||||
|
|
@ -79,11 +79,10 @@
|
||||||
"grunt-rename": "^0.1.4",
|
"grunt-rename": "^0.1.4",
|
||||||
"grunt-shell": "^1.1.2",
|
"grunt-shell": "^1.1.2",
|
||||||
"grunt-shell-spawn": "^0.3.8",
|
"grunt-shell-spawn": "^0.3.8",
|
||||||
"jest-cli": "^0.5.8",
|
"jest-cli": "^0.8.2",
|
||||||
"jsxhint": "^0.15.1",
|
"jsxhint": "^0.15.1",
|
||||||
"load-grunt-tasks": "^3.2.0",
|
"load-grunt-tasks": "^3.2.0",
|
||||||
"minimist": "^1.1.1",
|
"minimist": "^1.1.1",
|
||||||
"react-tools": "^0.13.1",
|
|
||||||
"run-sequence": "^1.0.2",
|
"run-sequence": "^1.0.2",
|
||||||
"shell-escape": "^0.2.0",
|
"shell-escape": "^0.2.0",
|
||||||
"source-map-support": "^0.3.2"
|
"source-map-support": "^0.3.2"
|
||||||
|
|
|
||||||
20
src/app.js
20
src/app.js
|
|
@ -1,24 +1,24 @@
|
||||||
require.main.paths.splice(0, 0, process.env.NODE_PATH);
|
require.main.paths.splice(0, 0, process.env.NODE_PATH);
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var Menu = remote.require('menu');
|
const remote = electron.remote;
|
||||||
|
const Menu = remote.Menu;
|
||||||
|
// ipcRenderer is used as we're in the process
|
||||||
|
const ipcRenderer = electron.ipcRenderer;
|
||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import SetupStore from './stores/SetupStore';
|
|
||||||
import ipc from 'ipc';
|
|
||||||
import machine from './utils/DockerMachineUtil';
|
|
||||||
import metrics from './utils/MetricsUtil';
|
import metrics from './utils/MetricsUtil';
|
||||||
import template from './menutemplate';
|
import template from './menutemplate';
|
||||||
import webUtil from './utils/WebUtil';
|
import webUtil from './utils/WebUtil';
|
||||||
import hubUtil from './utils/HubUtil';
|
import hubUtil from './utils/HubUtil';
|
||||||
import setupUtil from './utils/SetupUtil';
|
import setupUtil from './utils/SetupUtil';
|
||||||
import request from 'request';
|
|
||||||
import docker from './utils/DockerUtil';
|
import docker from './utils/DockerUtil';
|
||||||
import hub from './utils/HubUtil';
|
import hub from './utils/HubUtil';
|
||||||
import Router from 'react-router';
|
import Router from 'react-router';
|
||||||
import routes from './routes';
|
import routes from './routes';
|
||||||
import routerContainer from './router';
|
import routerContainer from './router';
|
||||||
import repositoryActions from './actions/RepositoryActions';
|
import repositoryActions from './actions/RepositoryActions';
|
||||||
import util from './utils/Util';
|
import machine from './utils/DockerMachineUtil';
|
||||||
var app = remote.require('app');
|
|
||||||
|
|
||||||
hubUtil.init();
|
hubUtil.init();
|
||||||
|
|
||||||
|
|
@ -47,6 +47,8 @@ var router = Router.create({
|
||||||
router.run(Handler => React.render(<Handler/>, document.body));
|
router.run(Handler => React.render(<Handler/>, document.body));
|
||||||
routerContainer.set(router);
|
routerContainer.set(router);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
setupUtil.setup().then(() => {
|
setupUtil.setup().then(() => {
|
||||||
Menu.setApplicationMenu(Menu.buildFromTemplate(template()));
|
Menu.setApplicationMenu(Menu.buildFromTemplate(template()));
|
||||||
docker.init();
|
docker.init();
|
||||||
|
|
@ -63,7 +65,7 @@ setupUtil.setup().then(() => {
|
||||||
throw err;
|
throw err;
|
||||||
});
|
});
|
||||||
|
|
||||||
ipc.on('application:quitting', () => {
|
ipcRenderer.on('application:quitting', () => {
|
||||||
if (localStorage.getItem('settings.closeVMOnQuit') === 'true') {
|
if (localStorage.getItem('settings.closeVMOnQuit') === 'true') {
|
||||||
machine.stop();
|
machine.stop();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,10 @@
|
||||||
import app from 'app';
|
import electron from 'electron';
|
||||||
import BrowserWindow from 'browser-window';
|
const app = electron.app;
|
||||||
|
const BrowserWindow = electron.BrowserWindow;
|
||||||
|
|
||||||
import fs from 'fs';
|
import fs from 'fs';
|
||||||
import os from 'os';
|
import os from 'os';
|
||||||
var ipc = require('electron').ipcMain;
|
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
import child_process from 'child_process';
|
import child_process from 'child_process';
|
||||||
|
|
||||||
|
|
@ -18,29 +20,6 @@ try {
|
||||||
settingsjson = JSON.parse(fs.readFileSync(path.join(__dirname, 'settings.json'), 'utf8'));
|
settingsjson = JSON.parse(fs.readFileSync(path.join(__dirname, 'settings.json'), 'utf8'));
|
||||||
} catch (err) {}
|
} catch (err) {}
|
||||||
|
|
||||||
let updateCmd = (args, cb) => {
|
|
||||||
let updateExe = path.resolve(path.dirname(process.execPath), '..', 'Update.exe');
|
|
||||||
let child = child_process.spawn(updateExe, args, {detached: true});
|
|
||||||
child.on('close', cb);
|
|
||||||
};
|
|
||||||
|
|
||||||
if (process.platform === 'win32') {
|
|
||||||
var squirrelCommand = process.argv[1];
|
|
||||||
let target = path.basename(process.execPath);
|
|
||||||
switch (squirrelCommand) {
|
|
||||||
case '--squirrel-install':
|
|
||||||
case '--squirrel-updated':
|
|
||||||
updateCmd(['--createShortcut', target], app.quit);
|
|
||||||
break;
|
|
||||||
case '--squirrel-uninstall':
|
|
||||||
updateCmd(['--removeShortcut', target], app.quit);
|
|
||||||
break;
|
|
||||||
case '--squirrel-obsolete':
|
|
||||||
app.quit();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
app.on('ready', function () {
|
app.on('ready', function () {
|
||||||
var mainWindow = new BrowserWindow({
|
var mainWindow = new BrowserWindow({
|
||||||
width: size.width || 1080,
|
width: size.width || 1080,
|
||||||
|
|
@ -66,25 +45,18 @@ app.on('ready', function () {
|
||||||
return false;
|
return false;
|
||||||
});
|
});
|
||||||
|
|
||||||
var updating = false;
|
|
||||||
ipc.on('application:quit-install', function () {
|
|
||||||
updating = true;
|
|
||||||
});
|
|
||||||
|
|
||||||
if (os.platform() === 'win32') {
|
if (os.platform() === 'win32') {
|
||||||
mainWindow.on('close', function () {
|
mainWindow.on('close', function () {
|
||||||
mainWindow.webContents.send('application:quitting');
|
mainWindow.webContents.send('application:quitting');
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
|
|
||||||
app.on('window-all-closed', function() {
|
app.on('window-all-closed', function () {
|
||||||
app.quit();
|
app.quit();
|
||||||
});
|
});
|
||||||
} else if (os.platform() === 'darwin') {
|
} else if (os.platform() === 'darwin') {
|
||||||
app.on('before-quit', function () {
|
app.on('before-quit', function () {
|
||||||
if (!updating) {
|
mainWindow.webContents.send('application:quitting');
|
||||||
mainWindow.webContents.send('application:quitting');
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -6,8 +6,9 @@ import shell from 'shell';
|
||||||
import util from '../utils/Util';
|
import util from '../utils/Util';
|
||||||
import metrics from '../utils/MetricsUtil';
|
import metrics from '../utils/MetricsUtil';
|
||||||
import containerActions from '../actions/ContainerActions';
|
import containerActions from '../actions/ContainerActions';
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var dialog = remote.require('dialog');
|
const remote = electron.remote;
|
||||||
|
const dialog = remote.dialog;
|
||||||
import mkdirp from 'mkdirp';
|
import mkdirp from 'mkdirp';
|
||||||
|
|
||||||
var ContainerHomeFolder = React.createClass({
|
var ContainerHomeFolder = React.createClass({
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,9 @@
|
||||||
import $ from 'jquery';
|
import $ from 'jquery';
|
||||||
import React from 'react/addons';
|
import React from 'react/addons';
|
||||||
import Router from 'react-router';
|
import Router from 'react-router';
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var dialog = remote.require('dialog');
|
const remote = electron.remote;
|
||||||
|
const dialog = remote.dialog;
|
||||||
import metrics from '../utils/MetricsUtil';
|
import metrics from '../utils/MetricsUtil';
|
||||||
import {OverlayTrigger, Tooltip} from 'react-bootstrap';
|
import {OverlayTrigger, Tooltip} from 'react-bootstrap';
|
||||||
import containerActions from '../actions/ContainerActions';
|
import containerActions from '../actions/ContainerActions';
|
||||||
|
|
|
||||||
|
|
@ -1,8 +1,9 @@
|
||||||
import _ from 'underscore';
|
import _ from 'underscore';
|
||||||
import React from 'react/addons';
|
import React from 'react/addons';
|
||||||
import metrics from '../utils/MetricsUtil';
|
import metrics from '../utils/MetricsUtil';
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var dialog = remote.require('dialog');
|
const remote = electron.remote;
|
||||||
|
const dialog = remote.dialog;
|
||||||
import ContainerUtil from '../utils/ContainerUtil';
|
import ContainerUtil from '../utils/ContainerUtil';
|
||||||
import containerActions from '../actions/ContainerActions';
|
import containerActions from '../actions/ContainerActions';
|
||||||
import util from '../utils/Util';
|
import util from '../utils/Util';
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,8 @@
|
||||||
import _ from 'underscore';
|
import _ from 'underscore';
|
||||||
import React from 'react/addons';
|
import React from 'react/addons';
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var dialog = remote.require('dialog');
|
const remote = electron.remote;
|
||||||
|
const dialog = remote.dialog;
|
||||||
import shell from 'shell';
|
import shell from 'shell';
|
||||||
import util from '../utils/Util';
|
import util from '../utils/Util';
|
||||||
import metrics from '../utils/MetricsUtil';
|
import metrics from '../utils/MetricsUtil';
|
||||||
|
|
|
||||||
|
|
@ -1,11 +1,11 @@
|
||||||
import React from 'react/addons';
|
import React from 'react/addons';
|
||||||
import remote from 'remote';
|
|
||||||
import RetinaImage from 'react-retina-image';
|
import RetinaImage from 'react-retina-image';
|
||||||
import ipc from 'ipc';
|
|
||||||
import util from '../utils/Util';
|
import util from '../utils/Util';
|
||||||
import metrics from '../utils/MetricsUtil';
|
import metrics from '../utils/MetricsUtil';
|
||||||
var Menu = remote.require('menu');
|
import electron from 'electron';
|
||||||
var MenuItem = remote.require('menu-item');
|
const remote = electron.remote;
|
||||||
|
const Menu = remote.Menu;
|
||||||
|
const MenuItem = remote.MenuItem;
|
||||||
import accountStore from '../stores/AccountStore';
|
import accountStore from '../stores/AccountStore';
|
||||||
import accountActions from '../actions/AccountActions';
|
import accountActions from '../actions/AccountActions';
|
||||||
import Router from 'react-router';
|
import Router from 'react-router';
|
||||||
|
|
@ -25,12 +25,6 @@ var Header = React.createClass({
|
||||||
document.addEventListener('keyup', this.handleDocumentKeyUp, false);
|
document.addEventListener('keyup', this.handleDocumentKeyUp, false);
|
||||||
|
|
||||||
accountStore.listen(this.update);
|
accountStore.listen(this.update);
|
||||||
|
|
||||||
ipc.on('application:update-available', () => {
|
|
||||||
this.setState({
|
|
||||||
updateAvailable: true
|
|
||||||
});
|
|
||||||
});
|
|
||||||
},
|
},
|
||||||
componentWillUnmount: function () {
|
componentWillUnmount: function () {
|
||||||
document.removeEventListener('keyup', this.handleDocumentKeyUp, false);
|
document.removeEventListener('keyup', this.handleDocumentKeyUp, false);
|
||||||
|
|
@ -79,10 +73,6 @@ var Header = React.createClass({
|
||||||
handleFullscreenHover: function () {
|
handleFullscreenHover: function () {
|
||||||
this.update();
|
this.update();
|
||||||
},
|
},
|
||||||
handleAutoUpdateClick: function () {
|
|
||||||
metrics.track('Restarted to Update');
|
|
||||||
ipc.send('application:quit-install');
|
|
||||||
},
|
|
||||||
handleUserClick: function (e) {
|
handleUserClick: function (e) {
|
||||||
let menu = new Menu();
|
let menu = new Menu();
|
||||||
|
|
||||||
|
|
@ -166,7 +156,6 @@ var Header = React.createClass({
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
let updateWidget = this.state.updateAvailable && !this.props.hideLogin ? <a className="btn btn-action small no-drag" onClick={this.handleAutoUpdateClick}>UPDATE NOW</a> : null;
|
|
||||||
return (
|
return (
|
||||||
<div className={headerClasses}>
|
<div className={headerClasses}>
|
||||||
<div className="left-header">
|
<div className="left-header">
|
||||||
|
|
@ -174,9 +163,6 @@ var Header = React.createClass({
|
||||||
{username}
|
{username}
|
||||||
</div>
|
</div>
|
||||||
<div className="right-header">
|
<div className="right-header">
|
||||||
<div className="updates">
|
|
||||||
{updateWidget}
|
|
||||||
</div>
|
|
||||||
{util.isWindows () ? this.renderWindowButtons() : this.renderLogo()}
|
{util.isWindows () ? this.renderWindowButtons() : this.renderLogo()}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,5 @@
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
|
const remote = electron.remote;
|
||||||
import shell from 'shell';
|
import shell from 'shell';
|
||||||
import router from './router';
|
import router from './router';
|
||||||
import util from './utils/Util';
|
import util from './utils/Util';
|
||||||
|
|
@ -6,7 +7,7 @@ import metrics from './utils/MetricsUtil';
|
||||||
import machine from './utils/DockerMachineUtil';
|
import machine from './utils/DockerMachineUtil';
|
||||||
import docker from './utils/DockerUtil';
|
import docker from './utils/DockerUtil';
|
||||||
|
|
||||||
var app = remote.require('app');
|
const app = remote.app;
|
||||||
|
|
||||||
// main.js
|
// main.js
|
||||||
var MenuTemplate = function () {
|
var MenuTemplate = function () {
|
||||||
|
|
|
||||||
|
|
@ -121,7 +121,6 @@ export default {
|
||||||
await machine.create();
|
await machine.create();
|
||||||
} else {
|
} else {
|
||||||
let state = await machine.status();
|
let state = await machine.status();
|
||||||
console.log(state);
|
|
||||||
if (state !== 'Running') {
|
if (state !== 'Running') {
|
||||||
if (state === 'Saved') {
|
if (state === 'Saved') {
|
||||||
router.get().transitionTo('setup');
|
router.get().transitionTo('setup');
|
||||||
|
|
|
||||||
|
|
@ -3,9 +3,10 @@ import Promise from 'bluebird';
|
||||||
import fs from 'fs';
|
import fs from 'fs';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
import crypto from 'crypto';
|
import crypto from 'crypto';
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var dialog = remote.require('dialog');
|
const remote = electron.remote;
|
||||||
var app = remote.require('app');
|
const dialog = remote.dialog;
|
||||||
|
const app = remote.app;
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
execFile: function (args, options) {
|
execFile: function (args, options) {
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,6 @@
|
||||||
import remote from 'remote';
|
import electron from 'electron';
|
||||||
var app = remote.require('app');
|
const remote = electron.remote;
|
||||||
|
const app = remote.app;
|
||||||
import fs from 'fs';
|
import fs from 'fs';
|
||||||
import util from './Util';
|
import util from './Util';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue