You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I attempted to implement the MicroformIntegrationApi, but I am experiencing issues with receiving errors in the response.
This is an example implementation where we populated the correct requirements based on the documentation by supplying the appropriate variables for the merchant_id, merchant_keyid, merchant_secret, and run_environment.
The Pydantic class for managing the operation as the key generation is utilized by the rest-api for our appliation (Django | Django-Ninja and Fast-API).
I replicated the same request using HTTP tools and the Cybersource REST-API dashboard. As a result, we were able to successfully generate a JWT response from https://apitest.cybersource.com/microform/v2/sessions.
What I noticed is the when I replicated the header generated by the generate_capture_context method it returns an authentication error.
I added the date to the headers value in the signature which is what the MicformIntegrationApi has generated -> signature: keyid="42d79b07-b077-42d1-b603-bd94104ecc20", algorithm="HmacSHA256", headers="host date request-target digest v-c-merchant-id", signature="**********************"
defget_signature_param(self, merchant_secret_key, merchant_id, httpmethod):
signature_list= ([])
# This method adds the host headersignature_list.append(GlobalLabelParameters.HOST.lower())
signature_list.append(": ")
signature_list.append(self.merchant_config_sigparam.request_host)
signature_list.append("\n")
# This method adds the date headersignature_list.append(GlobalLabelParameters.DATE.lower())
signature_list.append(": ")
signature_list.append(self.date)
signature_list.append("\n")
# This method adds the request-target headersignature_list.append(GlobalLabelParameters.REQUEST_TARGET)
signature_list.append(": ")
# This forms the get_request_targetifhttpmethod.upper() ==GlobalLabelParameters.GET:
get_request_target=GlobalLabelParameters.GET_LOWER_CASE+self.merchant_config_sigparam.request_targetsignature_list.append(get_request_target)
# This forms the post_request_targetelifhttpmethod.upper() ==GlobalLabelParameters.POST:
post_request_target=GlobalLabelParameters.POST_LOWER_CASE+self.merchant_config_sigparam.request_targetsignature_list.append(post_request_target)
elifhttpmethod.upper() ==GlobalLabelParameters.PUT:
put_request_target=GlobalLabelParameters.PUT_LOWER_CASE+self.merchant_config_sigparam.request_targetsignature_list.append(put_request_target)
elifhttpmethod.upper() ==GlobalLabelParameters.PATCH:
patch_request_target=GlobalLabelParameters.PATCH_LOWER_CASE+self.merchant_config_sigparam.request_targetsignature_list.append(patch_request_target)
elifhttpmethod.upper() ==GlobalLabelParameters.DELETE:
delete_request_target=GlobalLabelParameters.DELETE_LOWER_CASE+self.merchant_config_sigparam.request_targetsignature_list.append(delete_request_target)
The text was updated successfully, but these errors were encountered:
I attempted to implement the MicroformIntegrationApi, but I am experiencing issues with receiving errors in the response.
This is an example implementation where we populated the correct requirements based on the documentation by supplying the appropriate variables for the merchant_id, merchant_keyid, merchant_secret, and run_environment.
The Pydantic class for managing the operation as the key generation is utilized by the rest-api for our appliation (Django | Django-Ninja and Fast-API).
Response
I replicated the same request using HTTP tools and the Cybersource REST-API dashboard. As a result, we were able to successfully generate a JWT response from https://apitest.cybersource.com/microform/v2/sessions.
Response
What I noticed is the when I replicated the header generated by the
generate_capture_context
method it returns an authentication error.I added the date to the headers value in the signature which is what the MicformIntegrationApi has generated ->
signature: keyid="42d79b07-b077-42d1-b603-bd94104ecc20", algorithm="HmacSHA256", headers="host date request-target digest v-c-merchant-id", signature="**********************"
This is where it was implemented. The format of the headers varies greatly from the format expected by the end-point https://https://apitest.cybersource.com/microform/v2/sessions
api_client.ApiClient
method that handles the generation of thesignature
header.Snippets from the
GetSignatureParameter
ObjectThe text was updated successfully, but these errors were encountered: