
Product
Introducing GitHub Actions Scanning Support
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.
GScan is a tool for validating Ghost themes. It produces detailed reports of issues where themes need to be modified in order to be compatible with a specific version.
It is actively capable of dealing with the current and last major versions of Ghost (so at the time of writing v4, v3, v2 and v1).
GScan works on a system of rules. Each rule has a way to check whether it passes or fails and has help content which describes how to fix it. Each rule is also marked with an error level:
In addition, an error can be marked as fatal. A fatal error means, left unchecked a Ghost publication would throw 500 errors on certain pages because of the detected out-of-date or erroneous code.
There are 4 ways to use gscan to validate your theme:
Gscan is pre-installed in Ghost. If there are theme errors, Ghost will show them on boot in the console logs and in the UI (Ghost Admin).
Visit https://gscan.ghost.org and upload your zip to our online version of Gscan.
Install using yarn / npm:
yarn global add gscan
/ npm install -g gscan
To run a local directory through the checks:
gscan /path/to/theme/directory
To run a local zip file through the checks:
gscan /path/to/theme.zip -z
By default, GScan scans themes for the latest Ghost version compatibility. You can also specify a Ghost version by using the following parameters (for Ghost 1.0, 2.0, 3.0, 4.0, 5.0 and 6.0):
--v1
or -1
--v2
or -2
--v3
or -3
--v4
or -4
--v5
or -5
(default)
--v6
or -6
or --canary
Examples:
gscan /path/to/theme.zip -z -1
- scan a theme in a zip file for Ghost 1.0 compatibility
gscan /path/to/theme/directory --v2
- can a theme in a directory for Ghost 2.0 compatibility
gscan /path/to/theme/directory
- scan a theme for Ghost 5.0 compatibility
Install using yarn/npm and then:
var gscan = require('gscan');
gscan.checkZip({
path: 'path-to-zip',
// Pass in a folder to check
// if you need to check the theme for a different
// major Ghost version, you can pass it. Currently
// v1, v2, v3, v4, v5 and v6 are supported. Default is
// the latest Ghost version 5.0:
// checkVersion: 'v5',
name: 'my-theme'
}).then(function (result) {
console.log(result);
}).catch(function(err) {
console.log(err);
});
yarn dev
yarn start
./bin/cli.js -z /path/to/your/theme.zip
./bin/cli.js /path/to/directory
(Core team only)
yarn ship
When developing new rules or testing gscan following tools are great to have in the toolbelt:
Copyright (c) 2013-2025 Ghost Foundation - Released under the MIT license. Ghost and the Ghost Logo are trademarks of Ghost Foundation Ltd. Please see our trademark policy for info on acceptable usage.
FAQs
Scans Ghost themes looking for errors, deprecations, features and compatibility
The npm package gscan receives a total of 6,795 weekly downloads. As such, gscan popularity was classified as popular.
We found that gscan demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 29 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.
Product
Add real-time Socket webhook events to your workflows to automatically receive pull request scan results and security alerts in real time.
Research
The Socket Threat Research Team uncovered malicious NuGet packages typosquatting the popular Nethereum project to steal wallet keys.