Tuesday, May 13, 2025

Delete TFS Workspace Through command prompt D365 FO

Requirement: where I have situation need to configure the TFS in my Development machine but getting error when we map metadata.

 cause of the issue earlier in same Development machine another developer configures TFS with Private permission. so, system not allowing us to configure TFS.





solution

1) Open Developer command prompt visualstudio2022 

2)just enter tf workspaces. will get the list of users and workspaces



3) deleting workspace name

Follow the syntax
tf workspace /delete "WORKSPACENAME;PREVIOUSUSERACCOUNT”


copy and paste in the command prompt and hit enter, then select "Y".

tf workspace /delete "Test_venkates_1;venkatesh"  

after entering it will ask for confirmation enter yes .it will be deleted 


 


Monday, May 12, 2025

purchase order confirmation, product receipt, Invoice classes and methods

 Purchase order confirmation, product receipt, Invoice, cancel  classes and methods

Let's assume that we have the requirement to send business events after purchase order confirmation, cancel, product receipt and invoice Fully (header level)


1) purchase order cancel 

=================

[ExtensionOf(classstr(PurchCancel))]

public final class TestPurchCancel_Extension

{

public void run()

{   

PurchTable  purchTableOrig, purhtableLoc;

next run();

purchTableOrig = this.parmPurchTable();

                select firstonly purhtableLoc

where purhtableLoc.PurchId         == purchTableOrig.PurchId

&& purhtableLoc.PurchStatus == PurchStatus::Canceled;


    if(purhtableLoc.RecId)

{

//Write your logic

}

}

}



2) product receipt and invoice 
=====================

[ExtensionOf(classstr(PurchFormletter))]

public final class TestPurchFormLetter_Extension

{

    public void run()

    {

        PurchTable          purchTableOrig, purhtableLoc;

        next run();


        purchTableOrig = purchFormLetterContract.parmPurchTable();


        select firstonly purhtableLoc

            where purhtableLoc.PurchId      == purchTableOrig.PurchId

               &&(purhtableLoc.PurchStatus  == PurchStatus::Received||

                  purhtableLoc.PurchStatus  == PurchStatus::Invoiced);

        

        if(purhtableLoc.RecId)

        {

            //Write your logic 

        }

        

    }

}


3) purchase order confirmation

===========================

[ExtensionOf(classstr(SourceDocumentStateInProcess))]

public final class TestSourceDocumentStateInProcess_Extension

{

    protected boolean doTransition()

    {

        next doTransition();

        

        if (targetSourceDocumentAccountingStatus == SourceDocumentAccountingStatus::Completed)

        {

            PurchTable purchTable =                                PurchTable::findSourceDocumentHeader(sourceDocumentHeader.RecId);

            VendPurchOrderJour vendPurchOrderJour = VendPurchOrderJour::findByPurchId(purchTable.PurchId);

            if(vendPurchOrderJour.RecId)

            {

              //Write your logic

            }

        }

        return true.

    }

}


while doing purchase order confirmation, product receipt and invoice system will create journals and post and update the status in PurchTable  .after updating status or creating journal if we want any customizations we can do in below method  


[ExtensionOf(classstr(FormletterService))]
public  final class TestFormLetterService_Extension
{
    protected void processJournal(Printout _printout)
    {
       
        VendPurchOrderJour  vendPurchOrderJourloc;
        PurchTable          purchTableLoc;
vendinvoicejour     vendinvoicejour     
VendPackingSlipJour VendPackingSlipJour;

        next processJournal(_printout);

        purchTableLoc= formLetterContract.parmsourceTable() as PurchTable;

//purchase order confirmation
            select  firstonly vendPurchOrderJourloc
            where vendPurchOrderJourloc.PurchId         == purchTableLoc.PurchId
                && vendPurchOrderJourloc.DataAreaId == purchTableLoc.DataAreaId;
            if(vendPurchOrderJourloc.recid)
            {
            //write your logic 
    }
//for packingslip post
select  firstonly VendPackingSlipJour
            where VendPackingSlipJour.PurchId         == purchTableLoc.PurchId
                && VendPackingSlipJour.DataAreaId == purchTableLoc.DataAreaId;
            if(VendPackingSlipJour.recid)
            {
            //write your logic 
    }

//for invoice post
select  firstonly vendinvoicejour     
            where vendinvoicejour.PurchId         == purchTableLoc.PurchId
                && vendinvoicejour.DataAreaId == purchTableLoc.DataAreaId;
            if(vendinvoicejour.recid)
            {
            //write your logic 
    }
        
    }

}

Tuesday, March 18, 2025

Getting error while exporting data using Data Management

 

Getting error while exporting data using Data Management

 
<?xml version=/1.0/?><Errors><Error><ErrorCode>0</ErrorCode><SubComponent>Copy Error Component</SubComponent><Description>Index was outside the bounds of the array.</Description></Error><Error><ErrorCode>0</ErrorCode><SubComponent>Copy Error Component</SubComponent><Description>   at Microsoft.Dynamics.AX.Framework.Tools.DMF.DMFErrorDescription.ErrorOutputDescription.ProcessInput(Int32 inputID, PipelineBuffer buffer)</Description></Error><Error><ErrorCode>-1073450910</ErrorCode><SubComponent>Copy Error Component [255]</SubComponent><Description>System.ApplicationException: Could Not Process Input
   at Microsoft.Dynamics.AX.Framework.Tools.DMF.DMFErrorDescription.ErrorOutputDescription.ProcessInput(Int32 inputID, PipelineBuffer buffer)
   at Microsoft.SqlServer.Dts.Pipeline.ManagedComponentHost.HostProcessInput(IDTSManagedComponentWrapper100 wrapper, Int32 inputID, IDTSBuffer100 pDTSBuffer, IntPtr bufferWirePacket)</Description></Error><Error><ErrorCode>-1073450974</ErrorCode><SubComponent>SSIS.Pipeline</SubComponent><Description>SSIS Error Code DTS_E_PROCESSINPUTFAILED.  The ProcessInput method on component /Copy Error Component/ (255) failed with error code 0x80131600 while processing input /Error Input 257/ (257). The identified component returned an error from the ProcessInput method. The error is specific to the component, but the error is fatal and will cause the Data Flow task to stop running.  There may be error messages posted before this with more information about the failure.
</Description></Error></Errors>
Package execution failed please check event log in DMF service box

1. It is a custom data entity, yes I have tried to do a full Sync.
 
2. This Error was encountered while exporting.
 
3. This error is now solved, the root cause for this error was one of the fields that i was trying to export contained data in below format:
   
"Sample String 示例字符串"
 
The Text in English was also translated to chinese and added in the field.

To Solve this Issue I removed the chinese text from the field and only  imported the Englist text and now import happens Successfully.





Monday, February 24, 2025

Posting methods in x++

while posting packing Slip

class/SalesPackingSlipJournalPost/method/endUpdate();


[ExtensionOf(classStr(SalesPackingSlipJournalPost))]

final class TestSalesPackingJournalPost_Extension

{

     protected void endUpdate()

    {

            next endUpdate();

        // write your logic

    }

}

How to search metadata in x++

Query stringWhat it does
TrvExpTableIf the token is by itself, it is assumed to be the name. So this will find everything in the application that has "TrvExpTable" in the name.
type:form ccountFinds all forms that have "ccount" in their names.
type:form property:formtemplate=listpageFinds all forms that contain the property "FormTemplate" equal to ‘ListPage’.
type:table,formDesign property:"WorkflowDataSource=TrvExpTable"Finds formDesign nodes under tables, nothing would be found.
type:form,formmenufunctionbuttoncontrol property:Text=@SYS311998Finds all menu function button controls with the Text property equal to (a label) ‘@SYS311998’.
type:table,method name:insertFinds tables with a method containing "insert" in the method name.
type:table,tableindex name:ExportFinds tables with an index name containing the word "Export".
type:table,tableindexfield name:xpNumFinds table indexes with "xpNum" in the index field name.
type:table,tablefieldgroup name:EPNewFinds FieldGroups (in tables) containing ‘EPNew’ in their names.
type:form,formgridcontrol property:allowedit=no,heightmode=columnFinds form grid controls, with properties allowedit equal to "no" and heightmode equal to "column".
type:form,formtabcontrol property:arrangeMethod=Vertical,ViewEditMode=view,WidthMode=AutoFinds form tab controls, with properties arrangeMethod equal to "Vertical" and ViewEditMode equal to "view" and WidthMode equal to "Auto".
type:form,formDesign property:"WorkflowDataSource=TrvExpTable"Finds all forms with the "WorkflowDataSource" property in the FormDesign node set to the value "TrvExpTable".
model:”Application Suite” type:formdesign property:style=simplelistdetailFind all forms in Application Suite model that has the style property set to simpleListDetail in the FormDesign node.
code:"return null"Finds all places in the source code that contains "return null".
code:"element.lock()" type:formFinds all places in the forms source code that contain the snippet "element.lock()".
code:"insert" type:table,formFinds all places in the source code of either forms or tables that contain "insert".
code:"public display" type:form,methodFinds all form methods that contain the code "public display".
type:formbuttoncontrol property:text=Finds all form Button Controls that have empty text properties.


Reference;  Metadata search

 

Tuesday, February 4, 2025

Import Database ( Restore ) in d365 FO

 While restoring DB from  Tier2 to tier 1 environments (Bacpac to bak)

1) firstly we need  install the  SQl package  and extract it 



by using below command in command prompt  we restore the new DB in our dev machine 
2)SqlPackage.exe /a:import /sf:D:\Exportedbacpac\my.bacpac /tsn:localhost /tdn:<target database name> /p:CommandTimeout=1200 /TargetTrustServerCertificate:true 

  • tsn (target server name) – The name of the Microsoft SQL Server instance to import into.
  • tdn (target database name) – The name of the database to import into. The database should not already exist.
  • sf (source file) – The path and name of the file to import from.

EX



3)once New DB Created  we need to execute below script .

==========================================

CREATE USER axdeployuser FROM LOGIN axdeployuser

EXEC sp_addrolemember 'db_owner', 'axdeployuser'


CREATE USER axdbadmin FROM LOGIN axdbadmin

EXEC sp_addrolemember 'db_owner', 'axdbadmin'


CREATE USER axmrruntimeuser FROM LOGIN axmrruntimeuser

EXEC sp_addrolemember 'db_datareader', 'axmrruntimeuser'

EXEC sp_addrolemember 'db_datawriter', 'axmrruntimeuser'


CREATE USER axretaildatasyncuser FROM LOGIN axretaildatasyncuser


CREATE USER axretailruntimeuser FROM LOGIN axretailruntimeuser


CREATE USER axdeployextuser FROM LOGIN axdeployextuser


CREATE USER [NT AUTHORITY\NETWORK SERVICE] FROM LOGIN [NT AUTHORITY\NETWORK SERVICE]

EXEC sp_addrolemember 'db_owner', 'NT AUTHORITY\NETWORK SERVICE'


UPDATE T1

SET T1.storageproviderid = 0

    , T1.accessinformation = ''

    , T1.modifiedby = 'Admin'

    , T1.modifieddatetime = getdate()

FROM docuvalue T1

WHERE T1.storageproviderid = 1 --Azure storage


DROP PROCEDURE IF EXISTS SP_ConfigureTablesForChangeTracking

DROP PROCEDURE IF EXISTS SP_ConfigureTablesForChangeTracking_V2

GO

-- Begin Refresh Retail FullText Catalogs

DECLARE @RFTXNAME NVARCHAR(MAX);

DECLARE @RFTXSQL NVARCHAR(MAX);

DECLARE retail_ftx CURSOR FOR

SELECT OBJECT_SCHEMA_NAME(object_id) + '.' + OBJECT_NAME(object_id) fullname FROM SYS.FULLTEXT_INDEXES

    WHERE FULLTEXT_CATALOG_ID = (SELECT TOP 1 FULLTEXT_CATALOG_ID FROM SYS.FULLTEXT_CATALOGS WHERE NAME = 'COMMERCEFULLTEXTCATALOG');

OPEN retail_ftx;

FETCH NEXT FROM retail_ftx INTO @RFTXNAME;


BEGIN TRY

    WHILE @@FETCH_STATUS = 0 

    BEGIN 

        PRINT 'Refreshing Full Text Index ' + @RFTXNAME;

        EXEC SP_FULLTEXT_TABLE @RFTXNAME, 'activate';

        SET @RFTXSQL = 'ALTER FULLTEXT INDEX ON ' + @RFTXNAME + ' START FULL POPULATION';

        EXEC SP_EXECUTESQL @RFTXSQL;

        FETCH NEXT FROM retail_ftx INTO @RFTXNAME;

    END

END TRY

BEGIN CATCH

    PRINT error_message()

END CATCH


CLOSE retail_ftx; 

DEALLOCATE retail_ftx; 

-- End Refresh Retail FullText Catalogs


--Begin create retail channel database record--

declare @ExpectedDatabaseName nvarchar(64) = 'Default';

declare @DefaultDataGroupRecId BIGINT;

declare @ExpectedDatabaseRecId BIGINT; 

IF NOT EXISTS (select 1 from RETAILCONNDATABASEPROFILE where NAME = @ExpectedDatabaseName)

BEGIN 

select @DefaultDataGroupRecId = RECID from RETAILCDXDATAGROUP where NAME = 'Default'; 

insert into RETAILCONNDATABASEPROFILE (DATAGROUP, NAME, CONNECTIONSTRING, DATASTORETYPE)

values (@DefaultDataGroupRecId, @ExpectedDatabaseName, NULL, 0); 

select @ExpectedDatabaseRecId = RECID from RETAILCONNDATABASEPROFILE where NAME = @ExpectedDatabaseName; 

insert into RETAILCDXDATASTORECHANNEL (CHANNEL, DATABASEPROFILE)

select RCT.RECID, @ExpectedDatabaseRecId from RETAILCHANNELTABLE RCT

inner join RETAILCHANNELTABLEEXT RCTEX on RCTEX.CHANNEL = RCT.RECID

        update RETAILCHANNELTABLEEXT set LIVECHANNELDATABASE = @ExpectedDatabaseRecId where LIVECHANNELDATABASE = 0

END; 

--End create retail channel database record


4) Stop the below 4 services

  • World Wide Web Publishing Service
  • Microsoft Dynamics 365 Unified Operations: Batch Management Service
  • Management Reporter 2012 Process Service
  • Microsoft Dynamics 365 Unified Operations: Data Import Export Framework Service 
5) Rename the DB.

2
3
4
5
6
ALTER DATABASE AXDB SET SINGLE_USER WITH ROLLBACK IMMEDIATE
GO
ALTER DATABASE AXDB MODIFY NAME = AXDB_Orig
GO
ALTER DATABASE AXDB_Orig SET MULTI_USER
GO

6) start the below  4 services 
  • World Wide Web Publishing Service
  • Microsoft Dynamics 365 Unified Operations: Batch Management Service
  • Management Reporter 2012 Process Service
  • Microsoft Dynamics 365 Unified Operations: Data Import Export Framework Service

reference: Import Database


 

User License

 using Microsoft.Dynamics.AX.Security.Management;

using Microsoft.Dynamics.AX.Security.Management.Querying;

using Microsoft.Dynamics.AX.Security.Management.UI;


class test

{


    public static Str getDefaultDimName(DimensionDefault _dimensionDefault)

    {

        DefaultDimensionView    dimensionView;

        str                     dimensionValue;



        while select dimensionView

            where dimensionView.DefaultDimension == _dimensionDefault

        {

            dimensionValue += dimensionView.DisplayValue + '~';

        }


        return dimensionValue;

    }


    public static DimensionDefault createDefaultDim(Name _dimensionName, str _dimValue ,  DimensionDefault _oldDefaultDimenion = 0)

    {

        DimensionAttributeValueSetStorage   valueSetStorage = new DimensionAttributeValueSetStorage();

        DimensionDefault                    result;


        int                                 i;

        DimensionAttribute                  dimensionAttribute;

        DimensionAttributeValue             dimensionAttributeValue;

        DimensionDefault                    newDefaultDimension;

   

        dimensionAttribute = dimensionAttribute::findByName(_dimensionName);


        if (dimensionAttribute.RecId != 0 && _dimValue)

        {

            dimensionAttributeValue = DimensionAttributeValue::findByDimensionAttributeAndValueNoError(dimensionAttribute, _dimValue, false, true);

            valueSetStorage.addItem(dimensionAttributeValue);

        }

        result = valueSetStorage.save();

        newDefaultDimension   = LedgerDimensionDefaultFacade::serviceMergeDefaultDimensions(result,_oldDefaultDimenion);


        return newDefaultDimension;

    }


    public static LedgerJournalTable createLedgerJournal(LedgerJournalNameId    _journalName, CurrencyCode  _currencyCode = "")

    {

        LedgerJournalTable      ledgerJournalTable;

        LedgerJournalTableData  jourTableData;

        ;


        jourTableData = JournalTableData::newTable(ledgerJournalTable);


        ledgerJournalTable.JournalNum  = jourTableData.nextJournalId();

        ledgerJournalTable.JournalName = _journalName;

        ledgerJournalTable.initFromLedgerJournalName(_journalName);


        if(_currencyCode)

        {

            ledgerJournalTable.CurrencyCode = _currencyCode;

        }

        ledgerJournalTable.insert();


        return ledgerJournalTable;

    }


    public static boolean  checkUserLicence(UserLicenseType _userLlicenceType, UserId _userId = curUserId())

    {

        SecurityLicenseRole SecurityLicenseRole;

        SecurityRole        role;

        SecurityUserRole    userRole;

        UserInfo            userInfo;

        boolean             ret = false;


        DialogService::PopulateSysSecurityRolesWithAggregateLicense(SecurityLicenseRole.getPhysicalTableName(), SysSecurity::GetSecurityRepository());


        while select role

            exists join userRole

                where userRole.User == _userId

                   && userRole.SecurityRole == role.RecId

        {

            select firstonly SecurityLicenseRole

                where SecurityLicenseRole.SecurityRole == role.recId;

            

            if(SecurityLicenseRole.RecId)

            {

                List strlist = new List(Types::String);

                strlist = strSplit(SecurityLicenseRole.License, ',');

                ListIterator iterator = new ListIterator(strlist);

                str licenseString;

                boolean isFirst = true;

                while (iterator.more())

                {

                    UserLicenseType license = any2Enum(iterator.value());

                    if( license == _userLlicenceType )

                    {

                        ret = true;

                        break;

                    }

                    iterator.next();

                }

            }

        }

       

        return ret;

}


}

Delete TFS Workspace Through command prompt D365 FO

Requirement: where I have situation need to configure the TFS in my Development machine but getting error when we map metadata.  cause of t...