使用DocuSign AuthenticationApi.login()进行传统身份验证时出错-缺少grant_type / code

时间:2018-10-03 19:58:29

标签: java docusignapi oltu

我正在尝试在DocuSign Java SDK中使用Authentication :: login()API调用,并且收到错误消息。这是一些代码:

@Component
public class TestClass {

    private ApiClient apiClient;

    public void authenticate() {

        this.apiClient = new ApiClient("account-d.docusign.com", "docusignAccessCode",
                "mySecretIntegratorKey", "myClientSecret");

        final AuthenticationApi authenticationApi = new AuthenticationApi(this.apiClient);

        try {
            // ERROR ON THE LINE BELOW
            final LoginInformation loginInformation = authenticationApi.login();
        } catch (final ApiException e) {
            // do something appropriate
        }
    }
}

mySecretIntegratorKeymyClientSecret值显然不是我要发送的实际值,而其他值是。

这是我在调用login()时收到的错误:

Caused by: org.apache.oltu.oauth2.common.exception.OAuthSystemException: Missing grant_type/code
at com.docusign.esign.client.auth.OAuth$OAuthJerseyClient.execute(OAuth.java:184)
at org.apache.oltu.oauth2.client.OAuthClient.accessToken(OAuthClient.java:65)
at org.apache.oltu.oauth2.client.OAuthClient.accessToken(OAuthClient.java:55)
at org.apache.oltu.oauth2.client.OAuthClient.accessToken(OAuthClient.java:71)
at com.docusign.esign.client.auth.OAuth.updateAccessToken(OAuth.java:92)
... 123 common frames omitted

我意识到这是使用较旧的旧式身份验证,但是我有一个局限性,直到今年第一天才允许我升级到较新的身份验证方法。因此,现在我需要通过SDK版本2.2.1使用此旧方法。

有什么想法我在这里做错了吗?我敢肯定这很简单...

谢谢您的时间。

2 个答案:

答案 0 :(得分:1)

您要使用旧版身份验证吗?

在这种情况下,您需要对代码进行大量更新。

  • 仅致电new ApiClient(base_url)
  • 设置X-DocuSign-Authentication标头-

来自old Readme:

String authHeader = "{\"Username\":\"" +  username +
   "\",\"Password\":\"" +  password + 
   "\",\"IntegratorKey\":\"" +  integratorKey + "\"}";
apiClient.addDefaultHeader("X-DocuSign-Authentication", authHeader);
  • 然后使用authenticationApi.login查找用户的帐户ID和匹配的基本URL。

authenticationApi.login实际不是登录您。(!)

相反,该方法只是为您提供有关当前用户的信息。

由于不使用会话,因此无法使用该API登录。而是通过每个 API调用传递凭据。凭据可以是访问令牌(首选),也可以是旧式身份验证,即名称/密码/集成密钥三元组。

使用传统身份验证时,不使用客户端密码。

更多信息:请参阅本old version of the repo.

中有关使用用户名/密码的自述文件部分。

答案 1 :(得分:0)

以防万一有人在寻找有效的完整旧版代码!下面的C#代码段有效。这是生产就绪代码。我已经对其进行了测试,并且可以正常工作。您将必须单独创建一个EnvelopeDefinition,因为不包含此代码。但是,下面的内容将对用户进行身份验证,并将成功发送一个信封并获取信封ID:

string username = "john.bunce@mail.com"; 
string password = "your_password"; 
string integratorKey = "your_integration_key"; 

ApiClient apiClient = new ApiClient("https://www.docusign.net/restapi");

string authHeader = "{\"Username\":\"" + username + "\", \"Password\":\"" + password + "\", \"IntegratorKey\":\"" + integratorKey + "\"}";

apiClient.Configuration.AddDefaultHeader("X-DocuSign-Authentication", authHeader);
AuthenticationApi authApi = new AuthenticationApi(apiClient.Configuration);

LoginInformation loginInfo = authApi.Login();

string accountId = loginInfo.LoginAccounts[0].AccountId;
string baseURL = loginInfo.LoginAccounts[0].BaseUrl;
string[] baseUrlArray= Regex.Split(baseURL, "/v2");   

ApiClient apiClient2 = new ApiClient(baseUrlArray[0]); 
string authHeader2 = "{\"Username\":\"" + username + "\", \"Password\":\"" + password + "\", \"IntegratorKey\":\"" + integratorKey + "\"}";

apiClient2.Configuration.AddDefaultHeader("X-DocuSign-Authentication", authHeader2);        

EnvelopesApi envelopesApi = new EnvelopesApi(apiClient2.Configuration);

EnvelopeSummary results = envelopesApi.CreateEnvelope(accountId, envelopeDefinition);
string envelopeID = results.EnvelopeId;