This endpoint uses a POST request to return an OAuth bearer token; you submit this token in the other endpoints of the Shares 2 API to authorize the request.

Request Parameters

Note: The value of the grant_type parameter you submit will require one or additional parameters depending on its value; for example, a value of "ldap" dictates that you submit additional values related to the LDAP configuration. See the table below this one (and the request examples) for additional details.

Name Required/Optional Type Description
grant_type Required string Grant type; available values are ldap, saml, and refresh_token. See table below for additional detail.
redirect_uri optional boolean Redirect URI

Additional Required Values with "grant_type"

Grant Type Value Additional Required Parameters
ldap ldap_configuration_id, username,password
saml SAML assertion
refresh_token Submit refresh_token=refresh_token in the URL parameters or as part of a JSON body; for example:
-d '{"grant_type":"refresh_token","refresh_token":"refresh_token"}'
Submitting in the JSON body may be preferable for security reasons.

Success Response Codes

Method Code
GET 200 OK
POST 201 Created
PUT 200 OK
DELETE 204 No Content

Error Response Codes

A description of error is included in response body; see the examples below for additional details.

Method Error Reason
POST 422 Unprocessable Entity Group has already been taken

Response Attributes

Name Type Description
access_token string Access token
expires_in integer Seconds until access token expires
refresh_token string Refresh token
refresh_token_expires_in integer Seconds until refresh token expires

Example Request and Response


Request an access token with basic authentication

POST /oauth2/token

Request Example

curl "http://shares.example.com/oauth2/token" -d '{"grant_type":"password"}' -X POST /
        -u the_current_user@example.com:Password123_ \
        -H "Content-Type: application/json" \
        -H "Accept: application/json" \
        -H "Host: example.org" \
        -H "Cookie: "

Response Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self' 'unsafe-inline' 'unsafe-eval' https://local.connectme.us https://d3gcli72yxqn2z.cloudfront.net http://d3gcli72yxqn2z.cloudfront.net
Content-Type: application/json; charset=utf-8
ETag: W/"37be9ec335c2b1021ecb18edc8a716b8"
Cache-Control: max-age=0, private, must-revalidate
X-Request-Id: 97895416-dd1e-4fb0-b286-d682ebc73c08
X-Runtime: 0.027537
Content-Length: 177

Success Response Example

201 Created
{
"access_token": "Cu1MRyB-BuDmrSu1s6OE9QoTt6w7FrlFFAY6NotH0Bg",
"expires_in": 28799,
"refresh_token": "ZZ7sL_2gDq2P36qPCUSsFR7eKecMX-HVda5dNp6ogL4",
"refresh_token_expires_in": 604799
}

Error Response Example

401 Unauthorized
{
   "error": "Invalid email or password."
}

Error Response Example (Too many attempts from IP)

401 Unauthorized

Example Response Body

{
   "error": "You have made too many recent login attempts. Please wait 20 minutes and try again."
}

Error Response Example (Too many requests for email)

401 Unauthorized
{
   "error": "You have made too many recent login attempts. Please wait 20 minutes and try again."
}

Error Response Example (Requested an access token with a deactivated account)

401 Unauthorized
{
   "error": "Your account has been deactivated."
}

Error Response Example (Request an access token with an expired password)

401 Unauthorized
{
   "error": "Your password has expired."
}

Error Response Example (Requested an access token with an expired account)

401 Unauthorized
{
  "error": "Your account has expired."
}


Request an access token with a refresh token

POST /oauth2/token

Request Example

curl "http://shares.example.com/oauth2/token" -d '{"grant_type":"refresh_token","refresh_token":"DW_sUQ40_HjPJLxN7ft0odGI2UuogIq8JVV9j56VRiIlvKIc3pvshVTIsAocln6GyRmv75pFp9J4Hsr5lFupwg=="}' -X POST \
	-H "Content-Type: application/json" \
	-H "Accept: application/json" \
	-H "Host: example.org" \
	-H "Cookie: "

Response Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self' 'unsafe-inline' 'unsafe-eval' https://local.connectme.us https://d3gcli72yxqn2z.cloudfront.net http://d3gcli72yxqn2z.cloudfront.net
Content-Type: application/json; charset=utf-8
ETag: W/"595fe5c47a91471c91d1fdd9aeab4fc5"
Cache-Control: max-age=0, private, must-revalidate
X-Request-Id: edd87314-0468-436c-b0f4-a9eb8e5713e3
X-Runtime: 0.010292
Content-Length: 222

Success Response Example

201 Created
{
  "access_token": "Bdi_d4hwzE4YrEMaQW8HrHcIHCHH-DE4n8mlnRarIGs",
  "expires_in": 28799,
  "refresh_token": "DW_sUQ40_HjPJLxN7ft0odGI2UuogIq8JVV9j56VRiIlvKIc3pvshVTIsAocln6GyRmv75pFp9J4Hsr5lFupwg==",
  "refresh_token_expires_in": 604799
}

Error Response Example (Request an access token with an expired refresh token)

401 Unauthorized

Example Response Body

{
   "error": "Your refresh token has expired."
}

Error Response Example (Request an access token with an invalid refresh token)

401 Unauthorized

Example Response Body

{
   "error": "Invalid refresh token."
}


Request an access token with LDAP credentials

POST /oauth2/token

Request Example

curl "http://shares.example.com/oauth2/token" -d '{"grant_type":"ldap","ldap_configuration_id":381178965,"username":"cc414","password":"retneprac"}' -X POST

Response Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self' 'unsafe-inline' 'unsafe-eval' https://local.connectme.us https://d3gcli72yxqn2z.cloudfront.net http://d3gcli72yxqn2z.cloudfront.net
Content-Type: application/json; charset=utf-8
ETag: W/"cfff189c256c245a2b8719f50e8e80b5"
Cache-Control: max-age=0, private, must-revalidate
X-Request-Id: a2ee6d09-81f4-499d-85ab-b9168e63d7ae
X-Runtime: 0.112775
Content-Length: 177

Success Response Example

201 Created
{
  "access_token": "BrbzG5JZqPMukYL4ed1RUXEpkNOpqW1suORffoFYrWc",
  "expires_in": 28799,
  "refresh_token": "rHuGf9sB0I0v4Gfuee-EWFkdO4cm6NkyYfRZBkiEemE",
  "refresh_token_expires_in": 604799
}

Error Response Example

401 Unauthorized
{
   "error": "Invalid username or password."
}

Error Response Example (Login restricted by group)

401 Unauthorized

Example Response Body

{
   "error": "You do not have permission to log in."
}

Error Response Example (Login restricted by user)

401 Unauthorized

Example Response Body

{
   "error": "You do not have permission to log in."
}


Request an access token with invalid SAML credentials

POST /oauth2/token

Request Example

curl "http://shares.example.com/oauth2/token" -d '{"RelayState":"grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Asaml2-bearer\u0026saml_configuration_id=478127566","SAMLResponse":"<?xml version="1.0" encoding="UTF-8"?>
<saml2p:Response Destination="http://127.0.0.1:3000/oauth2/token?saml_configuration_id=1&amp;grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Asaml2-bearer&amp;redirect_uri=http%3A%2F%2F127.0.0.1%3A3000%2Fsaml%2F1%2Flogin" ID="_18553ee4cfb854e0f73f5fa81b6306ee" InResponseTo="_6dd7e1fd-8fd3-476e-a342-1705d7fd073a" IssueInstant="2016-11-21T18:27:35.998Z" 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="_0b3ae3d777d652f23254d7aef10d9de1" IssueInstant="2016-11-21T18:27:35.998Z" 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="#_0b3ae3d777d652f23254d7aef10d9de1"><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>nxAIVB5aS5AvMu5wJYCxfwQQkek=</ds:DigestValue></ds:Reference></ds:SignedInfo><ds:SignatureValue>ABkORNxyCQjpLtLqrczU1zB6YXvxIUHpWgGiM7JqoZ1jRT+QRioFr3l0y9ndlG6Sjs2LDUdI+BHrigkxB1Mj34Dcz40K/y7cRocySs3sw0X+1bb8JVXyfU+mT9ERxLuPuFV10GR9nzhEFO3ck92lKhUXlFE8qvNJyGW7MnC9xsZgbXX1SbZRPYqubZLcOt4fcZR6MA5WiCOYISW4OK1mQ47JIyyvTOU+rrjO8WURoUBPy1u2Yva9/zTrWJx71xLVrw8GAZgIvo5nOTCXXn+oXYITY/cr1+UzKwkWswnxNqhYw22V5w1Ae373wt7TC3VGyAaYYhJr6ZEYjZJv9zWuaw==</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="http://127.0.0.1:3000/saml/1/metadata">sudhirtester11</saml2:NameID><saml2:SubjectConfirmation Method="urn:oasis:names:tc:SAML:2.0:cm:bearer"><saml2:SubjectConfirmationData Address="10.0.205.127" InResponseTo="_6dd7e1fd-8fd3-476e-a342-1705d7fd073a" NotOnOrAfter="2016-11-21T18:32:35.998Z" Recipient="http://127.0.0.1:3000/oauth2/token?saml_configuration_id=1&amp;grant_type=urn%3Aietf%3Aparams%3Aoauth%3Agrant-type%3Asaml2-bearer&amp;redirect_uri=http%3A%2F%2F127.0.0.1%3A3000%2Fsaml%2F1%2Flogin"/></saml2:SubjectConfirmation></saml2:Subject><saml2:Conditions NotBefore="2016-11-21T18:27:35.998Z" NotOnOrAfter="2016-11-21T18:32:35.998Z"><saml2:AudienceRestriction><saml2:Audience>http://127.0.0.1:3000/saml/1/metadata</saml2:Audience></saml2:AudienceRestriction></saml2:Conditions><saml2:AuthnStatement AuthnInstant="2016-11-21T18:27:35.968Z" SessionIndex="_8a78381baf4efa9b24ef4f2db9bcf7cf"><saml2:SubjectLocality Address="10.0.205.127"/><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="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">sudhir@asperasoft.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=sudhirtester11,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">sudhirtester11</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=Test GroupE,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=Test GroupD,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=Test GroupF,OU=Users,OU=Asperasoft,DC=dev,DC=aspera,DC=us</saml2:AttributeValue></saml2:Attribute></saml2:AttributeStatement></saml2:Assertion></saml2p:Response>"}' -X POST \
	-H "Content-Type: application/json" \
	-H "Accept: application/json" \
	-H "Host: example.org" \
	-H "Cookie: "

Response Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
Content-Security-Policy: script-src 'self' 'unsafe-inline' 'unsafe-eval' https://local.connectme.us https://d3gcli72yxqn2z.cloudfront.net http://d3gcli72yxqn2z.cloudfront.net
Content-Type: application/json; charset=utf-8
Cache-Control: no-cache
X-Request-Id: 2844a20d-317a-423a-9409-c43314977eb8
X-Runtime: 0.025599
Content-Length: 35

Error Response Example

422 Unprocessable Entity
{
  "error": "Invalid SAML assertion."
}

Video player

Video

×