Authenticate with Earthdata Login
The first step to use NASA Earthdata is to create an account with Earthdata Login, please follow the instructions at NASA EDL
Once registered, earthaccess can use environment variables, a .netrc file or
interactive input from a user to login with NASA EDL.
If a strategy is not specified, environment variables will be used first, then
a .netrc (if found, see below), and finally a user's input.
If you have a .netrc file (see below) with your Earthdata Login credentials,
you can explicitly specify its use:
If your Earthdata Login credentials are set as the environment variables
EARTHDATA_USERNAME and EARTHDATA_PASSWORD, you can explicitly specify their
use:
Alternatively, you can use an existing Earthdata Login token by setting the environment
variable EARTHDATA_TOKEN to it and using the same "environment" strategy, above.
If you wish to enter your Earthdata Login credentials when prompted, with
optional persistence to your .netrc file (see below), specify the interactive
strategy:
Authentication
By default, earthaccess with automatically look for your EDL account
credentials in two locations:
- A
.netrcfile: By default, this is either~/_netrc(on a Windows system) or~/.netrc(on a non-Windows system). On any system, you may override the default location by setting theNETRCenvironment variable to the path of your desired.netrcfile.
NOTE: When setting the NETRC environment variable, there is no
requirement to use a specific filename. The name .netrc is common, but
used throughout documentation primarily for convenience. The only
requirement is that the contents of the file adhere to the
.netrc file format.
2. EARTHDATA_USERNAME and EARTHDATA_PASSWORD environment variables (or, optionally, EARTHDATA_TOKEN
to use an existing Earthdata Login token)
If neither of these options are configured, you can authenticate by calling the
earthaccess.login() method and manually entering your EDL account credentials.
Note you can pass persist=True to earthaccess.login() to have the EDL
account credentials you enter automatically saved to your .netrc file (see
above) for future use.
Once you are authenticated with NASA EDL you can:
- Get a file from a DAAC using a
fsspecsession. - Request temporary S3 credentials from a particular DAAC (needed to download or stream data from an S3 bucket in the cloud).
- Use the library to download or stream data directly from S3.
- Regenerate CMR tokens (used for restricted datasets).
Earthdata User Acceptance Testing (UAT) environment
If your EDL account is authorized to access the User Acceptance Testing (UAT)
system, you can set earthaccess to work with its EDL and CMR endpoints by
setting the system argument at login, as follows: