Defining resources
You can scaffold resources from the command line by running dg scaffold defs dagster.resources <path/to/resources_file.py>. For more information, see the dg CLI docs.
Typically, resources are defined by subclassing ConfigurableResource. Resources typically have a set of configuration values, which are used to specify information like account identifiers, API keys, or database names when interfacing with an external tool or service. This configuration schema is specified by attributes on the class.
The configuration system has a few advantages over plain Python parameter passing. Configured values can be:
- Replaced at run launch time in the Launchpad in Dagster UI, the GraphQL API, or the Python API
- Displayed in the Dagster UI
- Set dynamically using environment variables, resolved at runtime
With asset definitions
The following example demonstrates defining a subclass of ConfigurableResource that represents a connection to an external service. The resource can be configured by constructing a function using the @dg.Definitions.
You can define methods on the resource class which depend on config values.
import dagster as dg
import requests
from requests import Response
class MyConnectionResource(dg.ConfigurableResource):
    username: str
    def request(self, endpoint: str) -> Response:
        return requests.get(
            f"https://my-api.com/{endpoint}",
            headers={"user-agent": "dagster"},
        )
@dg.asset
def data_from_service(my_conn: MyConnectionResource) -> dict[str, Any]:
    return my_conn.request("/fetch_data").json()
Assets specify resource dependencies by annotating the resource as a parameter to the asset function.
To provide resource values to assets, attach them to the @dg.Definitions function. These resources are automatically passed to the function at runtime.
With sensors
Sensors use resources in the same way as assets, which can be useful for querying external services for data.
To specify resource dependencies on a sensor, annotate the resource type as a parameter to the sensor's function. For more information and examples, see the Sensors documentation.
With schedules
Schedules can use resources in case your schedule logic needs to interface with an external tool or to make your schedule logic more testable.
To specify resource dependencies on a schedule, annotate the resource type as a parameter to the schedule's function. For more information, see "Using resources in schedules.
With jobs
The following example defines a subclass of ConfigurableResource that represents a connection to an external service. The resource can be configured by constructing a function using the @dg.Definitions.
You can define methods on the resource class which depend on config values.
import dagster as dg
import requests
from requests import Response
class MyConnectionResource(dg.ConfigurableResource):
    username: str
    def request(self, endpoint: str) -> Response:
        return requests.get(
            f"https://my-api.com/{endpoint}",
            headers={"user-agent": "dagster"},
        )
@dg.op
def update_service(my_conn: MyConnectionResource):
    my_conn.request("/update")
@dg.job
def update_service_job():
    update_service()
@dg.definitions
def resources():
    return dg.Definitions(
        resources={
            "my_conn": MyConnectionResource(username="my_user"),
        },
    )
There are many supported config types that can be used when defining resources. Refer to the advanced config types documentation for a more comprehensive overview of the available config types.