Apify command-line interface (Apify CLI) helps you create, develop, build and run Apify Actors, and manage the Apify cloud platform from any computer.
Apify Actors are cloud programs that can perform arbitrary web scraping, automation or data processing job. They accept input, perform their job and generate output. While you can develop Actors in an online IDE directly in the Apify web application, for complex projects it is more convenient to develop Actors locally on your computer using Apify SDK and only push the Actors to the Apify cloud during deployment. This is where the Apify CLI comes in.
Note that Actors running on the Apify platform are executed in Docker containers, so with an appropriate Dockerfile
you can build your Actors in any programming language.
However, we recommend using JavaScript / Node.js, for which we provide most libraries and support.
On macOS (or Linux), you can install the Apify CLI via the Homebrew package manager.
brew install apify-cli
First, make sure you have Node.js version 16 or higher with NPM installed on your computer:
node --version
npm --version
Install or upgrade Apify CLI by running:
npm -g install apify-cli
If you receive an EACCES
error, you might need to run the command as root:
sudo npm -g install apify-cli
Alternatively, you can use Node Version Manager (nvm) and install Apify CLI only into a selected user-level Node version without requiring root privileges:
nvm install 16
nvm use 16
npm -g install apify-cli
Finally, verify that Apify CLI was installed correctly by running:
apify --version
which should print something like:
apify-cli/0.10.0 darwin-x64 node-v16.14.2
You can also skip the manual global installation altogether and use
npx apify-cli
with all the following commands instead.
The following examples demonstrate the basic usage of Apify CLI.
apify create my-hello-world
First, you will be prompted to select a template with the boilerplate for the Actor, to help you get started quickly.
The command will create a directory called my-hello-world
that contains a Node.js project
for the Actor and a few configuration files.
If you decided to skip the installation and go with
npx
, the command will benpx apify-cli create my-hello-world
.
cd ./my/awesome/project
apify init
This command will only set up local Actor development environment in an existing directory,
i.e. it will create the .actor/actor.json
file and apify_storage
directory.
Before you can run your project locally using apify run
, you have to set up the right start command in package.json
under scripts.start. For example:
{
...
"scripts": {
"start": "node your_main_file.js",
},
...
}
You can find more information about by running apify help run
.
If you want to run a Scrapy project on Apify platform, follow the Scrapy integration guide here.
cd my-hello-world
apify run
This command runs the Actor on your local machine. Now's your chance to develop the logic - or magic 😏
apify login
Before you can interact with the Apify cloud, you need to create an Apify account
and log in to it using the above command. You will be prompted for
your Apify API token.
Note that the command will store the API token and other sensitive information to ~/.apify
.
apify push
This command uploads your project to the Apify cloud and builds an Actor from it. On the platform, Actor needs to be built before it can be run.
apify call
Runs the Actor corresponding to the current directory on the Apify platform.
This command can also be used to run other Actors, for example:
apify call apify/hello-world
This file associates your local development project with an Actor on the Apify platform. It contains information such as Actor name, version, build tag and environment variables. Make sure you commit this file to the Git repository.
For example, .actor/actor.json
file can look as follows:
{
"actorSpecification": 1,
"name": "name-of-my-scraper",
"version": "0.0",
"buildTag": "latest",
"environmentVariables": {
"MYSQL_USER": "my_username",
"MYSQL_PASSWORD": "@mySecretPassword"
},
"dockerfile": "./Dockerfile",
"readme": "./ACTOR.md",
"input": "./input_schema.json",
"storages": {
"dataset": "./dataset_schema.json"
}
}
Dockerfile
field
If you specify the path to your Docker file under the dockerfile
field, this file will be used for Actor builds on the platform. If not specified, the system will look for Docker files at .actor/Dockerfile
and Dockerfile
in this order of preference.
Readme
field
If you specify the path to your readme file under the readme
field, the readme at this path will be used on the platform. If not specified, readme at .actor/README.md
and README.md
will be used in this order of preference.
Input
field
You can embed your input schema object directly in actor.json
under input
field. Alternatively, you can provide a path to a custom input schema. If not provided, the input schema at .actor/INPUT_SCHEMA.json
and INPUT_SCHEMA.json
is used in this order of preference.
Storages.dataset
field
You can define the schema of the items in your dataset under the storages.dataset
field. This can be either an embedded object or a path to a JSON schema file. You can read more about the schema of your Actor output here.
Note on migration from deprecated config "apify.json"
Note that previously, Actor config was stored in the apify.json
file that has been deprecated. You can find the (very slight) differences and migration info in migration guidelines.
There are two options how you can set up environment variables for Actors.
All keys from env
will be set as environment variables into Apify platform after you push Actor to Apify. Current values on Apify will be overridden.
{
"actorSpecification": 1,
"name": "dataset-to-mysql",
"version": "0.1",
"buildTag": "latest",
"environmentVariables": {
"MYSQL_USER": "my_username",
"MYSQL_PASSWORD": "@mySecretPassword"
}
}
In Apify Console select your Actor, you can set up variables into Source tab.
After setting up variables in the app, remove the environmentVariables
from .actor/actor.json
. Otherwise, variables from .actor/actor.json
will override variables in the app.
{
"actorSpecification": 1,
"name": "dataset-to-mysql",
"version": "0.1",
"buildTag": "latest"
}
CLI provides commands to manage secrets environment variables. Secrets are stored to the ~/.apify
directory.
You can add a new secret using the command:
apify secrets:add mySecretPassword pwd1234
After adding a new secret you can use the secret in .actor/actor.json
.
{
"actorSpecification": 1,
"name": "dataset-to-mysql",
...
"environmentVariables": {
"MYSQL_PASSWORD": "@mySecretPassword"
},
...
}
To see all CLI commands simply run:
apify help
To get information about a specific command run:
apify help COMMAND
Still haven't found what you were looking for? Please go to Apify Help center or contact us.
This section contains printouts of apify help
for all commands.
apify actor
apify actor get-input
apify actor get-value KEY
apify actor push-data [ITEM]
apify actor set-value KEY [VALUE]
apify actors
apify actors build [ACTORID]
apify actors call [ACTORID]
apify actors info ACTORID
apify actors ls
apify actors pull [ACTORID]
apify actors push [ACTORID]
apify actors rm ACTORID
apify actors start [ACTORID]
apify builds
apify builds create [ACTORID]
apify builds info BUILDID
apify builds log BUILDID
apify builds ls [ACTORID]
apify builds rm BUILDID
apify call [ACTORID]
apify create [ACTORNAME]
apify datasets
apify datasets create [DATASETNAME]
apify datasets get-items DATASETID
apify datasets info STOREID
apify datasets ls
apify datasets push-items NAMEORID [ITEM]
apify datasets rename NAMEORID [NEWNAME]
apify datasets rm DATASETNAMEORID
apify help [COMMAND]
apify info
apify init [ACTORNAME]
apify key-value-stores
apify key-value-stores create [KEYVALUESTORENAME]
apify key-value-stores delete-value STOREID ITEMKEY
apify key-value-stores get-value KEYVALUESTOREID ITEMKEY
apify key-value-stores info STOREID
apify key-value-stores keys STOREID
apify key-value-stores ls
apify key-value-stores rename KEYVALUESTORENAMEORID [NEWNAME]
apify key-value-stores rm KEYVALUESTORENAMEORID
apify key-value-stores set-value STOREID ITEMKEY [VALUE]
apify login
apify logout
apify pull [ACTORID]
apify push [ACTORID]
apify request-queues
apify run
apify runs
apify runs abort RUNID
apify runs info RUNID
apify runs log RUNID
apify runs ls [ACTORID]
apify runs resurrect RUNID
apify runs rm RUNID
apify secrets
apify secrets add NAME VALUE
apify secrets rm NAME
apify task
apify task run TASKID
apify validate-schema [PATH]
Manages runtime data operations inside of a running Actor.
USAGE
$ apify actor
DESCRIPTION
Manages runtime data operations inside of a running Actor.
See code: src/commands/actor/index.ts
Gets the Actor input value from the default key-value store associated with the Actor run.
USAGE
$ apify actor get-input
DESCRIPTION
Gets the Actor input value from the default key-value store associated with the Actor run.
See code: src/commands/actor/get-input.ts
Gets a value from the default key-value store associated with the Actor run.
USAGE
$ apify actor get-value KEY
ARGUMENTS
KEY Key of the record in key-value store
DESCRIPTION
Gets a value from the default key-value store associated with the Actor run.
See code: src/commands/actor/get-value.ts
Saves data to Actor's run default dataset.
USAGE
$ apify actor push-data [ITEM]
ARGUMENTS
ITEM JSON string with one object or array of objects containing data to be stored in the default dataset.
DESCRIPTION
Saves data to Actor's run default dataset.
Accept input as:
- JSON argument:
$ apify actor push-data {"key": "value"}
- Piped stdin:
$ cat ./test.json | apify actor push-data
See code: src/commands/actor/push-data.ts
Sets or removes record into the default key-value store associated with the Actor run.
USAGE
$ apify actor set-value KEY [VALUE] [-c <value>]
ARGUMENTS
KEY Key of the record in key-value store.
VALUE Record data, which can be one of the following values:
- If empty, the record in the key-value store is deleted.
- If no `contentType` flag is specified, value is expected to be any JSON string value.
- If options.contentType is set, value is taken as is.
FLAGS
-c, --contentType=<value> Specifies a custom MIME content type of the record. By default "application/json" is used.
DESCRIPTION
Sets or removes record into the default key-value store associated with the Actor run.
It is possible to pass data using argument or stdin.
Passing data using argument:
$ apify actor set-value KEY my-value
Passing data using stdin with pipe:
$ cat ./my-text-file.txt | apify actor set-value KEY --contentType text/plain
See code: src/commands/actor/set-value.ts
Manages Actor creation, deployment, and execution on the Apify platform.
USAGE
$ apify actors
DESCRIPTION
Manages Actor creation, deployment, and execution on the Apify platform.
See code: src/commands/actors/index.ts
Creates a new build of the Actor.
USAGE
$ apify actors build [ACTORID] [--json] [--tag <value>] [--version <value>] [--log]
ARGUMENTS
ACTORID Optional Actor ID or Name to trigger a build for. By default, it will use the Actor from the current
directory.
FLAGS
--log Whether to print out the build log after the build is triggered.
--tag=<value> Build tag to be applied to the successful Actor build. By default, this is "latest".
--version=<value> Optional Actor Version to build. By default, this will be inferred from the tag, but this flag is
required when multiple versions have the same tag.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Creates a new build of the Actor.
See code: src/commands/actors/build.ts
Executes Actor remotely using your authenticated account.
USAGE
$ apify actors call [ACTORID] [--json] [-b <value>] [-t <value>] [-m <value>] [-i <value> | --input-file
<value>] [-s] [-o]
ARGUMENTS
ACTORID Name or ID of the Actor to run (e.g. "my-actor", "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not
provided, the command runs the remote Actor specified in the '.actor/actor.json' file.
FLAGS
-b, --build=<value> Tag or number of the build to run (e.g. "latest" or "1.2.34").
-i, --input=<value> Optional JSON input to be given to the Actor.
-m, --memory=<value> Amount of memory allocated for the Actor run, in megabytes.
-o, --output-dataset Prints out the entire default dataset on successful run of the Actor.
-s, --silent Prevents printing the logs of the Actor run to the console.
-t, --timeout=<value> Timeout for the Actor run in seconds. Zero value means there is no timeout.
--input-file=<value> Optional path to a file with JSON input to be given to the Actor. The file must be a valid
JSON file. You can also specify `-` to read from standard input.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Executes Actor remotely using your authenticated account.
Reads input from local key-value store by default.
See code: src/commands/actors/call.ts
Get information about an Actor.
USAGE
$ apify actors info ACTORID [--json] [--readme | --input]
ARGUMENTS
ACTORID The ID of the Actor to return information about.
FLAGS
--input Return the Actor input schema.
--readme Return the Actor README.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Get information about an Actor.
See code: src/commands/actors/info.ts
Prints a list of recently executed Actors or Actors you own.
USAGE
$ apify actors ls [--json] [--my] [--offset <value>] [--limit <value>] [--desc]
FLAGS
--desc Sort Actors in descending order.
--limit=<value> [default: 20] Number of Actors that will be listed.
--my Whether to list Actors made by the logged in user.
--offset=<value> Number of Actors that will be skipped.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Prints a list of recently executed Actors or Actors you own.
See code: src/commands/actors/ls.ts
Download Actor code to current directory. Clones Git repositories or fetches Actor files based on the source type.
USAGE
$ apify actors pull [ACTORID] [-v <value>] [--dir <value>]
ARGUMENTS
ACTORID Name or ID of the Actor to run (e.g. "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not provided, the
command will update the Actor in the current directory based on its name in ".actor/actor.json" file.
FLAGS
-v, --version=<value> Actor version number which will be pulled, e.g. 1.2. Default: the highest version
--dir=<value> Directory where the Actor should be pulled to
DESCRIPTION
Download Actor code to current directory. Clones Git repositories or fetches Actor files based on the source type.
See code: src/commands/actors/pull.ts
Deploys Actor to Apify platform using settings from '.actor/actor.json'.
USAGE
$ apify actors push [ACTORID] [-v <value>] [-b <value>] [-w <value>] [--no-prompt] [--force] [--dir <value>]
ARGUMENTS
ACTORID Name or ID of the Actor to push (e.g. "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not provided, the
command will create or modify the Actor with the name specified in '.actor/actor.json' file.
FLAGS
-b, --build-tag=<value> Build tag to be applied to the successful Actor build. By default, it is taken from the
'.actor/actor.json' file
-v, --version=<value> Actor version number to which the files should be pushed. By default, it is taken from
the '.actor/actor.json' file.
-w, --wait-for-finish=<value> Seconds for waiting to build to finish, if no value passed, it waits forever.
--dir=<value> Directory where the Actor is located
--force Push an Actor even when the local files are older than the Actor on the platform.
--no-prompt Do not prompt for opening the Actor details in a browser. This will also not open the
browser automatically.
DESCRIPTION
Deploys Actor to Apify platform using settings from '.actor/actor.json'.
Files under '3' MB upload as "Multiple source files"; larger projects upload as ZIP file.
Use --force to override newer remote versions.
See code: src/commands/actors/push.ts
Permanently removes an Actor from your account.
USAGE
$ apify actors rm ACTORID
ARGUMENTS
ACTORID The Actor ID to delete.
DESCRIPTION
Permanently removes an Actor from your account.
See code: src/commands/actors/rm.ts
Starts Actor remotely and returns run details immediately.
USAGE
$ apify actors start [ACTORID] [--json] [-b <value>] [-t <value>] [-m <value>] [-i <value> | --input-file
<value>]
ARGUMENTS
ACTORID Name or ID of the Actor to run (e.g. "my-actor", "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not
provided, the command runs the remote Actor specified in the '.actor/actor.json' file.
FLAGS
-b, --build=<value> Tag or number of the build to run (e.g. "latest" or "1.2.34").
-i, --input=<value> Optional JSON input to be given to the Actor.
-m, --memory=<value> Amount of memory allocated for the Actor run, in megabytes.
-t, --timeout=<value> Timeout for the Actor run in seconds. Zero value means there is no timeout.
--input-file=<value> Optional path to a file with JSON input to be given to the Actor. The file must be a valid
JSON file. You can also specify `-` to read from standard input.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Starts Actor remotely and returns run details immediately.
Uses authenticated account and local key-value store for input.
See code: src/commands/actors/start.ts
Manages Actor build processes and versioning.
USAGE
$ apify builds
DESCRIPTION
Manages Actor build processes and versioning.
See code: src/commands/builds/index.ts
Creates a new build of the Actor.
USAGE
$ apify builds create [ACTORID] [--json] [--tag <value>] [--version <value>] [--log]
ARGUMENTS
ACTORID Optional Actor ID or Name to trigger a build for. By default, it will use the Actor from the current
directory.
FLAGS
--log Whether to print out the build log after the build is triggered.
--tag=<value> Build tag to be applied to the successful Actor build. By default, this is "latest".
--version=<value> Optional Actor Version to build. By default, this will be inferred from the tag, but this flag is
required when multiple versions have the same tag.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Creates a new build of the Actor.
See code: src/commands/builds/create.ts
Prints information about a specific build.
USAGE
$ apify builds info BUILDID [--json]
ARGUMENTS
BUILDID The build ID to get information about.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Prints information about a specific build.
See code: src/commands/builds/info.ts
Prints the log of a specific build.
USAGE
$ apify builds log BUILDID
ARGUMENTS
BUILDID The build ID to get the log from.
DESCRIPTION
Prints the log of a specific build.
See code: src/commands/builds/log.ts
Lists all builds of the Actor.
USAGE
$ apify builds ls [ACTORID] [--json] [--offset <value>] [--limit <value>] [--desc] [-c]
ARGUMENTS
ACTORID Optional Actor ID or Name to list runs for. By default, it will use the Actor from the current directory.
FLAGS
-c, --compact Display a compact table.
--desc Sort builds in descending order.
--limit=<value> [default: 10] Number of builds that will be listed.
--offset=<value> Number of builds that will be skipped.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Lists all builds of the Actor.
See code: src/commands/builds/ls.ts
Permanently removes an Actor build from the Apify platform.
USAGE
$ apify builds rm BUILDID
ARGUMENTS
BUILDID The build ID to delete.
DESCRIPTION
Permanently removes an Actor build from the Apify platform.
See code: src/commands/builds/rm.ts
Executes Actor remotely using your authenticated account.
USAGE
$ apify call [ACTORID] [--json] [-b <value>] [-t <value>] [-m <value>] [-i <value> | --input-file
<value>] [-s] [-o]
ARGUMENTS
ACTORID Name or ID of the Actor to run (e.g. "my-actor", "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not
provided, the command runs the remote Actor specified in the '.actor/actor.json' file.
FLAGS
-b, --build=<value> Tag or number of the build to run (e.g. "latest" or "1.2.34").
-i, --input=<value> Optional JSON input to be given to the Actor.
-m, --memory=<value> Amount of memory allocated for the Actor run, in megabytes.
-o, --output-dataset Prints out the entire default dataset on successful run of the Actor.
-s, --silent Prevents printing the logs of the Actor run to the console.
-t, --timeout=<value> Timeout for the Actor run in seconds. Zero value means there is no timeout.
--input-file=<value> Optional path to a file with JSON input to be given to the Actor. The file must be a valid
JSON file. You can also specify `-` to read from standard input.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Executes Actor remotely using your authenticated account.
Reads input from local key-value store by default.
See code: src/commands/call.ts
Creates an Actor project from a template in a new directory.
USAGE
$ apify create [ACTORNAME] [-t <value>] [--skip-dependency-install] [--omit-optional-deps]
ARGUMENTS
ACTORNAME Name of the Actor and its directory
FLAGS
-t, --template=<value> Template for the Actor. If not provided, the command will prompt for it.
Visit
https://raw.githubusercontent.com/apify/actor-templates/master/templates/manifest.json
to find available template names.
--omit-optional-deps Skip installing optional dependencies.
--skip-dependency-install Skip installing Actor dependencies.
DESCRIPTION
Creates an Actor project from a template in a new directory.
See code: src/commands/create.ts
Manages structured data storage and retrieval.
USAGE
$ apify datasets
DESCRIPTION
Manages structured data storage and retrieval.
See code: src/commands/datasets/index.ts
Creates a new dataset for storing structured data on your account.
USAGE
$ apify datasets create [DATASETNAME] [--json]
ARGUMENTS
DATASETNAME Optional name for the Dataset
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Creates a new dataset for storing structured data on your account.
See code: src/commands/datasets/create.ts
Retrieves dataset items in specified format (JSON, CSV, etc).
USAGE
$ apify datasets get-items DATASETID [--limit <value>] [--offset <value>] [--format json|jsonl|csv|html|rss|xml|xlsx]
ARGUMENTS
DATASETID The ID of the Dataset to export the items for
FLAGS
--format=<option> [default: json] The format of the returned output. By default, it is set to 'json'
<options: json|jsonl|csv|html|rss|xml|xlsx>
--limit=<value> The amount of elements to get from the dataset. By default, it will return all available items.
--offset=<value> The offset in the dataset where to start getting items.
DESCRIPTION
Retrieves dataset items in specified format (JSON, CSV, etc).
See code: src/commands/datasets/get-items.ts
Prints information about a specific dataset.
USAGE
$ apify datasets info STOREID [--json]
ARGUMENTS
STOREID The dataset store ID to print information about.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Prints information about a specific dataset.
See code: src/commands/datasets/info.ts
Prints all datasets on your account.
USAGE
$ apify datasets ls [--json] [--offset <value>] [--limit <value>] [--desc] [--unnamed]
FLAGS
--desc Sorts datasets in descending order.
--limit=<value> [default: 20] Number of datasets that will be listed.
--offset=<value> Number of datasets that will be skipped.
--unnamed Lists datasets that don't have a name set.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Prints all datasets on your account.
See code: src/commands/datasets/ls.ts
Adds data items to specified dataset. Accepts single object or array of objects.
USAGE
$ apify datasets push-items NAMEORID [ITEM]
ARGUMENTS
NAMEORID The dataset ID or name to push the objects to
ITEM The object or array of objects to be pushed.
DESCRIPTION
Adds data items to specified dataset. Accepts single object or array of objects.
See code: src/commands/datasets/push-items.ts
Change dataset name or removes name with --unname flag.
USAGE
$ apify datasets rename NAMEORID [NEWNAME] [--unname]
ARGUMENTS
NAMEORID The dataset ID or name to delete.
NEWNAME The new name for the dataset.
FLAGS
--unname Removes the unique name of the dataset.
DESCRIPTION
Change dataset name or removes name with --unname flag.
See code: src/commands/datasets/rename.ts
Permanently removes a dataset.
USAGE
$ apify datasets rm DATASETNAMEORID
ARGUMENTS
DATASETNAMEORID The dataset ID or name to delete
DESCRIPTION
Permanently removes a dataset.
See code: src/commands/datasets/rm.ts
Display help for apify.
USAGE
$ apify help [COMMAND...] [-n]
ARGUMENTS
COMMAND... Command to show help for.
FLAGS
-n, --nested-commands Include all nested commands in the output.
DESCRIPTION
Display help for apify.
See code: @oclif/plugin-help
Prints details about your currently authenticated Apify account.
USAGE
$ apify info
DESCRIPTION
Prints details about your currently authenticated Apify account.
See code: src/commands/info.ts
Sets up an Actor project in your current directory by creating actor.json and storage files.
USAGE
$ apify init [ACTORNAME] [-y]
ARGUMENTS
ACTORNAME Name of the Actor. If not provided, you will be prompted for it.
FLAGS
-y, --yes Automatic yes to prompts; assume "yes" as answer to all prompts. Note that in some cases, the command may
still ask for confirmation.
DESCRIPTION
Sets up an Actor project in your current directory by creating actor.json and storage files.
If the directory contains a Scrapy project in Python, the command automatically creates wrappers so that you can run
your scrapers without changes.
Creates the '.actor/actor.json' file and the 'storage' directory in the current directory, but does not touch any
other existing files or directories.
WARNING: Overwrites existing 'storage' directory.
See code: src/commands/init.ts
Manages persistent key-value storage.
USAGE
$ apify key-value-stores
DESCRIPTION
Manages persistent key-value storage.
Alias: kvs
See code: src/commands/key-value-stores/index.ts
Creates a new key-value store on your account.
USAGE
$ apify key-value-stores create [KEYVALUESTORENAME] [--json]
ARGUMENTS
KEYVALUESTORENAME Optional name for the key-value store
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Creates a new key-value store on your account.
See code: src/commands/key-value-stores/create.ts
Delete a value from a key-value store.
USAGE
$ apify key-value-stores delete-value STOREID ITEMKEY
ARGUMENTS
STOREID The key-value store ID to delete the value from.
ITEMKEY The key of the item in the key-value store.
DESCRIPTION
Delete a value from a key-value store.
See code: src/commands/key-value-stores/delete-value.ts
Retrieves stored value for specified key. Use --only-content-type to check MIME type.
USAGE
$ apify key-value-stores get-value KEYVALUESTOREID ITEMKEY [--only-content-type]
ARGUMENTS
KEYVALUESTOREID The key-value store ID to get the value from.
ITEMKEY The key of the item in the key-value store.
FLAGS
--only-content-type Only return the content type of the specified key
DESCRIPTION
Retrieves stored value for specified key. Use --only-content-type to check MIME type.
See code: src/commands/key-value-stores/get-value.ts
Shows information about a key-value store.
USAGE
$ apify key-value-stores info STOREID [--json]
ARGUMENTS
STOREID The key-value store ID to print information about.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Shows information about a key-value store.
See code: src/commands/key-value-stores/info.ts
Lists all keys in a key-value store.
USAGE
$ apify key-value-stores keys STOREID [--json] [--limit <value>] [--exclusive-start-key <value>]
ARGUMENTS
STOREID The key-value store ID to list keys for.
FLAGS
--exclusive-start-key=<value> The key to start the list from.
--limit=<value> [default: 20] The maximum number of keys to return.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Lists all keys in a key-value store.
See code: src/commands/key-value-stores/keys.ts
Lists all key-value stores on your account.
USAGE
$ apify key-value-stores ls [--json] [--offset <value>] [--limit <value>] [--desc] [--unnamed]
FLAGS
--desc Sorts key-value stores in descending order.
--limit=<value> [default: 20] Number of key-value stores that will be listed.
--offset=<value> Number of key-value stores that will be skipped.
--unnamed Lists key-value stores that don't have a name set.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Lists all key-value stores on your account.
See code: src/commands/key-value-stores/ls.ts
Renames a key-value store, or removes its unique name.
USAGE
$ apify key-value-stores rename KEYVALUESTORENAMEORID [NEWNAME] [--unname]
ARGUMENTS
KEYVALUESTORENAMEORID The key-value store ID or name to delete
NEWNAME The new name for the key-value store
FLAGS
--unname Removes the unique name of the key-value store
DESCRIPTION
Renames a key-value store, or removes its unique name.
See code: src/commands/key-value-stores/rename.ts
Permanently removes a key-value store.
USAGE
$ apify key-value-stores rm KEYVALUESTORENAMEORID
ARGUMENTS
KEYVALUESTORENAMEORID The key-value store ID or name to delete
DESCRIPTION
Permanently removes a key-value store.
See code: src/commands/key-value-stores/rm.ts
Stores value with specified key. Set content-type with --content-type flag.
USAGE
$ apify key-value-stores set-value STOREID ITEMKEY [VALUE] [--content-type <value>]
ARGUMENTS
STOREID The key-value store ID to set the value in.
ITEMKEY The key of the item in the key-value store.
VALUE The value to set.
FLAGS
--content-type=<value> [default: application/json] The MIME content type of the value. By default, "application/json"
is assumed.
DESCRIPTION
Stores value with specified key. Set content-type with --content-type flag.
See code: src/commands/key-value-stores/set-value.ts
Authenticates your Apify account and saves credentials to '~/.apify'.
USAGE
$ apify login [-t <value>] [-m console|manual]
FLAGS
-m, --method=<option> [Optional] Method of logging in to Apify
<options: console|manual>
-t, --token=<value> [Optional] Apify API token
DESCRIPTION
Authenticates your Apify account and saves credentials to '~/.apify'.
All other commands use these stored credentials.
Run 'apify logout' to remove authentication.
See code: src/commands/login.ts
Removes authentication by deleting your API token and account information from '~/.apify'.
USAGE
$ apify logout
DESCRIPTION
Removes authentication by deleting your API token and account information from '~/.apify'.
Run 'apify login' to authenticate again.
See code: src/commands/logout.ts
Download Actor code to current directory. Clones Git repositories or fetches Actor files based on the source type.
USAGE
$ apify pull [ACTORID] [-v <value>] [--dir <value>]
ARGUMENTS
ACTORID Name or ID of the Actor to run (e.g. "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not provided, the
command will update the Actor in the current directory based on its name in ".actor/actor.json" file.
FLAGS
-v, --version=<value> Actor version number which will be pulled, e.g. 1.2. Default: the highest version
--dir=<value> Directory where the Actor should be pulled to
DESCRIPTION
Download Actor code to current directory. Clones Git repositories or fetches Actor files based on the source type.
See code: src/commands/pull.ts
Deploys Actor to Apify platform using settings from '.actor/actor.json'.
USAGE
$ apify push [ACTORID] [-v <value>] [-b <value>] [-w <value>] [--no-prompt] [--force] [--dir <value>]
ARGUMENTS
ACTORID Name or ID of the Actor to push (e.g. "apify/hello-world" or "E2jjCZBezvAZnX8Rb"). If not provided, the
command will create or modify the Actor with the name specified in '.actor/actor.json' file.
FLAGS
-b, --build-tag=<value> Build tag to be applied to the successful Actor build. By default, it is taken from the
'.actor/actor.json' file
-v, --version=<value> Actor version number to which the files should be pushed. By default, it is taken from
the '.actor/actor.json' file.
-w, --wait-for-finish=<value> Seconds for waiting to build to finish, if no value passed, it waits forever.
--dir=<value> Directory where the Actor is located
--force Push an Actor even when the local files are older than the Actor on the platform.
--no-prompt Do not prompt for opening the Actor details in a browser. This will also not open the
browser automatically.
DESCRIPTION
Deploys Actor to Apify platform using settings from '.actor/actor.json'.
Files under '3' MB upload as "Multiple source files"; larger projects upload as ZIP file.
Use --force to override newer remote versions.
See code: src/commands/push.ts
Manages URL queues for web scraping and automation tasks.
USAGE
$ apify request-queues
DESCRIPTION
Manages URL queues for web scraping and automation tasks.
See code: src/commands/request-queues/index.ts
Executes Actor locally with simulated Apify environment variables.
USAGE
$ apify run [-p] [--purge-queue] [--purge-dataset] [--purge-key-value-store] [--entrypoint <value>] [-i
<value> | --input-file <value>]
FLAGS
-i, --input=<value> Optional JSON input to be given to the Actor.
-p, --purge Shortcut that combines the --purge-queue, --purge-dataset and --purge-key-value-store
options.
--entrypoint=<value> Optional entrypoint for running with injected environment variables.
For Python, it is the module name, or a path to a file.
For node.js, it is the npm script name, or a path to a JS/MJS file. You can also pass in
a directory name, provided that directory contains an "index.js" file.
--input-file=<value> Optional path to a file with JSON input to be given to the Actor. The file must be a
valid JSON file. You can also specify `-` to read from standard input.
--purge-dataset Deletes the local directory containing the default dataset before the run starts.
--purge-key-value-store Deletes all records from the default key-value store in the local directory before the
run starts, except for the "INPUT" key.
--purge-queue Deletes the local directory containing the default request queue before the run starts.
DESCRIPTION
Executes Actor locally with simulated Apify environment variables.
Stores data in local 'storage' directory.
NOTE: For Node.js Actors, customize behavior by modifying the 'start' script in package.json file.
See code: src/commands/run.ts
Manages Actor run operations
USAGE
$ apify runs
DESCRIPTION
Manages Actor run operations
See code: src/commands/runs/index.ts
Aborts an Actor run.
USAGE
$ apify runs abort RUNID [--json] [-f]
ARGUMENTS
RUNID The run ID to abort.
FLAGS
-f, --force Whether to force the run to abort immediately, instead of gracefully.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Aborts an Actor run.
See code: src/commands/runs/abort.ts
Prints information about an Actor run.
USAGE
$ apify runs info RUNID [--json] [-v]
ARGUMENTS
RUNID The run ID to print information about.
FLAGS
-v, --verbose Prints more in-depth information about the Actor run.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Prints information about an Actor run.
See code: src/commands/runs/info.ts
Prints the log of a specific run.
USAGE
$ apify runs log RUNID
ARGUMENTS
RUNID The run ID to get the log from.
DESCRIPTION
Prints the log of a specific run.
See code: src/commands/runs/log.ts
Lists all runs of the Actor.
USAGE
$ apify runs ls [ACTORID] [--json] [--offset <value>] [--limit <value>] [--desc] [-c]
ARGUMENTS
ACTORID Optional Actor ID or Name to list runs for. By default, it will use the Actor from the current directory.
FLAGS
-c, --compact Display a compact table.
--desc Sort runs in descending order.
--limit=<value> [default: 10] Number of runs that will be listed.
--offset=<value> Number of runs that will be skipped.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Lists all runs of the Actor.
See code: src/commands/runs/ls.ts
Resurrects an aborted or finished Actor Run.
USAGE
$ apify runs resurrect RUNID [--json]
ARGUMENTS
RUNID The run ID to resurrect.
GLOBAL FLAGS
--json Format output as json.
DESCRIPTION
Resurrects an aborted or finished Actor Run.
See code: src/commands/runs/resurrect.ts
Deletes an Actor Run.
USAGE
$ apify runs rm RUNID
ARGUMENTS
RUNID The run ID to delete.
DESCRIPTION
Deletes an Actor Run.
See code: src/commands/runs/rm.ts
Manages secure environment variables for Actors.
USAGE
$ apify secrets
DESCRIPTION
Manages secure environment variables for Actors.
Example:
$ apify secrets add mySecret TopSecretValue123
The "mySecret" value can be used in an environment variable defined in '.actor/actor.json' file by adding the "@"
prefix:
{
"actorSpecification": 1,
"name": "my_actor",
"environmentVariables": { "SECRET_ENV_VAR": "@mySecret" },
"version": "0.1"
}
When the Actor is pushed to Apify cloud, the "SECRET_ENV_VAR" and its value is stored as a secret environment variable
of the Actor.
See code: src/commands/secrets/index.ts
Adds a new secret to '~/.apify' for use in Actor environment variables.
USAGE
$ apify secrets add NAME VALUE
ARGUMENTS
NAME Name of the secret
VALUE Value of the secret
DESCRIPTION
Adds a new secret to '~/.apify' for use in Actor environment variables.
See code: src/commands/secrets/add.ts
Permanently deletes a secret from your stored credentials.
USAGE
$ apify secrets rm NAME
ARGUMENTS
NAME Name of the secret
DESCRIPTION
Permanently deletes a secret from your stored credentials.
See code: src/commands/secrets/rm.ts
Manages scheduled and predefined Actor configurations.
USAGE
$ apify task
DESCRIPTION
Manages scheduled and predefined Actor configurations.
See code: src/commands/task/index.ts
Executes predefined Actor task remotely using local key-value store for input.
USAGE
$ apify task run TASKID [-b <value>] [-t <value>] [-m <value>]
ARGUMENTS
TASKID Name or ID of the Task to run (e.g. "my-task" or "E2jjCZBezvAZnX8Rb").
FLAGS
-b, --build=<value> Tag or number of the build to run (e.g. "latest" or "1.2.34").
-m, --memory=<value> Amount of memory allocated for the Task run, in megabytes.
-t, --timeout=<value> Timeout for the Task run in seconds. Zero value means there is no timeout.
DESCRIPTION
Executes predefined Actor task remotely using local key-value store for input.
Customize with --memory and --timeout flags.
See code: src/commands/task/run.ts
Validates Actor input schema from one of these locations (in priority order):
USAGE
$ apify validate-schema [PATH]
ARGUMENTS
PATH Optional path to your INPUT_SCHEMA.json file. If not provided ./INPUT_SCHEMA.json is used.
DESCRIPTION
Validates Actor input schema from one of these locations (in priority order):
1. Object in '.actor/actor.json' under "input" key
2. JSON file path in '.actor/actor.json' "input" key
3. .actor/INPUT_SCHEMA.json
4. INPUT_SCHEMA.json
Optionally specify custom schema path to validate.
See code: src/commands/validate-schema.ts