Skip to content

Commit

Permalink
New scanning logic to help identify if your devices are on the networ…
Browse files Browse the repository at this point in the history
…k or not or unreachable.
  • Loading branch information
jfrux committed Nov 8, 2018
1 parent 14acd12 commit 75f3292
Show file tree
Hide file tree
Showing 31 changed files with 600 additions and 200 deletions.
66 changes: 54 additions & 12 deletions app/actions/eon_list_actions.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ export function ADD_ERROR(error) {
};
}


export function RESET_ERROR() {
return {
type: types.RESET_ERROR
Expand All @@ -18,7 +17,10 @@ export function RESET_ERROR() {
export function ADD_EON(eon) {
return {
type: types.ADD_EON,
payload: eon
payload: {
id: eon.id,
data: eon
}
};
}

Expand All @@ -30,13 +32,12 @@ export function ADDING_EON(eon) {
}

export function ADD_EON_SUCCESS(eon) {
let addEon = {};

addEon[eon.id] = eon;
console.warn("ADD_EON_SUCCESS:",eon);
return {
type: types.ADD_EON_SUCCESS,
payload: {
...addEon
id: eon.id,
data: eon
}
};
}
Expand All @@ -45,8 +46,8 @@ export function ADD_EON_FAILED(eon, error) {
return {
type: types.ADD_EON_FAILED,
payload: {
eonToAdd: eon,
addingEonError: error
id: eon.id,
data: eon
}
};
}
Expand All @@ -65,26 +66,67 @@ export function REMOVE_UNRESOLVED_EON(removeId) {
payload: removeId
};
}

export function DO_PING_EON(eon) {
return {
type: types.DO_PING_EON,
payload: {
id: eon.id,
data: eon
}
};
}
export function PING_EON(eon) {
return {
type: types.PING_EON,
payload: {
id: eon.id,
data: eon
}
};
}
export function PING_EON_SUCCESS(eon) {
return {
type: types.PING_EON_SUCCESS,
payload: {
id: eon.id,
data: eon
}
};
}
export function PING_EON_FAILED(eon) {
return {
type: types.PING_EON_FAILED,
payload: {
id: eon.id,
data: eon
}
};
}

export function RESOLVED_EON(eon, mac) {
let updatedEon = {};
eon.addStatus = 1;
eon.reachable = 1;
eon.mac = mac;
eon.id = mac;
updatedEon[eon.mac] = eon;
// updatedEon[eon.mac] = eon;

return {
type: types.RESOLVED_EON,
payload: {
...updatedEon
id: eon.id,
data: eon
}
};
}
export function UPDATE_UNRESOLVED(eon) {
let updatedEon = {};
updatedEon[eon.id] = eon;
return {
type: types.UPDATE_UNRESOLVED,
payload: {
...updatedEon
id: eon.id,
data: eon
}
};
}
Expand Down
7 changes: 7 additions & 0 deletions app/actions/network_scanner_actions.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,11 @@ export function BEGIN_scanNetwork() {
type: types.SCAN_NETWORK
};
}
export function PINGED_EONS() {
return {
type: types.PINGED_EONS
};
}

export function updateScanCount(count) {
return {
Expand All @@ -31,6 +36,8 @@ export function RESULT_scanNetwork(result) {
payload: result
};
}


// console.warn("OPEN " + result.ip,result);
// newEon[randomId] = {
// ...result,
Expand Down
8 changes: 7 additions & 1 deletion app/actions/ui_actions.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
import * as types from '../constants/ui_action_types';
import rpc from '../rpc';
import rpc from '../rpc-client';

export function APP_READY() {
return {
type: types.APP_READY
};
}

export function SET_TERMINAL_FONT_SIZE(fontSize) {
return {
Expand Down
1 change: 1 addition & 0 deletions app/app.global.scss
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ body {
flex-flow: wrap;
position:fixed;
background-color: #000;
z-index:1;
// background: radial-gradient(619.87px at 50% 6.62%, #072339 0%, #051B2C 100%)!important;
@import "styles/windows-top-bar";
@import "styles/top-bar";
Expand Down
106 changes: 100 additions & 6 deletions app/app.html
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta charset="utf-8" />
<title>Workbench</title>
<script>
(function() {
Expand All @@ -12,16 +12,110 @@
// HACK: Writing the script path should be done with webpack
document.getElementsByTagName('head')[0].appendChild(link);
}
}());
})();
</script>
<link href='https://api.mapbox.com/mapbox-gl-js/v0.49.0/mapbox-gl.css' rel='stylesheet' />
<link
href="https://api.mapbox.com/mapbox-gl-js/v0.49.0/mapbox-gl.css"
rel="stylesheet"
/>
<script src="https://www.gstatic.com/charts/loader.js"></script>
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" />

<meta
name="viewport"
content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"
/>

<script src="http://localhost:8097"></script>
<style>
body {
margin: 0;
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
font-size: 1rem;
font-weight: 400;
line-height: 1.5;
color: #212529;
text-align: left;
background-color: #000;
}
@keyframes spinner {
0% {
-webkit-transform: rotate(0deg);
-ms-transform: rotate(0deg);
transform: rotate(0deg);
}
100% {
-webkit-transform: rotate(360deg);
-ms-transform: rotate(360deg);
transform: rotate(360deg);
}
}
.spinner {
display: block;
width: 100%;
height: 100%;
position: relative;
}
.circle {
width: 100%;
height: 100%;
position: absolute;
z-index: 10001;
top:0;
left:0;
display: block;
margin: 0 auto;
background-size: 100% 100%;
background-position: center center;
background-repeat: no-repeat;
animation: spinner 0.8s infinite linear;
}
.loading_overlay {
position: absolute;
top: 0;
right: 0;
width: 100%;
height: 100%;
opacity: 1;
-webkit-app-region: drag; }

.loading_indicator_wrap {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -80%);
height: 80px;
width: 80px;
-webkit-app-region: drag; }

.loading_message {
position: absolute;
top: 50%;
left: 50%;
color: #FFF;
transform: translate(-50%, -50%);
-webkit-app-region: drag;
margin-top: 45px;
opacity: 0.6;
white-space: nowrap;
font-size: 12px; }
.loading_message span {
display: block;
text-align: center; }
.loading_message span.line2 {
color: rgba(255, 255, 255, 0.5); }
</style>
</head>
<body>
<div id="root"></div>
<div class="loading_overlay">
<span class="loading_indicator_wrap">
<img
class="circle"
src=""
/></span>
<div class="loading_message">
<span class="line1">Loading Workbench</span>
</div>
</div>
<script>
{
const scripts = [];
Expand All @@ -35,7 +129,7 @@
// Dynamically insert the bundled app script in the renderer process
const port = process.env.PORT || 1212;
scripts.push(
(process.env.HOT)
process.env.HOT
? 'http://localhost:' + port + '/dist/renderer.dev.js'
: './dist/renderer.prod.js'
);
Expand Down
21 changes: 10 additions & 11 deletions app/background/server.js
Original file line number Diff line number Diff line change
@@ -1,26 +1,21 @@
var terminals = {};
var logs = {};

const PORT = 9788;
const express = require('express');
const app = express();
import defaultShell from '../utils/default-shell';
const pty = require('node-pty-prebuilt');
const chalk = require('chalk');
const prefix = chalk.bold.blue;
const bgTaskColor = chalk.green;

function writeLog(...params) {
console.info(prefix('workbench') + ' ' + chalk.bold(bgTaskColor('[terminal]')), bgTaskColor(...params));
}
// try {
// spawn = require('node-pty-prebuilt').spawn;
// } catch (err) {
// throw "pty could not be spawned";
// }
const argv = require('yargs').argv;

const argv = require('yargs').argv;
const port = argv.port || PORT;
const host = '127.0.0.1';

const ALLOWED_ORIGINS = [
'0.0.0.0',
'127.0.0.1',
Expand Down Expand Up @@ -51,7 +46,7 @@ app.use('/', express.static(__dirname + '/../build'));
require('express-ws')(app);

app.post('/terminals', function (req, res) {
let shell = argv.shell && argv.shell !== '' ? argv.shell : process.platform === 'win32' ? 'cmd.exe' : 'bash';
let shell = defaultShell;
let cols = parseInt(req.query.cols, 10);
let rows = parseInt(req.query.rows, 10);
let term = pty.fork(shell, [], {
Expand Down Expand Up @@ -118,12 +113,16 @@ module.exports = {
startServer() {
return new Promise((resolve, reject) => {
if (!port) {
console.error('Please provide a port: node ./src/server.js --port=XXXX');
writeLog('ERROR: Please provide a port: node ./src/server.js --port=XXXX');
process.exit(1);
reject();
} else {
writeLog("Started Terminal Service");
resolve(app.listen(port, host));
try {
resolve(app.listen(port, host));
} catch (e) {
writeLog('ERROR: Could not start background/server...', e.message);
}
}
});
}
Expand Down
Loading

0 comments on commit 75f3292

Please sign in to comment.