A remote scan is an alternate way to scan with no UI intervention. This can be done using a continuous integration toolchain, or manually via the command line. The results are then published on the UI automatically.

For languages such as C or C++, a strict mode remote scan can help to increase the accuracy of the scan.
Note: The repository type must be set to remote

How to download embold-scanner from Embold?

Download embold-scanner from your Embold Account’s section > Releases tab > CLI. There will be one file with names similar to the following: ‘browserstack-codequality-scanner-archive.tar.gz’.

Remote scan using embold-scanner

  1. Download the Embold CLI tool from control panel. Extract that Embold CLI tool and make sure it has all the executable permissions.
  2. Login to Embold server. Now create a Project in Embold. Read more about creating a new project here.
  3. Generate the Embold Access Token (EAT) for remote scan. Read more here for generating EAT.
  4. Create and link a remote repository with the language you want to scan. Download the repository configuration (repository-configuration.json) for this new remote repository added.

Commands

  1. embold-scanner – This command is applicable for Linux machines.
  2. embold-scanner.bat – This command is applicable for Windows machines.

Sub-commands

  1. analyse – Scans the local repository and publishes the scan results to the Embold UI.
  2. local-analyse – Scans the repository locally and store the results in csv without publishing to the Embold UI.
  3. gated-commit – Use to scan on changes files before the commit is performed.

Usage: embold-scanner analyse -am <arg> -b <arg> -c <arg> -d <arg> -h -l <arg> -r <arg> -s <arg> -sh <arg> -si <arg> -sp <arg> -s <arg> -t <arg> -u <arg> -vd <arg> -rn <arg> -ci <arg> -vd <arg> -sd <arg> -v

Example

  1. Linux:
    embold-scanner analyse -c <./repository configuration.json> -u <Embold URL> -t <Embold TOKEN> -b <BASE_DIR> -d <DATA_DIR> -s <snapshot name> -r <REPO UID> -sh <CORONA PACKAGE PATH> -l <LOG_FOLDER>
  2. Windows :
    embold-scanner.bat analyse -c <./repository configuration.json> -u <Embold URL> -t <Embold TOKEN> -b <BASE_DIR> -d <DATA_DIR> -s <snapshot name> -r <REPO UID> -sh <CORONA PACKAGE PATH> -l <LOG_FOLDER>

Options

-t,–token <arg>Embold Token
-u,–url <arg>Embold URL
-am,–analysis-mode <arg>Analysis Mode
-b,–repository-base-dir <arg>Scan will happen for this directory
-c,–scan-config-file <arg>Scan settings YAML/JSON file path
-d,–data-dir <arg>Data directory for temporary use
-h,–helpHelp
-l,–scanner-logs <arg>Embold scanner logs directory path
-r,–repository-uid <arg>The Data will be published in this
Repository in Embold UI
-s,–snapshot-label <arg>This label identifies the snapshot which
will be published on Embold UI after
successful scan. The value can also be
an environment variable
-sh,–scanner-home <arg>Embold scanner home path
-si,–session-id <arg>Session ID
-sp,–scan-profile <arg>Scan profile xml file path
-ssu, –skip-source-uploadSkip Source Upload
-rn,–revision-number <arg>SCM Revision NUmber
-ci,–component-uid <arg>SCM Component ID
-sd,–snapshot-id <arg>Snapshot id
-v,–verboseEnable verbose mode
-vd,–vcs_details <arg>vcs details
Options

After a successful remote scan, the below results will be displayed to the user.

On the successful scan, results are displayed on the console.

Prerequisites

  • If you are using CI/CD for C# remote scans, you need to install the DotNet-3.0.101 package if it is not already installed and then simply restart the machine.


  • File path use for -sh(scanner home), -l (scanner-logs) and -d(data directory) should have read write permission.
  • The following linters/tools must be installed on the remote machine.
LanguageLinterversion
CPPcppcheck2.8
C_SHARPmicrosoft_security_codescan5.6.2
TYPESCRIPTeslintv7.32.0
tslint5.9.1
JAVASCRIPTjshint2.9.5
eslintv7.32.0
GOstaticcheckv0.2.1
gosec2.8.1
gometalinterv2.0.0
PYTHONbandit1.7.0
pylint2.11.1
dlint0.11.0
PHPphpcs3.2.3
phpmd2.6.1
RUBYbrakeman5.1.1
KOTLINdetekt1.18.1
mobsfscan0.1.0
SOLIDITYsolhint3.3.6
SWIFTswiftlint0.32.0
APEXpmd6.39.0
HTMLhtmlhint0.15.1
SQLsqlcheck1
CSSstylelint14.15.1
INFRASTRUCTUREcheckov2.0.654
YAMLkubesec2.11.5
LUAluacheck0.23.0

Prerequisites to run remotescan for Swift

  • Install xcode on your macOS
  • Run below command and the output should be similar to the below screenshot
xcode-select -p
  • If your output is not as above screenshot then run the below command
sudo xcode-select -s /Applications/Xcode.app/Contents/Developer
  • Reverify the output of following command
xcode-select -p
  • your final output should be as below screenshot
  • Now run the remotescan

Configuration for https enabled Embold

  • Import the same set of certificates used for Embold in default jre keystore on standalone Corona machine.
  • Default jre path: Java/jre1.8.0_171/lib/security.
  • Below is the command:
    “keytool -import -trustcacerts -alias gamma -file “ ”-keystore cacerts”

Re-Analyse Snapshot

The Re-Analyse Snapshot feature allows users to update existing snapshots to reflect the latest code changes, ensuring accurate and up-to-date analysis.

Key Features:

  1. Snapshot Replacement:
    Re-analysed snapshots replace older ones with the same timestamp, removing outdated data while maintaining consistency.
  2. Timestamp Validation:
    • On the Issues page, the left-side timestamp reflects the older snapshot, while the right-side timestamp shows the updated one.
    • All timestamps in the updated snapshot will reflect newer data.
  3. Suppression Handling:
    • Suppressed issues in earlier snapshots are retained in the re-analysed snapshot.
    • If suppression is removed in the latest snapshot and re-analysed, the suppression data will no longer appear.
  4. Compatibility:
    • Works with both remote and normal scans.
    • Supports re-analysis for the most recent 30 snapshots.
  5. Gamma_Generic Compatibility:
    • Generic issues will not appear on the UI if a CSV is not provided during re-analysis.
    • Existing CSV files on the server are not replaced.

Benefits:

  • Keeps issue tracking and suppression data accurate across snapshots.
  • Provides a seamless way to reflect code changes without duplicating timestamps.
  • Works across different environments and scan types.

This feature ensures that snapshots remain up-to-date and accurate, enabling better analysis and tracking.

Check below command for Reanalyse-Snapshot ;

embold-scanner analyse -c <./repository configuration.json> -u <Embold URL> -t <Embold TOKEN> -b <BASE_DIR> -d <DATA_DIR> -s <snapshot name> -r <REPO UID> -sh <CORONA PACKAGE PATH> -l <LOG_FOLDER> -sd <Snapshot_id>

To find the snapshot_id, navigate to the Snapshots section of the repository and click the Copy button next to the desired snapshot.