Fraud Prevention Hooks

Namespace: DirectScale.Disco.Extension.Hooks.FraudPrevention

GetOrderPaymentToReview

Hook for the function that gets the OrderPayment that needs to be reviewed by Fraud Prevention integration.

Basic Implementation

public class GetOrderPaymentToReview : IHook<GetOrderPaymentToReviewHookRequest, GetOrderPaymentToReviewHookResponse>
{
  public GetOrderPaymentToReview() { }

  public GetOrderPaymentToReviewHookResponse Invoke(GetOrderPaymentToReviewHookRequest request, Func<GetOrderPaymentToReviewHookRequest, GetOrderPaymentToReviewHookResponse> func)
  {
    return func(request);
  }
}

Register Hook

services.AddTransient<IHook<GetOrderPaymentToReviewHookRequest, GetOrderPaymentToReviewHookResponse>, GetOrderPaymentToReview>();

Request Model

{
  "Order": {
    "BackofficeId": "string",
    "LastModifiedDate": "0001-01-01T00:00:00",
    "BillPhone": "string",
    "CommissionDate": "0001-01-01T00:00:00",
    "AssociateId": 0,
    "Email": "string",
    "InvoiceDate": "0001-01-01T00:00:00",
    "LocalInvoiceNumber": 0,
    "Name": "string",
    "OrderDate": "0001-01-01T00:00:00",
    "OrderType": 0,
    "OrderNumber": 0,
    "SpecialInstructions": "string",
    "Status": "string",
    "TotalBonus": 0.0,
    "TotalCost": 0.0,
    "TotalCV": 0.0,
    "TotalQV": 0.0,
    "Void": false,
    "BillAddress": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "PartyId": 0,
    "IsPaid": false,
    "IsShipped": false,
    "Custom": {
      "Field1": "string",
      "Field2": "string",
      "Field3": "string",
      "Field4": "string",
      "Field5": "string"
    },
    "CanRerun": false,
    "LineItems": [],
    "Packages": [],
    "Totals": [],
    "Payments": [],
    "OrderCoupons": [],
    "USDSubTotal": 0.0,
    "USDTotal": 0.0,
    "IsMoveable": {
      "IsOrderMovable": false,
      "MessageType": 0,
      "Message": "string"
    }
  },
  "Payments": null
}

Response Model

{
  "PaymentInfo": {
    "Input1": "string",
    "Input2": "string",
    "Last4": "string",
    "CardType": "string",
    "InputMonth": 1,
    "InputYear": 1900,
    "SecurityCode": "string",
    "Address": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "MerchantId": 0,
    "Amount": 0.0,
    "CurrencyCode": "string",
    "OrderPaymentId": 0,
    "RedirectUrl": "string",
    "PaymentMethodId": "string",
    "ProfileType": 0,
    "FraudPreventionData": {
      "FraudPreventionId": "string",
      "FraudPreventionProviderId": "string",
      "FraudPreventionType": 0,
      "IpAddress": "string"
    },
    "ExpireDate": "0001-01-01T00:00:00"
  }
}

GetPreCheck

Hook for the function that checks a payment before it’s processed to see if it looks fraudulent.

Basic Implementation

public class GetPreCheck : IHook<GetPreCheckHookRequest, GetPreCheckHookResponse>
{
  public GetPreCheck() { }

  public GetPreCheckHookResponse Invoke(GetPreCheckHookRequest request, Func<GetPreCheckHookRequest, GetPreCheckHookResponse> func)
  {
    return func(request);
  }
}

Register Hook

services.AddTransient<IHook<GetPreCheckHookRequest, GetPreCheckHookResponse>, GetPreCheck>();

Request Model

{
  "Order": {
    "BackofficeId": "string",
    "LastModifiedDate": "0001-01-01T00:00:00",
    "BillPhone": "string",
    "CommissionDate": "0001-01-01T00:00:00",
    "AssociateId": 0,
    "Email": "string",
    "InvoiceDate": "0001-01-01T00:00:00",
    "LocalInvoiceNumber": 0,
    "Name": "string",
    "OrderDate": "0001-01-01T00:00:00",
    "OrderType": 0,
    "OrderNumber": 0,
    "SpecialInstructions": "string",
    "Status": "string",
    "TotalBonus": 0.0,
    "TotalCost": 0.0,
    "TotalCV": 0.0,
    "TotalQV": 0.0,
    "Void": false,
    "BillAddress": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "PartyId": 0,
    "IsPaid": false,
    "IsShipped": false,
    "Custom": {
      "Field1": "string",
      "Field2": "string",
      "Field3": "string",
      "Field4": "string",
      "Field5": "string"
    },
    "CanRerun": false,
    "LineItems": [],
    "Packages": [],
    "Totals": [],
    "Payments": [],
    "OrderCoupons": [],
    "USDSubTotal": 0.0,
    "USDTotal": 0.0,
    "IsMoveable": {
      "IsOrderMovable": false,
      "MessageType": 0,
      "Message": "string"
    }
  },
  "ShipMethodId": 0,
  "LanguageCode": "string",
  "payments": [
    {
      "Input1": "string",
      "Input2": "string",
      "Last4": "string",
      "CardType": "string",
      "InputMonth": 1,
      "InputYear": 1900,
      "SecurityCode": "string",
      "Address": {
        "Id": 0,
        "AddressLine1": "string",
        "AddressLine2": "string",
        "AddressLine3": "string",
        "City": "string",
        "State": "string",
        "PostalCode": "string",
        "CountryCode": "string"
      },
      "MerchantId": 0,
      "Amount": 0.0,
      "CurrencyCode": "string",
      "OrderPaymentId": 0,
      "RedirectUrl": "string",
      "PaymentMethodId": "string",
      "ProfileType": 0,
      "FraudPreventionData": {
        "FraudPreventionId": "string",
        "FraudPreventionProviderId": "string",
        "FraudPreventionType": 0,
        "IpAddress": "string"
      },
      "ExpireDate": "0001-01-01T00:00:00"
    }
  ]
}

Response Model

{
  "Status": 0,
  "Payment": {
    "PaymentType": "string",
    "AuthorizationCode": "string",
    "Response": "string",
    "ResponseId": "string",
    "TransactionNumber": "string",
    "ReferenceNumber": "string",
    "Status": 0,
    "Amount": 0.0,
    "Currency": "string",
    "Merchant": 0,
    "FraudPreventionId": "string",
    "FraudPreventionProviderId": null,
    "OrderNumber": 0,
    "Redirect": false,
    "RedirectURL": "string",
    "SpecialInstructionsURL": "string",
    "SavedPaymentId": null
  }
}

ParseCallbackData

When an order is flagged to be checked for fraud, it needs to pass to another service. When that service is finished it’ll call the CallbackData() function. This is a hook for parsing that callback data.

Basic Implementation

public class ParseCallbackData : IHook<ParseCallbackDataHookRequest, ParseCallbackDataHookResponse>
{
  public ParseCallbackData() { }

  public ParseCallbackDataHookResponse Invoke(ParseCallbackDataHookRequest request, Func<ParseCallbackDataHookRequest, ParseCallbackDataHookResponse> func)
  {
    return func(request);
  }
}

Register Hook

services.AddTransient<IHook<ParseCallbackDataHookRequest, ParseCallbackDataHookResponse>, ParseCallbackData>();

Request Model

{
  "CallbackData": {}
}

Response Model

{
  "Data": null
}

GetFraudPreventionInfo

Hook for the function that gets the fraud prevention provider information. Such as providerId.

Basic Implementation

public class GetFraudPreventionInfo : IHook<GetFraudPreventionInfoHookRequest, GetFraudPreventionInfoHookResponse>
{
  public GetFraudPreventionInfo() { }

  public GetFraudPreventionInfoHookResponse Invoke(GetFraudPreventionInfoHookRequest request, Func<GetFraudPreventionInfoHookRequest, GetFraudPreventionInfoHookResponse> func)
  {
    return func(request);
  }
}

Register Hook

services.AddTransient<IHook<GetFraudPreventionInfoHookRequest, GetFraudPreventionInfoHookResponse>, GetFraudPreventionInfo>();

Request Model

{}

Response Model

{
  "Info": {
    "ProviderId": 0,
    "ClientSideCode": "string",
    "FraudPreventionId": "string"
  }
}

GetUserDefinedFields

Namespace: DirectScale.Disco.Extension.Hooks.FraudPrevention

This Hook is specific to Kount Fraud Prevention provider.

Basic Implementation

public class GetUserDefinedFields : IHook<GetUserDefinedFieldsHookRequest, GetUserDefinedFieldsHookResponse>
    {
        public GetUserDefinedFields() { }

        public GetUserDefinedFieldsHookResponse Invoke(GetUserDefinedFieldsHookRequest request, Func<GetUserDefinedFieldsHookRequest, GetUserDefinedFieldsHookResponse> func)
        {
            return func(request);
        }
    }

Register Hook

services.AddTransient<IHook<GetUserDefinedFieldsHookRequest, GetUserDefinedFieldsHookResponse>, GetUserDefinedFields>();

Request Model

{
  "KountMerchantId": 0,
  "Order": {
    "BackofficeId": "string",
    "LastModifiedDate": "0001-01-01T00:00:00",
    "BillPhone": "string",
    "CommissionDate": "0001-01-01T00:00:00",
    "AssociateId": 0,
    "Email": "string",
    "InvoiceDate": "0001-01-01T00:00:00",
    "LocalInvoiceNumber": 0,
    "Name": "string",
    "OrderDate": "0001-01-01T00:00:00",
    "OrderType": 0,
    "OrderNumber": 0,
    "SpecialInstructions": "string",
    "Status": "string",
    "TotalBonus": 0.0,
    "TotalCost": 0.0,
    "TotalCV": 0.0,
    "TotalQV": 0.0,
    "Void": false,
    "BillAddress": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "PartyId": 0,
    "IsPaid": false,
    "IsShipped": false,
    "Custom": {
      "Field1": "string",
      "Field2": "string",
      "Field3": "string",
      "Field4": "string",
      "Field5": "string"
    },
    "CanRerun": false,
    "LineItems": [],
    "Packages": [],
    "Totals": [],
    "Payments": [],
    "OrderCoupons": [],
    "USDSubTotal": 0.0,
    "USDTotal": 0.0,
    "IsMoveable": {
      "IsOrderMovable": false,
      "MessageType": 0,
      "Message": "string"
    }
  },
  "Payment": {
    "Input1": "string",
    "Input2": "string",
    "Last4": "string",
    "CardType": "string",
    "InputMonth": 1,
    "InputYear": 1900,
    "SecurityCode": "string",
    "Address": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "MerchantId": 0,
    "Amount": 0.0,
    "CurrencyCode": "string",
    "OrderPaymentId": 0,
    "RedirectUrl": "string",
    "PaymentMethodId": "string",
    "ProfileType": 0,
    "FraudPreventionData": {
      "FraudPreventionId": "string",
      "FraudPreventionProviderId": "string",
      "FraudPreventionType": 0,
      "IpAddress": "string"
    },
    "ExpireDate": "0001-01-01T00:00:00"
  },
  "IpAddress": "string",
  "Associate": {
    "AssociateId": 0,
    "ShipAddress": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "Address": {
      "Id": 0,
      "AddressLine1": "string",
      "AddressLine2": "string",
      "AddressLine3": "string",
      "City": "string",
      "State": "string",
      "PostalCode": "string",
      "CountryCode": "string"
    },
    "AcceptTerms": false,
    "AssociateBaseType": 0,
    "AssociateType": 0,
    "PriceGroup": 0,
    "AssociateTypeName": "string",
    "BackOfficeId": "string",
    "BirthDate": "0001-01-01T00:00:00",
    "CompanyName": "string",
    "DormantDate": "0001-01-01T00:00:00",
    "EmailAddress": "string",
    "Name": "string string",
    "DisplayFirstName": "string",
    "DisplayLastName": "string",
    "LegalFirstName": "string",
    "LegalLastName": "string",
    "RomanizedFirstName": "string",
    "RomanizedLastName": "string",
    "PrimaryPhone": "string",
    "SecondaryPhone": "string",
    "LanguageCode": "string",
    "ShipAttention": "string",
    "ShipPhone": "string",
    "SignupDate": "0001-01-01T00:00:00",
    "UpgradeDate": "0001-01-01T00:00:00",
    "SignupMethod": "string",
    "TaxExempt": false,
    "TaxId": "string",
    "TaxResaleNo": "string",
    "TeamId": 0,
    "TextNumber": "string",
    "ExternalId": "string",
    "StatusId": 0,
    "Void": false,
    "Custom": {
      "Field1": "string",
      "Field2": "string",
      "Field3": "string",
      "Field4": "string",
      "Field5": "string"
    }
  }
}

Response Model

{
  "UserDefinedFields": null
}
Was this article helpful?
0 out of 0 found this helpful
Previous Next

Comments

0 comments

Please sign in to leave a comment.