Share via


GetChangedTaxScheduleDetailKeyList

Description

Retrieves a list of changed tax schedule detail key objects for the tax schedule details that have been acted on during the specified interval. A tax schedule detail has been acted on if it has been created, updated, or deleted. Entity change tracking must be enabled for this method to return valid results.

Parameters

Parameter

Type

Description

criteria

TaxScheduleDetailChangedKeyCriteria

The tax schedule detail changed key criteria object that specifies which changed tax schedule detail key objects to return.

context

Context

Specifies information about how the method will be called.

Return Value:

Value

Type

Description

GetChangedTaxScheduleDetailKeyListResult

ArrayOfChangedTaxScheduleDetailKey

The list of changed tax schedule detail key objects that match the specified criteria.

Interfaces

  • Dynamics GP

Examples

The following C# example retrieves the list of the changed tax schedule detail key objects for all of the tax schedule details that were created, updated, or deleted over the last week. A message box displays the number of tax schedule details that had each action type performed on them.

Gg133629.LegacyEndpoint(en-us,MSDN.10).gif** Legacy endpoint**

using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Forms;
using DynamicsGPWebServiceSample.DynamicsGPService;

namespace DynamicsGPWebServiceSample
{
    class Program
    {
        static void Main(string[] args)
        {
            CompanyKey companyKey;
            Context context;
            TaxScheduleDetailChangedKeyCriteria taxScheduleDetailCriteria;
            ChangedTaxScheduleDetailKey[] changedTaxScheduleDetailKeyObjects;
            BetweenRestrictionOfNullableOfDateTime restriction;

            // Create an instance of the service
            DynamicsGP wsDynamicsGP = new DynamicsGP();

            // Be sure the default credentials are used
            wsDynamicsGP.UseDefaultCredentials = true;

            // Create a context with which to call the service
            context = new Context();

            // Specify which company to use (sample company)
            companyKey = new CompanyKey();
            companyKey.Id = (-1);

            // Set up the context object
            context.OrganizationKey = (OrganizationKey)companyKey;

            // Create the restriction that defines the interval examined for changes
            // The following restriction includes the last week
            restriction = new BetweenRestrictionOfNullableOfDateTime();
            restriction.From = DateTime.Today.Date.AddDays(-7);
            restriction.To = DateTime.Today.Date.AddDays(1);

            // Create the criteria to return tax schedule detail objects that changed
            taxScheduleDetailCriteria = new TaxScheduleDetailChangedKeyCriteria();
            taxScheduleDetailCriteria.LastModifiedDate = restriction;

            // Retrieve the changed tax schedule detail key objects
            changedTaxScheduleDetailKeyObjects = wsDynamicsGP.GetChangedTaxScheduleDetailKeyList(taxScheduleDetailCriteria, context);

            // Display the numbers of tax schedule details that were acted on this week
            int created = 0;
            int updated = 0;
            int deleted = 0;

            foreach (ChangedTaxScheduleDetailKey key in changedTaxScheduleDetailKeyObjects)
            {
                if (key.Action == DataModificationAction.Created)
                    created++;

                if (key.Action == DataModificationAction.Updated)
                    updated++;

                if (key.Action == DataModificationAction.Deleted)
                    deleted++;
            }

            string message;
            message = "Tax schedule details: \n";
            message = message + "Created: " + created.ToString() + "\n";
            message = message + "Updated: " + updated.ToString() + "\n";
            message = message + "Deleted: " + deleted.ToString() + "\n";

            MessageBox.Show(message);
        }
    }
}

Gg133629.NativeEndpoint(en-us,MSDN.10).gif** Native endpoint **

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.ServiceModel;
using System.Windows.Forms;
using DynamicsGPWebServiceSample.DynamicsGPService;

namespace DynamicsGPWebServiceSample
{
    class Program
    {
        static void Main(string[] args)
        {
            CompanyKey companyKey;
            Context context;
            TaxScheduleDetailChangedKeyCriteria taxScheduleDetailCriteria;
            ChangedTaxScheduleDetailKey[] changedTaxScheduleDetailKeyObjects;
            BetweenRestrictionOfNullableOfdateTime restriction;

            // Create an instance of the service
            DynamicsGPClient wsDynamicsGP = new DynamicsGPClient();

            // Create a context with which to call the service
            context = new Context();

            // Specify which company to use (sample company)
            companyKey = new CompanyKey();
            companyKey.Id = (-1);

            // Set up the context object
            context.OrganizationKey = (OrganizationKey)companyKey;

            // Create the restriction that defines the interval examined for changes
            // The following restriction includes the last week
            restriction = new BetweenRestrictionOfNullableOfdateTime();
            restriction.From = DateTime.Today.Date.AddDays(-7);
            restriction.To = DateTime.Today.Date.AddDays(1);

            // Create the criteria to return tax schedule detail objects that changed
            taxScheduleDetailCriteria = new TaxScheduleDetailChangedKeyCriteria();
            taxScheduleDetailCriteria.LastModifiedDate = restriction;

            // Retrieve the changed tax schedule detail key objects
            changedTaxScheduleDetailKeyObjects = wsDynamicsGP.GetChangedTaxScheduleDetailKeyList(taxScheduleDetailCriteria, context);

            // Display the numbers of tax schedule details that were acted on this week
            int created = 0;
            int updated = 0;
            int deleted = 0;

            foreach (ChangedTaxScheduleDetailKey key in changedTaxScheduleDetailKeyObjects)
            {
                if (key.Action == DataModificationAction.Created)
                    created++;

                if (key.Action == DataModificationAction.Updated)
                    updated++;

                if (key.Action == DataModificationAction.Deleted)
                    deleted++;
            }

            string message;
            message = "Tax Schedule Details: \n";
            message = message + "Created: " + created.ToString() + "\n";
            message = message + "Updated: " + updated.ToString() + "\n";
            message = message + "Deleted: " + deleted.ToString() + "\n";

            MessageBox.Show(message);

            // Close the service
            if (wsDynamicsGP.State != CommunicationState.Faulted)
            {
                wsDynamicsGP.Close();
            }
        }
    }
}