Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

hops-config

Package Overview
Dependencies
Maintainers
1
Versions
225
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

hops-config

Hops core configuration

  • 9.5.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
243
increased by4.74%
Maintainers
1
Weekly downloads
 
Created
Source

Hops Config

npm

hops-config exposes options to configure the other Hops packages and your own application. It is quite flexible and highly extensible.

Installation

In case you want to extend the configuration or access it from your server/browser code, you should explicitly add hops-config as a dependency to your project.
Otherwise it will be installed through the other hops packages and doesn't need to be installed directly.

npm install --save hops-config

Usage

Please find a list of the default options below. They can be set in your project's package.json and can be overridden by using npm config in the command line. You can extend hops-config within your project allowing you to use it to configure your isomorphic applications. The configuration is immutable at runtime - if you import it in your own application, you can only read its values, but you cannot alter them.

Available Options

FieldTypeDescription
httpsBooleanWhether to use https or not. Defaults to false
hostStringHost name of your project. Defaults to 0.0.0.0
portNumberPort of your host. Defaults to 8080
locationsArray<string>One or more application shell locations, e.g. "/" and/or "/profile"
basePathStringRoot path of your application on the server. This is inserted as an HTTP path prefix between host and locations. For example, if you set e.g. "basePath": "my-custom-basepath" and "location": ["/profile"], then your application would be available at http://0.0.0.0:8080/my-custom-basepath/profile/
assetPathStringHTTP root path of your asset files on the server. It's not dependent on basePath, you can define totally separate directories
browsersStringBrowserslist query. Defaults to "> 1%, last 2 versions, Firefox ESR" (which is also the Browserlist default query). It is used for Babel and PostCSS
nodeStringNode target version. Defaults to current. It is used to specify the Node version which Babel should compile for
envVars{ HOPS_MODE: 'dynamic' }Environment variables meant to be passed to webpack.EnvironmentPlugin, i.e. made accessible to your app
moduleDirsArray<string>One or more directories that Hops should use for module path resolution. For example, you can specify a directory that holds a yet unpublished Node.js package. It works similar to the resolve.modulesDirectories field in Webpack, i.e. if you specify moduleDirs: ["my-module-dir"], it will look in ./my-module-dir, ../my-module-dir, ../../my-module-dir and so on
appDirStringDirectory of your app. This way, you can put your app to a place other than project root. Defaults to "."
buildDirStringDirectory where the build artifacts (i.e. your application/asset files) will be saved to. Defaults to "build". Hops always removes the specified directory before starting a new build
cacheDirStringDirectory where internally used artifacts not meant to be served will be output (e.g. the manifest.json/manifest.js files generated by Webpack). Defaults to "node_modules/.cache/hops"
buildConfigStringPath to your Webpack build configuration file. Defaults to undefined - use this option in your package.json to overwrite the default configuration. Read more about it at hops-build-config
developConfigStringPath to your Webpack development configuration file. Defaults to undefined - use this option in your package.json to overwrite the default configuration. Read more about it at hops-build-config
nodeConfigStringPath to your Webpack node/server-side rendering configuration file. Defaults to undefined - use this option in your package.json to overwrite the default configuration. Read more about it athops-build-config
manifestStringThe application's manifest.js as a string. Defaults to a getter function that returns the content of the automatically generated manifest.js
assetsObject literalThe applications's .js and .css assets. Defaults to a getter function that returns the assets contained in the automatically generated manifest.json
extendsStringPath to a baseline configuration (could be for example a node module or a project-specific file), allowing you join the current configuration with that baseline

All keys matching /(config|file|dir)s?$/i will be treated as a filesystem path (or array thereof) and resolved relative to your app's root folder. This only applies if the respective value is not an absolute path already.

Configure via package.json

The following example package.json shows how the config object might look like:

"name": "my-application",
"scripts": {
    "build": "hops build",
    "develop": "hops develop",
    "serve": "hops serve",
    "start": "hops start",
    "test": "echo \"Error: no test specified\" && exit 1"
  },
"config": {
    "hops": {
      "extends": "path-to-my-hops-config/config.js",
      "https": true,
      "host": "0.0.0.0",
      "port": 3000,
      "locations": [
        "/",
        "/foo"
      ],
      "basePath": "my-base-path",
      "assetPath": "my-asset-path",
      "browsers": "> 2%, last 1 versions, Firefox ESR",
      "moduleDirs": [
        "my-unpublished-packages"
      ],
      "appDir": "my-app-directory",
      "buildDir": "my-build-directory",
      "cacheDir": "my-cache-directory",
      "buildConfig": "path-to-my-custom-webpack-config/build.js"
    }
  }

Configure via CLI

You can override the configuration values defined in your package.json. Consider the above package.json and let's say you want to want to override the port value. Note that this only works in an "npm like" context, i.e. with npm and yarn.

To override the port value for your local environment without actually changing your package.json, set the respective npm environment variable...

npm config set my-application:hops:port 1337

... and then run...

npm start

... which will start your server on port 1337.

Custom Webpack Configuration

For further information on how to extend the base webpack configurations head over to: hops-build-config.

Keywords

FAQs

Package last updated on 09 Jan 2018

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc