This library implements an Authentication handler for HTTP requests using the Akamai EdgeGrid Authentication scheme for cURL.
egcurl
is a simple Python-based command wrapper around the traditional cURL command to sign requests for Akamai OPEN APIs. The script intercepts a subset of cURL command arguments to produce a request signature. Then it uses cURL to make the API call with all the original arguments and the computed request signature.
Note: There is now a simpler command line tool available, httpie. You don't need to be familiar with cURL to use httpie. It's available on the httpie-edgegrid GitHub repository.
The examples and guides on the developer portal are moving to this new tool, thus consider using it for your API calls.
-
Install Python 3.6 or later on your system. You can download it from https://www.python.org/downloads/. If you're running GNU/Linux or macOS, you probably already have it.
NOTE: Python 2 is no longer supported by the Python Software Foundation. You won't be able to use the library with Python 2.
-
Install cURL. The script expects to find it in your path.
-
Install the
edgegrid-python
authentication handler to sign your requests by running this command:pip install edgegrid-python
-
Clone this repository and then execute
egcurl
directly from the cloned repository.
We provide authentication credentials through an API client. Requests to the API are signed with a timestamp and are executed immediately.
-
Place your credentials in an EdgeGrid resource file
~/.edgerc
, in the[default]
section.[default] client_secret = C113nt53KR3TN6N90yVuAgICxIRwsObLi0E67/N8eRN= host = akab-h05tnam3wl42son7nktnlnnx-kbob3i3v.luna.akamaiapis.net access_token = akab-acc35t0k3nodujqunph3w7hzp7-gtm6ij client_token = akab-c113ntt0k3n4qtari252bfxxbsl-yvsdj
-
Use
egcurl
to sign your requests along with and--eg-edgerc
argument to point to the path of your.edgerc
configuration file and an--eg-section
argument to specify the credentials' section header.python3 egcurl --eg-edgerc ~/.edgerc --eg-section default --request GET
egcurl
supports an older non-standard configuration file, specified by --eg-config
. If you use this argument or if the ~/.egcurl
file exists, this configuration file will be consulted first to retrieve your client configuration. If the file doesn't exist or the section isn't found, egcurl
will look for the client configuration in your ~/.edgerc
file automatically.
The older ~/.egcurl
configuration is deprecated. Support for this file and format will be removed on or shortly after 2017-05-01. You can easily convert an older ~/.egcurl
configuration to an ~/.edgerc
with the convert_egcurl.pl
script. For example:
$ ./convert_egcurl.pl < ~/.egcurl > ~/.edgerc
$ mv ~/.egcurl ~/.egcurl-backup
To use the library, provide the credential's section header of your .edgerc
file and the appropriate endpoint information.
python3 egcurl --eg-edgerc ~/.edgerc --eg-section default --request GET \
--url "https://luna.akamaiapis.net/identity-management/v3/user-profile" \
--header 'accept: application/json'
When entering query parameters, you can first save them as variables and then pass them in the url after a question mark ("?") at the end of the main URL path.
auth_grants=true
notifications=true
actions=true
python3 egcurl --eg-edgerc ~/.edgerc --eg-section default --request GET \
--url "https://luna.akamaiapis.net/identity-management/v3/user-profile?authGrants=$auth_grants¬ifications=$notifications&actions=$actions" \
--header 'accept: application/json'
Enter request headers in the --header
argument.
Note: You don't need to include the
Content-Type
andContent-Length
headers. The authentication layer adds these values.
python3 egcurl --eg-edgerc ~/.edgerc --eg-section default --request GET \
--url "https://luna.akamaiapis.net/identity-management/v3/user-profile" \
--header 'accept: application/json'
Provide the request body as an object in the --data
argument.
python3 egcurl --eg-edgerc ~/.edgerc --eg-section default --request PUT \
--url "https://luna.akamaiapis.net/identity-management/v3/user-profile/basic-info" \
--header 'accept: application/json' \
--header 'content-type: application/json' \
--data '
{
"contactType": "Billing",
"country": "USA",
"firstName": "John",
"lastName": "Smith",
"preferredLanguage": "English",
"sessionTimeOut": 30,
"timeZone": "GMT",
"phone": "3456788765"
}'
Use the --eg-verbose
argument to enable debugging and get additional information on the HTTP request and response.
python3 egcurl --eg-verbose --eg-edgerc ~/.edgerc --eg-section default --request GET \
--url "https://luna.akamaiapis.net/identity-management/v3/user-profile" \
--header 'accept: application/json'
egcurl
is a wrapper around the traditional cURL command, thus it supports nearly all arguments for cURL.
egcurl
has these optional non-standard arguments available:
Argument | Description |
---|---|
--eg-edgerc <FILE> |
Location of your .edgerc configuration file. |
--eg-section <SECTION> |
The credential's section header of your .edgerc configuration file. |
--eg-json |
Automatically applies JSON pretty-format to the response. |
--eg-verbose |
Increases logging verbosity. Can be repeated to further increase verbosity. |
Note:
egcurl
doesn't support these arguments:
-F
,--form
,--form-string
--data-urlencode
-G
,--get
There're several things you need to take into account when specifying the request data for POST requests.
-
The POST requests support only
-d
,--data
and--data-ascii
for ascii data and--data-binary
for binary data. -
You can use only one data option on the same command line.
-
If the data starts with the
@
character, the rest is treated as the name of the file to read the data from. You can specify only one file on the same command line.
Use ./egcurl --help
to get detailed information on egcurl
and the available arguments.
$ ./egcurl --help
usage: egcurl [-h] [-H HEADER] [--eg-edgerc EG_EDGERC | --eg-config EG_CONFIG]
[--eg-json] [--eg-section EG_SECTION] [--eg-verbose]
[-d DATA | --data-binary DATA_BINARY] [-X {DELETE,GET,PATCH,POST,PUT}]
url
Akamai {OPEN} API utility for signed API requests with cURL.
positional arguments:
url Request URL
optional arguments:
-h, --help show this help message and exit
-H HEADER, --header HEADER
HTTP headers to pass on to cURL (repeatable)
--eg-edgerc EG_EDGERC
Location of EdgeRc configuration ini file.
--eg-config EG_CONFIG
Location of older configuration file (DEPRECATED).
--eg-json Automatically apply JSON pretty-format to the response.
--eg-section EG_SECTION
Section of the config file for the desired OPEN API credentials.
--eg-verbose Enable verbose logging output (repeat for even more)
-d DATA, --data DATA, --data-ascii DATA
ASCII data content for POST body
--data-binary DATA_BINARY
binary data content for POST body
-X {DELETE,GET,PATCH,POST,PUT}, --method {DELETE,GET,PATCH,POST,PUT}, --request {DELETE,GET,PATCH,POST,PUT}
HTTP method for the request
Several arguments above as well as any unlisted arguments are passed on to cURL,
starting with unlisted arguments followed by URL. The <url> argument should always be
the first item starting with "https://". The URL hostname will automatically be replaced
with the one specified by the selected configuration section.
This tool indirectly uses pyOpenSSL for Python < 3 via EdgeGrid for Python, which is used to produce request signatures. macOS includes a very old version of it (0.13.1) by default, which is incompatible with EdgeGrid for Python.
If you're using macOS and are incorrectly receiving an instruction to run pip install edgegrid-python
, the issue is likely that your pyOpenSSL dependency is too old and needs to be upgraded.
Run this command to fix the problem:
pip install -U pyOpenSSL
Note: DO NOT RUN THIS COMMAND AS ROOT. It's not possible to upgrade the system installation of pyOpenSSL on macOS. Attempting to upgrade it will fail with inexplicable errors.
To report an issue or make a suggestion, create a new GitHub issue.
Copyright 2025 Akamai Technologies, Inc. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use these files except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.