Faspex authenticates users with an OAuth mechanism. This endpoint generates an OAuth token, using the grant type specified in the request. To use the generated OAuth token with the API, include the following token in the authorization header: "Authorization: Bearer {oauth_token}". For example:

"Authorization: Bearer HRuHfrm58QhGtZuLVqAptA"

The bearer token (OAuth token) is equivalent to the value of the "access_token" attribute returned in the initial request.

OAuth tokens are associated with Faspex users, so admin access will be granted only if the user that generated the token is an admin.


Create an OAuth token:

POST /auth/oauth2/token

Request Body: None

Request Parameters

Parameter Name Required/Optional Format Default Value Description
grant_type required string none Specifies the type of authentication to use. Available grant types:
  • password - Basic authorization
  • urn:ietf:params:oauth:grant-type:saml2-bearer - SAML assertion. See Generating an OAuth Token for a SAML User for additional instructions.
  • refresh_token - OAuth token created in the request is automatically refreshed (to extend the life of the token) so the user does not need to provide credentials again

Success Response Code

  • 201 Created - Returned with token information

Response Attributes

Attribute Name Format Description
access_token string OAuth token returned by the post request. This token expires before the refresh token.
token_type string The type of OAuth token (bearer is the type used with the Faspex v.4 API)
refresh_token string Token to submit in a POST request to receive new bearer token and new refresh token
expires_in integer Time left until token expires (in seconds)

Success Response Example

{
  "access_token":"Qs_9v5ZZzxm4-SylyUCOaA",
  "token_type":"bearer",
  "refresh_token":"RaW3uJjg2eTaHX32Sy1eKQ",
  "expires_in":86400
}

The following are examples of how to generate and use an OAuth token in requests:

  • Create OAuth token:
    curl -X POST -u {username} https://{faspex_url}/auth/oauth2/token?grant_type={grant_type}
    < br /> Note: Aspera recommends that you do not submit the user password along with the username in the request, instead allowing the system to return a prompt for the password.
  • Use OAuth token to access user data:
    curl -H "Authorization: Bearer {bearer_token}" https://{faspex_url}/api/users/
  • Refresh a token:
    curl -k -X POST "https://{faspex_url}/auth/oauth2/token?grant_type=refresh_token&refresh_token={refresh_token}"

Example Request and Response

Create OAuth token:

curl -X POST -u sam http://10.0.0.0/aspera/faspex/auth/oauth2/token?grant_type=password
{  
   "access_token":"YrPSD5XHC9J8V7-fAJG1yg",
   "token_type":"bearer",
   "refresh_token":"ceELnGrtCqEa61NlnGHu8A",
   "expires_in":86400
}

Use OAuth token to access user data (returns information for all users)

curl -k -H "Authorization: Bearer PgQux2MwJODFfmK5zhJGSA" https://10.0.0.0/aspera/faspex/api/users/
{  
   "id":"91",
   "name":"jsmith",
   "first_name":"John",
   "last_name":"Smith",
   "account_activated":true,
   "account_expires":false,
   "admin":true,
   "downloads_allowed":true,
   "uploads_allowed":true,
   "can_send_normal_packages":true,
   "can_send_to_all_faspex_users":true,
   "can_send_to_external_email":true,
   "created_at":"2016-09-02T15:25:18-05:00",
   "updated_at":"2017-07-17T17:37:03-05:00",
   "delete_packages_after_download":false,
   "user_profile_data_attributes":[  
      {  
         "created_at":"2016/09/02 15:25:18 -0500",
         "id":49,
         "updated_at":"2016/09/02 15:25:18 -0500",
         "user_id":91,
         "user_profile_field_id":6,
         "value":"",
         "user_profile_field_name":"Department"
      },
      {  
         "created_at":"2016/09/02 15:25:18 -0500",
         "id":50,
         "updated_at":"2016/09/02 15:25:18 -0500",
         "user_id":91,
         "user_profile_field_id":7,
         "value":"",
         "user_profile_field_name":"Country"
      }
   ],
   "memberships":[  
      {  
         "id":36,
         "e_workgroup_id":8,
         "e_workgroup_type":"Workgroup",
         "e_workgroup_name":"test_wg",
         "user_id":91,
         "can_read":true,
         "can_write":true,
         "is_wg_admin":false,
         "created_at":"2016/09/02 15:26:01 -0500",
         "updated_at":"2016/09/02 15:26:01 -0500"
      }
   ]
},

 . . . 
 
{  
"id":"122",
"name":"pamela+5@asperasoft.com",
"first_name":"pamela+5@asperasoft.com",
"last_name":"(external email)",
"account_activated":true,
"account_expires":false,
"admin":false,
"downloads_allowed":true,
"uploads_allowed":true,
"can_send_normal_packages":true,
"can_send_to_all_faspex_users":true,
"can_send_to_external_email":true,
"created_at":"2017-07-13T08:36:44-05:00",
"updated_at":"2017-07-13T08:36:44-05:00",
"delete_packages_after_download":false,
"user_profile_data_attributes":[  

],
"memberships":[  

]
}

Refresh a token (request and response)

curl -k -X POST "https://10.0.0.0/aspera/faspex/auth/oauth2/token?grant_type=refresh_token&refresh_token=QNWjnuWucMCt_Mc7Uho_6A"
{"access_token":"6AGXWSBz5TMdxu00irq7hg","token_type":"bearer","refresh_token":"c88hRBlBWBoGkJUdf0Iqqg","expires_in":86400}

As you can see in the example above, the request to refresh a token with the refresh_token parameter generates a new access token and a new refresh token value for future requests.

Generating an OAuth Token for a SAML User

To use the Faspex v4 API with a SAML user, you need to generate an OAuth token. First you must capture the SAML response, then you pass in the SAML response in string form.

I. Capturing a SAML Response

  1. Download SAML tracer for Firefox.
  2. Open SAML tracer (Tools > SAML tracer)
  3. Log into Faspex in the SAML login page.
  4. In the SAML Tracer dialog, click the POST request that contains the segment /auth/saml/callback in the URL (it will also be marked with a "SAML" label).
  5. Click the Parameters > SAML tab and copy the string under SAMLResponse.

II. Passing the SAML Response

  1. Copy and paste the SAML response (the "assertion") that you captured in Part (I) into a file that's in a form of a POST request (see the sample below).
  2. Run a cURL command to generate the token. Here is one example:
    curl -k -H "Content-type: application/json" -H "Accept:application/json" "https://10.0.153.31/aspera/faspex/auth/oauth2/token" --data @dyang_saml_assertion.txt

Note: The SAML assertion expires about 5 minutes after creation, so you must run this command soon after retrieving the assertion.

Sample assertion file:

{
"grant_type": "urn:ietf:params:oauth:grant-type:saml2-bearer",
"id": 1,
"assertion": "<?xml version="1.0" encoding="UTF-8"?>
<saml2p:Response Destination="https://10.0.153.31/aspera/faspex/auth/saml/callback?id=1" ID="_554ad179c80565420ba55cb6370d053c" InResponseTo="_5a80dd30-93cf-0134-d7fb-0050568274ab" IssueInstant="2016-11-23T17:22:46.569Z" Version="2.0" xmlns:saml2p="urn:oasis:names:tc:SAML:2.0:protocol"><saml2:Issuer Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion">https://shib-idp-01.dev.aspera.us/idp/shibboleth</saml2:Issuer><saml2p:Status><saml2p:StatusCode Value="urn:oasis:names:tc:SAML:2.0:status:Success"/></saml2p:Status><saml2:Assertion ID="_a8a0a92fec791eba1fbd499c7ab628e1" IssueInstant="2016-11-23T17:22:46.569Z" Version="2.0" xmlns:saml2="urn:oasis:names:tc:SAML:2.0:assertion" xmlns:xs="http://www.w3.org/2001/XMLSchema"><saml2:Issuer Format="urn:oasis:names:tc:SAML:2.0:nameid-format:entity">https://shib-idp-01.dev.aspera.us/idp/shibboleth</saml2:Issuer><ds:Signature xmlns:ds="http://www.w3.org/2000/09/xmldsig#"><ds:SignedInfo><ds:CanonicalizationMethod Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"/><ds:SignatureMethod Algorithm="http://www.w3.org/2000/09/xmldsig#rsa-sha1"/><ds:Reference URI="#_a8a0a92fec791eba1fbd499c7ab628e1"><ds:Transforms><ds:Transform Algorithm="http://www.w3.org/2000/09/xmldsig#enveloped-signature"/><ds:Transform Algorithm="http://www.w3.org/2001/10/xml-exc-c14n#"><ec:InclusiveNamespaces PrefixList="xs" xmlns:ec="http://www.w3.org/2001/10/xml-exc-c14n#"/></ds:Transform></ds:Transforms><ds:DigestMethod Algorithm="http://www.w3.org/2000/09/xmldsig#sha1"/><ds:DigestValue>7FpzLUrh/qJptL3gjKDXIwFq8gU=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>BHRAVE49pRee5sur8ftuzQJy0tQMZOJAalTv2zJMD28mrx2BpsFS3UNLPuDa4OKNLCjljmeV+X9J+ltTdvvx7hv2CuqfX/QH5m1j1cXQRyM1d1js+moCRUQjA8GHvwax1zKSpFeGHRVR0UXeqWhhibF/f9IDTszMT8i7ZKUXh04ZgZhcsM1xUPYXkrtNr75TwDYcAPP98zjh/FyDUP2OqWmjhuIZHdZqVl+wDDsXfCChmj+CeUjlIuVRFSwf4NtL/K9GVEaUfmJBFImKjYizOjsSzwo5UY8NqdKVdVd+U3m3Bya/ChMYfnB+/OoW4BwjGlMUM2V1bKOLcq5v30gxmA==</ds:SignatureValue><ds:KeyInfo><ds:X509Data><ds:X509Certificate>MIIDUDCCAjigAwIBAgIVANkYVO1LBB6MuViBihCDECq8XoAxMA0GCSqGSIb3DQEBBQUAMCQxIjAg
BgNVBAMTGXNoaWItaWRwLTAxLmRldi5hc3BlcmEudXMwHhcNMTMxMTA2MjIzODAzWhcNMzMxMTA2
MjIzODAzWjAkMSIwIAYDVQQDExlzaGliLWlkcC0wMS5kZXYuYXNwZXJhLnVzMIIBIjANBgkqhkiG
9w0BAQEFAAOCAQ8AMIIBCgKCAQEAkk7e5VrTJpcmeQTbNQXlgBTgpeWkkhx+8t4zpEh4UbQr8sXh
so9GtDQjVhasWMfGPAO+Mlp112eXVvT8uQQMBh2Ce7qSx1aXl4ZsJw+mPfuRf6xIZDk5sVNfY801
SxXbeVvPSGXN6lTPV7/0/dd4s+IMIeG6NfIdfpFbYa4F2QaJD28ergf3KELzHkrBWti55NH8Np49
rk5Iq0fk56YR1KuETHI2pS3vvVIOJMwIhOvOrsNxHu0O6oohFmLM5k+yHQqur1Lk0mV9GFZnwDWC
lwPcLKvJ6gTv8k4hUkI0fhWUVOENcleyyDc9acnMXCrnM424eW4QnKE1H8u8xO6DcwIDAQABo3kw
dzBWBgNVHREETzBNghlzaGliLWlkcC0wMS5kZXYuYXNwZXJhLnVzhjBodHRwczovL3NoaWItaWRw
LTAxLmRldi5hc3BlcmEudXMvaWRwL3NoaWJib2xldGgwHQYDVR0OBBYEFPZq25rft0WK+9WvL+Wl
+W+knKH2MA0GCSqGSIb3DQEBBQUAA4IBAQAhCICuALkaLW1glDVtp8YuYB3FZqBn0Y3ekt/OUXIU
uGwXDYhR8FdumXhGIGdUaPlQHd3MnZRIVougy7fS/Qyg8V/C8ALa5g7K/2sTOi/RtMjRQZK+vOlO
oxneqotk4BPGp3an+m1pdnxjJvphL4kX/ZPuCcvkyzoDnelv/c+dE/+Yz6IzmL1j/drsxRL8etPc
jpgGjIF4TDGTNDDhleOyLP3yN2aNPqEpF/Y8WOVhejrkux2YKwH6SQVKdSgodD6EVsUs13F1atvB
BRRwBWgG2lFBnVRl01r3LOjH0VtFK/Hms3V3L9jE7ucR+qDbWNdPEmVwBY2aHr0EQU/NscQl</ds:X509Certificate></ds:X509Data></ds:KeyInfo></ds:Signature><saml2:Subject><saml2:NameID Format="urn:oasis:names:tc:SAML:1.1:nameid-format:unspecified" NameQualifier="https://shib-idp-01.dev.aspera.us/idp/shibboleth" SPNameQualifier="https://10.0.153.31/aspera/faspex/auth/saml/metadata/1">dyang</saml2:NameID><saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml2:SubjectConfirmationData Address="10.41.41.170" InResponseTo="_5a80dd30-93cf-0134-d7fb-0050568274ab" NotOnOrAfter="2016-11-23T17:27:46.569Z" Recipient="https://10.0.153.31/aspera/faspex/auth/saml/callback?id=1"/></saml2:SubjectConfirmation></saml2:Subject><saml2:Conditions NotBefore="2016-11-23T17:22:46.569Z" NotOnOrAfter="2016-11-23T17:27:46.569Z"><saml2:AudienceRestriction><saml2:Audience>https://10.0.153.31/aspera/faspex/auth/saml/metadata/1</saml2:Audience></saml2:AudienceRestriction></saml2:Conditions><saml2:AuthnStatement AuthnInstant="2016-11-23T17:22:46.473Z" SessionIndex="_aff28e5c2f93b21dacfa8beeee17593c"><saml2:SubjectLocality Address="10.41.41.170"/><saml2:AuthnContext><saml2:AuthnContextClassRef>urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport</saml2:AuthnContextClassRef></saml2:AuthnContext></saml2:AuthnStatement><saml2:AttributeStatement><saml2:Attribute FriendlyName="office" Name="office" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Emeryville</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="sn" Name="surname" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">yang</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="company_name" Name="company_name" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">Aspera-Test-Shib</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="email" Name="email" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">dyang.aspera+win2008AD@gmail.com</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="entryDN" Name="id" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">CN=dyang,OU=dyang test,OU=Users,OU=Asperasoft,DC=dev,DC=aspera,DC=us</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="givenName" Name="given_name" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">dyang</saml2:AttributeValue></saml2:Attribute><saml2:Attribute FriendlyName="memberOf" Name="member_of" NameFormat="urn:oasis:names:tc:SAML:2.0:attrname-format:unspecified"><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">CN=dyang SAML group 3,OU=dyang test,OU=Users,OU=Asperasoft,DC=dev,DC=aspera,DC=us</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">CN=dyang_external_users_group,OU=dyang test,OU=Users,OU=Asperasoft,DC=dev,DC=aspera,DC=us</saml2:AttributeValue><saml2:AttributeValue xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:type="xs:string">CN=dyang SAML group 2,OU=dyang test,OU=Users,OU=Asperasoft,DC=dev,DC=aspera,DC=us</saml2:AttributeValue></saml2:Attribute></saml2:AttributeStatement></saml2:Assertion></saml2p:Response>" 
}

Video player

Video

×