Merge pull request #1098 from guardicore/eslint

Add eslint
This commit is contained in:
Mike Salvatore 2021-04-15 07:29:51 -04:00 committed by GitHub
commit d507e6f617
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
10 changed files with 28 additions and 23 deletions

View File

@ -28,3 +28,8 @@ repos:
- id: detect-private-key - id: detect-private-key
- id: end-of-file-fixer - id: end-of-file-fixer
- id: trailing-whitespace - id: trailing-whitespace
- repo: https://github.com/eslint/eslint
rev: v7.24.0
hooks:
- id: eslint
args: ["monkey/monkey_island/cc/ui/src/", "--fix", "--max-warnings=0"]

View File

@ -71,7 +71,7 @@ script:
- cd monkey_island/cc/ui - cd monkey_island/cc/ui
- npm ci # See https://docs.npmjs.com/cli/ci.html - npm ci # See https://docs.npmjs.com/cli/ci.html
- eslint ./src --quiet # Test for errors - eslint ./src --quiet # Test for errors
- JS_WARNINGS_AMOUNT_UPPER_LIMIT=7 - JS_WARNINGS_AMOUNT_UPPER_LIMIT=0
- eslint ./src --max-warnings $JS_WARNINGS_AMOUNT_UPPER_LIMIT # Test for max warnings - eslint ./src --max-warnings $JS_WARNINGS_AMOUNT_UPPER_LIMIT # Test for max warnings
# Build documentation # Build documentation

View File

@ -23,3 +23,11 @@ This means setting up an environment with Linux 32/64-bit with Python installed
The Monkey Island is a Python backend React frontend project. Similar to the agent, the backend's requirements are listed in the matching [`requirements.txt`](https://github.com/guardicore/monkey/blob/master/monkey/monkey_island/requirements.txt). The Monkey Island is a Python backend React frontend project. Similar to the agent, the backend's requirements are listed in the matching [`requirements.txt`](https://github.com/guardicore/monkey/blob/master/monkey/monkey_island/requirements.txt).
To setup a working front environment, run the instructions listed in the [`readme.txt`](https://github.com/guardicore/monkey/blob/master/monkey/monkey_island/readme.txt) To setup a working front environment, run the instructions listed in the [`readme.txt`](https://github.com/guardicore/monkey/blob/master/monkey/monkey_island/readme.txt)
## Pre-commit
Pre-commit is a multi-language package manager for pre-commit hooks. It will run a set of checks when you attempt to commit. If your commit does not pass all checks, it will be reformatted and/or you'll be given a list of errors and warnings that need to be fixed before you can commit.
Our CI system runs the same checks when pull requests are submitted. This system may report that the build has failed if the pre-commit hooks have not been run or all issues have not been resolved.
To install and configure pre-commit, run `pip install --user pre-commit`. Next, go to the top level directory of this repository and run `pre-commit install`. Pre-commit will now run automatically whenever you `git commit`.

View File

@ -56,7 +56,7 @@ const getContents = (props) => {
// update existing state, not run-over // update existing state, not run-over
let prevRes = result; let prevRes = result;
for (let key in result) { for (let key in result) {
if (result.hasOwnProperty(key)) { if (Object.prototype.hasOwnProperty.call(result, key)) {
prevRes[key] = result[key]; prevRes[key] = result[key];
} }
} }

View File

@ -27,7 +27,7 @@ function RunOptions(props) {
.then(res => { .then(res => {
let commandServers = res.configuration.internal.island_server.command_servers; let commandServers = res.configuration.internal.island_server.command_servers;
let ipAddresses = commandServers.map(ip => { let ipAddresses = commandServers.map(ip => {
return ip.split(":", 1); return ip.split(':', 1);
}); });
setIps(ipAddresses); setIps(ipAddresses);
setInitialized(true); setInitialized(true);

View File

@ -1,6 +1,5 @@
import React from 'react'; import React from 'react';
import Graph from 'react-graph-vis'; import Graph from 'react-graph-vis';
import Dimensions from 'react-dimensions'
class GraphWrapper extends React.Component { class GraphWrapper extends React.Component {

View File

@ -58,7 +58,7 @@ class ReportPageComponent extends AuthComponent {
credentialTypes = { credentialTypes = {
PASSWORD: 'password', PASSWORD: 'password',
HASH: 'hash', HASH: 'hash',
KEY: 'key', KEY: 'key'
} }
issueContentTypes = { issueContentTypes = {
@ -152,7 +152,7 @@ class ReportPageComponent extends AuthComponent {
[this.issueContentTypes.TYPE]: this.issueTypes.DANGER [this.issueContentTypes.TYPE]: this.issueTypes.DANGER
}, },
'zerologon_pass_restore_failed': { 'zerologon_pass_restore_failed': {
[this.issueContentTypes.OVERVIEW]: zerologonOverviewWithFailedPassResetWarning, [this.issueContentTypes.OVERVIEW]: zerologonOverviewWithFailedPassResetWarning
}, },
'island_cross_segment': { 'island_cross_segment': {
[this.issueContentTypes.OVERVIEW]: crossSegmentIssueOverview, [this.issueContentTypes.OVERVIEW]: crossSegmentIssueOverview,
@ -437,9 +437,9 @@ class ReportPageComponent extends AuthComponent {
isIssuePotentialSecurityIssue(issueName) { isIssuePotentialSecurityIssue(issueName) {
let issueDescriptor = this.IssueDescriptorEnum[issueName]; let issueDescriptor = this.IssueDescriptorEnum[issueName];
return issueDescriptor.hasOwnProperty(this.issueContentTypes.TYPE) && return Object.prototype.hasOwnProperty.call(issueDescriptor, this.issueContentTypes.TYPE) &&
issueDescriptor[this.issueContentTypes.TYPE] === this.issueTypes.WARNING && issueDescriptor[this.issueContentTypes.TYPE] === this.issueTypes.WARNING &&
issueDescriptor.hasOwnProperty(this.issueContentTypes.OVERVIEW); Object.prototype.hasOwnProperty.call(issueDescriptor, this.issueContentTypes.OVERVIEW);
} }
getImmediateThreats() { getImmediateThreats() {
@ -476,9 +476,9 @@ class ReportPageComponent extends AuthComponent {
isIssueImmediateThreat(issueName) { isIssueImmediateThreat(issueName) {
let issueDescriptor = this.IssueDescriptorEnum[issueName]; let issueDescriptor = this.IssueDescriptorEnum[issueName];
return issueDescriptor.hasOwnProperty(this.issueContentTypes.TYPE) && return Object.prototype.hasOwnProperty.call(issueDescriptor, this.issueContentTypes.TYPE) &&
issueDescriptor[this.issueContentTypes.TYPE] === this.issueTypes.DANGER && issueDescriptor[this.issueContentTypes.TYPE] === this.issueTypes.DANGER &&
issueDescriptor.hasOwnProperty(this.issueContentTypes.OVERVIEW); Object.prototype.hasOwnProperty.call(issueDescriptor, this.issueContentTypes.OVERVIEW);
} }
getImmediateThreatsOverviews() { getImmediateThreatsOverviews() {
@ -597,8 +597,8 @@ class ReportPageComponent extends AuthComponent {
generateIssue = (issue) => { generateIssue = (issue) => {
let issueDescriptor = this.IssueDescriptorEnum[issue.type]; let issueDescriptor = this.IssueDescriptorEnum[issue.type];
let reportFnc = (issue) => {}; let reportFnc = {};
if (issue.hasOwnProperty('credential_type') && issue.credential_type !== null) { if (Object.prototype.hasOwnProperty.call(issue, 'credential_type') && issue.credential_type !== null) {
reportFnc = issueDescriptor[this.issueContentTypes.REPORT][issue.credential_type]; reportFnc = issueDescriptor[this.issueContentTypes.REPORT][issue.credential_type];
} else { } else {
reportFnc = issueDescriptor[this.issueContentTypes.REPORT]; reportFnc = issueDescriptor[this.issueContentTypes.REPORT];

View File

@ -1,7 +0,0 @@
class IssueDescriptor {
constructor(name, overviewComponent, reportComponent) {
this.name = name;
this.overviewComponent = overviewComponent;
this.reportComponent = reportComponent;
}
}

View File

@ -3,11 +3,11 @@ import CollapsibleWellComponent from '../CollapsibleWell';
import {generateInfoBadges} from './utils'; import {generateInfoBadges} from './utils';
export function sharedPasswordsIssueOverview() { export function sharedPasswordsIssueOverview() {
return (<li key={"shared_passwords"}>Multiple users have the same password</li>) return (<li key={'shared_passwords'}>Multiple users have the same password</li>)
} }
export function sharedAdminsDomainIssueOverview() { export function sharedAdminsDomainIssueOverview() {
return (<li key={"admin_domains"}>Shared local administrator account - Different machines have the same account as a local return (<li key={'admin_domains'}>Shared local administrator account - Different machines have the same account as a local
administrator.</li>) administrator.</li>)
} }

View File

@ -12,7 +12,7 @@ const columns = [
columns: [ columns: [
{ {
Header: 'Status', id: 'status', Header: 'Status', id: 'status',
accessor: x => { accessor: function getAccessor (x) {
return <StatusLabel status={x.status} size="3x" showText={false}/>; return <StatusLabel status={x.status} size="3x" showText={false}/>;
}, },
maxWidth: MAX_WIDTH_STATUS_COLUMN maxWidth: MAX_WIDTH_STATUS_COLUMN
@ -24,7 +24,7 @@ const columns = [
{ {
Header: 'Monkey Tests', id: 'tests', Header: 'Monkey Tests', id: 'tests',
style: {'whiteSpace': 'unset'}, // This enables word wrap style: {'whiteSpace': 'unset'}, // This enables word wrap
accessor: x => { accessor: function getAccessor (x) {
return <TestsStatus tests={x.tests}/>; return <TestsStatus tests={x.tests}/>;
} }
} }