Contact Me

Total Pageviews

Saturday, 4 October 2014

Restrict user access to certain companies through Roles

Follow the steps below:

1.Start off by finding the user that you want to restrict access to just a selected  number of companies.


2.Now open up the user profile, and click on the Assign Organizations menu button within the User’s Roles tab.  


3.When the Organizations for the User * maintenance form is displayed, you will see that the user has full access to all of the companies within the system.
To restrict access, click on the Grant Access to Specific Organizations Individually radio button.

4.This will allow you to select from the Available Organization Nodes. Select Organization that you want to grant the user access to, and then click on the Grant button.

5.You can repeat this process for any additional Organizations that you want them to have access to and then click on the Close button to exit the form.
How It Works…
6.The next time the user logs in, they will only see the organization that you have granted them access to.

Happy Daxing:) 

Assign Roles to Users in Ax 2012

Roles can be assigned to a user by performing the following steps:

1. Open the Users list page and locate the required user.
2. Click on Edit or double-click on the user, as shown in the following screenshot:



We can chose to assign new roles, remove existing roles, assign organizations, and
edit roles.
Removing a role is straightforward. Highlight the role and click on Remove. The user doesn't have to be logged out for this to happen, but will need to log off to see the effects of any change to the user's security.

3.Click on Assign roles, which will show a list of all the available roles as shown in the
following screenshot:


 4. Check each role checkbox depending on the role the user should be a member
of and click on OK. This closes the form and updates the User details form.

Happy Daxing :)




Friday, 3 October 2014

User Relations in Axapta

Some features in AX require that your user account and employee record are linked. This is a good practice, and all users who are employees (or subcontractors) should be associated with an employee record. Without this link, some functionality will not work, especially within sales and marketing.


All the users who are employees on a temporary or permanent basis should be related
to an employee.

For defining the relation between users and employees, perform the following steps:

1. On the Users list page, select the user you wish to assign as an employee and click
on Relations.

2. Go to the General Tab.

3. Select Employee from Lookup.
4. Save the record in the User relations form.
5. Close the User relations form.
6. Close the User form.
Happy Daxing :)


Wednesday, 1 October 2014

Creating a new Dynamics AX user

This post  explains the process of creating a user manually within AX, either as an Active
Directory user or as an Active Directory user group.

To create a single user, navigate to System administration | Common | Users. The  following window will be opened:


 We can create a new Active Directory user with the following steps:

1. On the Users list page, click on User in the New button group on the action pane,
as shown in the following screenshot:
Once you save the record (or check Enabled), the system will look up the account details
entered in your Active Directory to validate the details entered and also to store those of the
user (or the Active Directory group) and Security Identifier (SID).

You can also create a new user from an Active Directory user group. This is a special case of
user management, where all users in an Active Directory are granted access based on their
user group in the Active Directory.

The concept is that you create a user group in your Active Directory for each role within AX and
add the users into this group.
When the user in the Active Directory user group logs in to AX for the first time, it creates a
specific user with the roles (and privileges) of the user group.

To create a user group user, the steps are the same as per an individual user account, except
for the following fields:

User Id -> This is merely a unique ID, but using the AD user group is preferable.
Alias ->     This is the user group, for example, AXAdmins.
Account type -> This is the Active Directory group.

Once complete, closing the form will save the changes and validate that the Active Directory
user group exists.


Importing users from the Active Directory:

Users can be imported from the Active Directory through the following steps:
 

1. On the Users list page, click on Import. This will open the Active Directory
Import Wizard.


2. Click on Next, which will display the following page:



3. On clicking Next, AX will produce a list of users that will be imported:


 
4. Click on Next to continue to user role selection, or go back to adjust the
selections made:

We now have the option to add the users to roles.Let's say we are adding the finance department to AX. We can add all the finance users in one batch, assigning the Accountant role to all. Once complete, we can move the managers in to the Accounting manager role.

In the preceding example, Josh is a Product designer, but also in charge of IT.

5.Once complete, click on Next and select the profiles that the users should be a part
of, as shown in the following screenshot:



6. Once complete, click on Next.
7. On this final step, clicking on Finish will import the users with the settings you have
specified. Clicking on Cancel will close the wizard without importing the users.

The users will now appear in the Users list page; you can double-click on a record to view the details and make any adjustments.

Happy Daxing :)


Monday, 22 September 2014

Import Data from Excel Using Dialog (X++)

Hi all,

Today I am going to tell you guys how to Import Data from an Excel file into Ax Table using a Dialog.

Step 1 : Create a Table (ProductType) with three fields as following :


Step 2: Create a class "ImportExcel" that extends Runbase framework and with the following methods :

class ImportExcel extends RunBase
{
   #excel
   #file

   FileNameOpen               fileNameOpen;
   DialogField                     dialogfileNameOpen;

   COMVariant                  comVariant1;
   COMVariantType          comVariant2;
   SysExcelApplication      app;
   SysExcelWorkbooks      workbooks;
   SysExcelWorkbook       workbook;
   SysExcelWorksheets     worksheets;
   SysExcelWorksheet       worksheet;
   SysExcelCells                 cells;
   SysExcelCell                   rcell;

   #define.CurrentVersion(1)
   #localMacro.CurrentList
       fileNameOpen
   #endMacro
}
 


public Object dialog()
{
    DialogRunBase       dialog = super();
;
    dialog.caption("@SYS7444");
    dialogfileNameOpen = dialog.addFieldValue(typeid(FileNameOpen), fileNameOpen);
    dialog.filenameLookupFilter(["@SYS28576",#XLSX, "@SYS28576",#XLS]);
    return dialog;
}



public boolean getFromDialog()
{
    boolean ret;


    ret = super();

    fileNameOpen = dialogfileNameOpen.value();

    return ret;
}



public container pack()
{
    return [#CurrentVersion, #CurrentList];
}


public boolean unpack(container _packedClass)
{
    Version version = RunBase::getVersion(_packedClass);
    ;
    switch (version)
    {
        case(#CurrentVersion) :
            [version, #CurrentList] = _packedClass;
            break;

        default :
            return false;
    }

    return true;
}


public boolean validate(Object calledFrom)
{
    boolean ret;

    ret = super(calledFrom);

    if(!fileNameOpen)
        ret = checkFailed(strfmt('File name cannot be left blank'));

    if(fileNameOpen && !WinApi::fileExists(fileNameOpen))
        ret = checkfailed('File not found');

    return ret;
}


public static void main(Args args)
{
    ImportExcel      importMapping;
    ;

    importMapping  =   new ImportExcel();

    if (importMapping.prompt())
    {
        importMapping.run();
    }
}


public void run()
{
    try
    {
        ttsbegin;
        this.importExcel();
      
        ttscommit;
    }
    catch (Exception::Error)
    {
        ttsabort;
        exceptionTextFallThrough();//to avoid Compiler error
    }
}


And finally the ImportExcel method of the class :

void importExcel()
{
    #AviFiles
    ProductType                 productType;
    int                         row;
    SysOperationProgress        progress1;
    ;
    //Define parameters
    app = SysExcelApplication::construct();
    Workbooks = app.Workbooks();
    COMVariant1 = new COMVariant();
    COMVariant1.bStr(fileNameOpen);
    Workbook = Workbooks.add( COMVariant1);
    Worksheets = Workbook.worksheets();
    Worksheet = Worksheets.itemFromNum(1);
    Cells = Worksheet.Cells();

    progress1   =   new SysOperationProgress();
    progress1.setCaption("Excel import");
    progress1.setAnimation(#AviTransfer);

    delete_from  productType ;

    row = 1;
    do
    {
       progress1.setText(strfmt("Importing row %1", row));
       productType.ID   = cells.item(row,1).value().bStr();
       productType.Type = cells.item(row,2).value().bStr();
       productType.Description = cells.item(row,3).value().bStr();

       productType.insert();
       row++;
       COMVariant2 = cells.item(row, 1).value().variantType();

    }
    while( COMVariant2!= COMVariantType::VT_EMPTY);
    info(strfmt("%1 rows imported", row-1));









Happy Daxing:)