Research
Security News
Malicious npm Package Targets Solana Developers and Hijacks Funds
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
@contentful/app-scripts
Advanced tools
@contentful/app-scripts
This project makes it easier to perform some recurrent operations in Contentful's App Framework.
Locally:
npm i @contentful/app-scripts
Globally:
npm i -g @contentful/app-scripts
When installed
$ contentful-app-scripts create-app-definition
Otherwise
$ npx @contentful/app-scripts create-app-definition
const { createAppDefinition } = require('@contentful/app-scripts');
const { myCustomLogic } = require('./my-custom-logic')(async function main() {
myCustomLogic();
await createAppDefinition.interactive();
})();
Scripts exported from this module will all be in the following shape
interface Script<Result, Options> {
// query the user or local cache for required information
interactive: () => Result;
// run by automation (`--ci` flag), they would need all the information upfront
nonInteractive: (...options: Options) => Result;
}
:warning: Please note
Both interactive and nonInteractive version of the same script is meant to return the same result.
Allows creating a new AppDefinition provided a Content Management Token (more details here).
It only runs in interactive mode.
Example
$ npx --no-install @contentful/app-scripts create-app-definition
Allows you to upload a build directory and create a new AppBundle that is bound to an AppDefinition. It runs in interactive or non-interactive mode.
Note: The command will automatically activate the bundle. To skip the activation you can pass the --skip-activation
argument in interactive and non-interactive mode and then manually activate it.
In the interactive mode, the CLI will ask for all required options.
Example
$ npx --no-install @contentful/app-scripts upload
When passing the --ci
argument the command will fail when the required variables are not set as arguments.
Example
$ npx --no-install @contentful/app-scripts upload --ci \ --bundle-dir ./built \ --organization-id some-org-id \ --definition-id some-app-def-id \ --token $MY_CONTENTFUL_PAT
Options:
Argument | Description | Default value |
---|---|---|
--bundle-dir | The directory of your build folder (e.g.: ./build ) | |
--organization-id | The ID of your organization | |
--definition-id | The ID of the app to which to add the bundle | |
--token | A personal access token | |
--skip-activation | (optional) Boolean flag to skip the automatic activation of the AppBundle | false |
--comment | (optional) A comment which will be associated with the created AppBundle . Can be used to differentiate bundles. | |
--host | (optional) Contentful CMA-endpoint to use | api.contentful.com |
Note: You can also pass all arguments in interactive mode to skip being asked for it.
Allows you to activate an AppBundle for an AppDefinition. When activated the app will serve the newly activated AppBundle.
In the interactive mode, the CLI will ask for all required options.
Example
$ npx --no-install @contentful/app-scripts activate
When passing the --ci
argument adding all variables as arguments is required.
Example
$ npx --no-install @contentful/app-scripts activate --ci \ --bundle-id some-bundle-id \ --organization-id some-org-id \ --definition-id some-app-def-id \ --token $MY_CONTENTFUL_PAT
Options:
Argument | Description | Default value |
---|---|---|
--bundle-id | The ID of the AppBundle you want to activate | |
--organization-id | The ID of your organization | |
--definition-id | The ID of the app to which to add the bundle | |
--token | A personal access token | |
--host | (optional) Contentful CMA-endpoint to use | api.contentful.com |
Note: You can also pass all arguments in interactive mode to skip being asked for it.
It opens the settings in the contentful web app so that you can use the UI to change the settings of an AppDefinition.
Example
$ npx --no-install @contentful/app-scripts open-settings --definition-id some-definition-id
You can also execute this command without the argument if the environment variable (CONTENTFUL_APP_DEF_ID
) has been set.
Example
$ CONTENTFUL_APP_DEF_ID=some-definition-id npx --no-install @contentful/app-scripts open-settings
Allows you to clean the list of previous bundles. It fetches the list and deletes all bundles except the 50 newest ones.
You can adjust the amount you want to keep by passing --keep <amount>
to the argument, if not passed, the default is 50.
In the interactive mode, the CLI will ask for all required options.
Example
$ npx --no-install @contentful/app-scripts bundle-cleanup
You can also execute this command without the argument if the environment variable (CONTENTFUL_APP_DEF_ID
) and (CONTENTFUL_ORG_ID
) has been set.
When passing the --ci
argument adding all variables as arguments is required
Example
$ npx --no-install @contentful/app-scripts bundle-cleanup --ci \ --organization-id some-org-id \ --definition-id some-app-def-id \ --token $MY_CONTENTFUL_PAT --keep 30
Options:
Argument | Description | Default value |
---|---|---|
--organization-id | The ID of your organization | |
--definition-id | The ID of the app to which to add the bundle | |
--token | A personal access token | |
--keep | (optional) The amount of bundles to keep | 50 |
--host | (optional) Contentful CMA-endpoint to use | api.contentful.com |
Note: You can also pass all arguments in interactive mode to skip being asked for it.
It opens a dialog to select the space and environment where the app associated with the given AppDefinition should be installed.
Example
$ npx --no-install @contentful/app-scripts install --definition-id some-definition-id
You can also execute this command without the argument if the environment variable (CONTENTFUL_APP_DEF_ID
) has been set.
Example
$ CONTENTFUL_APP_DEF_ID=some-definition-id npx --no-install @contentful/app-scripts install
By default, the script will install the app into the default host URL: app.contentful.com
. If you want to install the app into a different host URL, you can set the argument --host
to the desired host URL.
Example
$ npx --no-install @contentful/app-scripts install --definition-id some-definition-id --host api.eu.contentful.com
We gather depersonalized usage data of our CLI tools in order to improve experience. If you do not want your data to be gathered, you can opt out by providing an env variable DISABLE_ANALYTICS
set to any value:
Example
DISABLE_ANALYTICS=true npx create-contentful-app
FAQs
A collection of scripts for building Contentful Apps
The npm package @contentful/app-scripts receives a total of 9,456 weekly downloads. As such, @contentful/app-scripts popularity was classified as popular.
We found that @contentful/app-scripts demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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.
Research
Security News
A malicious npm package targets Solana developers, rerouting funds in 2% of transactions to a hardcoded address.
Security News
Research
Socket researchers have discovered malicious npm packages targeting crypto developers, stealing credentials and wallet data using spyware delivered through typosquats of popular cryptographic libraries.
Security News
Socket's package search now displays weekly downloads for npm packages, helping developers quickly assess popularity and make more informed decisions.