Friday, July 8, 2016

"Keyset does not exist" error message when you try to change the identity of an application pool by using Internet Information Services


When I try to change the identity of any application pool, received the following error message:

---------------------------
Application Pools
---------------------------
There was an error while performing this operation.

Details:

Keyset does not exist (Exception from HRESULT: 0x80090016)


Reason : 
         There is not enough permissions to open file

  • %ALLUSERSPROFILE%\Microsoft\Crypto\RSA\MachineKeys\ 6de9cb26d2b98c01ec4e9e8b34824aa2_*
  • %ALLUSERSPROFILE%\Microsoft\Crypto\RSA\MachineKeys\ 76944fb33636aeddb9590521c2e8815a_*


Resolution

  1.     Go to '%ALLUSERSPROFILE%\Microsoft\Crypto\RSA\MachineKeys'
  2.     Find files with name starts as 6de9cb26d2b98c01ec4e9e8b34824aa2_ and                            76944fb33636aeddb9590521c2e8815a_.
  3.    Check permission for this file. Default permissions are:
    •        System, Administrators,TrustedInstaller - Full permissions
    •       IIS_IUSR,WMSVC - Read permissions
    •       LOCAL SERVICE - Read permission

If the issue still persists:

Take backup of MachineKeys (%ALLUSERSPROFILE%\Microsoft\Crypto\RSA\MachineKeys)
Give full permissions to your account to access the MachineKeys folder.

  Please check that files have name 6de9cb26d2b98c01ec4e9e8b34824aa2_GUID and 76944fb33636aeddb9590521c2e8815a_GUID .

If not, just copy existing files started with name 6de9cb26d2b98c01ec4e9e8b34824aa2_ and 76944fb33636aeddb9590521c2e8815a_ and then set GUID part in the file name equals to GUID obtained from MachineGuid registry key from HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Cryprography\





Wednesday, June 1, 2016

C# 6.0 New Features

Using Static Statement
We all know that you can import a namespace with using.  This gives us the ability to use a type with just the type’s name in our code. 
using System;

public class Driver
{
    public static void Main()
    {
         // without importing a namespace, we'd have to fully qualify the type
        // Console as System.Console
       //System.Console.WriteLine("Hello, World!");

        Console.WriteLine("Hello, World!");
    }
}

In C#6.0, import the static members of a class into our namespace , making them available without qualification in subsequent code:
using static System.Console;
 
public class Driver
{
    public static void Main()
    {
        // Now, the System.Console static class is imported, so we
        // can use WriteLine directly
        WriteLine("Hello, World!");
    }
}
 
void Main()
{
    MyStaticClass.Print("this string");      //Print is a static member in MyStaticClass
    // or...
    Print("this string");
}
 
Importing static types and accessing extension methods of them like the code above will give you an error. The following code will generate the "The name 'IsPolygon' does not exist in the current context".
Non-extension static methods are invoked as though they are methods on the current type, whereas extension methods are invoked only as though they are methods on a variable.
Read only Property and initialization
Public string Name {get;} = “XXXXX”;       or            public string Name => “XXXX”;
Expression-Bodied Get-Only Properties
Now, if you have a property that is get-only, you can write the body of the property using the expression syntax.  That is, you can use the lambda-expression syntax to write the body of the property. 
That is, instead of writing the { get { return your expression; } } syntax, we can simply write => your expression;
For example, if we convert our get-only properties above, we can get:
   1: public class Rectangle
   2: {
   3:     public int Length { get; set; }
   4:     public int Width { get; set; }
   5:  
   6:     // much more concise! Read Only properties
   7:     public int Area => Length * Width;
   8:     public int Perimeter => 2 * (Length + Width);
   9:  
  10:     public override string ToString()
  11:     {
  12:         return $"Rectange: Length={Length}, Width={Width}";
  13:     }
  14: }
It does not create a delegate, it is simply borrowing the lambda expression syntax to simplify writing simple bodies that result in an expression.
After lambda express we always have single statement.
Expression-bodied function members can work for both methods and properties. If you have a method with one statement, and that statement can be represented as an expression:
public string GetFullName() {
  return FirstName + " " + LastName;
}
Or a getter-only properties/indexers with a body that can be represented as an expression:
public string FormalName {
  get { return FirstName[0] + ". " + LastName; }
}
Public object TestObj {get {return obj;}}                //Read only property
You can collapse those down into something that looks like a cross between a member declaration and a lambda expression:
public string GetFullName() => FirstName + " " + LastName;
public string FormalName => FirstName[0] + ". " + LastName;
public object TestObj => obj;      //Read only property in C#6.0
Null Propagation Operator
In earlier versions of the C# language, we always had to write an if condition for a null check before using an object or its property. Now C# 6.0 has introduced the Null-Propagation Operator (?.) that enables developers to check for the null value within an object reference chain. The null-propagation operator (?.) will return null if anything in the object reference chain is null.

Example 1
In earlier versions of the C# language, you always had to check for nulls explicitly before using an object or its property, as shown below:
Hide   Copy Code
if (Employee.Name == null
    Console.WriteLine("No Employee name provided"); 
}
The same can be converted into a one-liner using the Conditional Access Operator in C# 6.
Hide   Copy Code
Console.WriteLine(Employee?.Name ?? "No Employee name provided");
Example 2
Suppose we have a class called Student that has another property studentdetails of type Details class. Now we can have the following code snippet to print theAddress .
Hide   Copy Code
if (student != null && student.studentdetails != null
    Console.WriteLine(student.studentdetails.Address); 
else 
    Console.WriteLine("No Address"); 
}
As we can see, to avoid the null-reference exception, we have checked the null for student andstudent.studentdetails since they can have a null reference as object. So, the preceding code snippet can be re-written using the null propagation operator (?.) as follows:
Hide   Copy Code
Console.WriteLine(student?.studentdetails?.Address ?? "No Address");
Both code snippets will provide us the address of the student.

What I think is, it's a really nice feature because instead of checking each and individual objects, using the nullpropagation operator (?.) we can check the entire chain of references together and whenever there is a nullvalue in the entire chain of reference, it will return null.

nameof Operator
nameof operator allows you to retrieve the name of a variable, type or member.
Use the nameof operator to avoid the use of hard-coded strings in our code.
This operator will help us get rid of “magic strings” in our code. We all know following use case:
public void Method(int arg)
{
    if (arg < 0)
    {
        throw new ArgumentOutOfRangeException("arg");
    }
}
With nameof operator we can rewrite code in a nicer way:
public void Method(int arg)
{
    if (arg < 0)
    {
        throw new ArgumentOutOfRangeException(nameof(arg));
    }
}
That is! nameof just returns a string representation of variable\method\type\propery\field.

String Interpolation
This feature inserts values into a string with simple syntax. It is similar to string.Format, but variables may be accessed directly
            string name = "Valentino";
            int age = 7;

            var data1 = string.Format("name:{0}, age:{1}", name, age);
            Console.WriteLine("classic string format - {0}", data1);

            var data2 = $"name:{name}, age:{age}";
            Console.WriteLine("string interpolation  - {0}", data2);
            Console.ReadLine();

Exception Filters
It allows us to specify conditions along with a catch block. The catch block is only executed if the condition satisfies. 
public void Main()
{
  try
  {  
      throw new Exception("E2");
  }
  catch(Exception ex) when(ex.Message == "E1")
  {
    Console.WriteLine("caught E1");
  }
  catch(Exception ex) when(ex.Message == "E2")
  {
    Console.WriteLine("caught E2");
  }
}

Setting default values to Auto Properties
Now we can assign default value to the properties without writing a second line.  Just place an “=” equal sign at the end and write the default value to it.
Earlier we used to have to do this by setting the default value in the constructor
public string FirstName { get; set; } = "Default Value";

Wednesday, February 24, 2016

Get value when selected an item from datalist

The datalist element and the list attribute are the two new HTML features that bind up the autocomplete functionality.

I have used above features to implement autocomplete functionality in my sample.

My requirement is to select a cityName from the datalist and want to get cityId from cityList

 <input list="fromCityList" required type="text" name="fromCity" placeholder="City" ng-model="Trip.from.city" ng-change="Trip.from.id = (cityList|filter:{name:Trip.from.city})[0].id">
                                                <datalist id="fromCityList" >
                                                    <select>
                                                        <option ng-repeat="city in cityList | filter : {name : Trip.from.city}"
                                                                value="{{city.name}}" ></option>
                                                    </select>
                                                </datalist> 


I have ued the built-in filter to retrieve the correct cityId value for the cityName.


Monday, January 11, 2016

Why BizTalk not supporting multiple send locations for one send port?

     We can have multiple disassemblers in Receive Pipeline, we can receive multiple format files from the same receive pipeline. It execute all the components (0 to 255)placed in it.

     But we cannot have multiple assemblers in Send Pipeline (it can have only 0 to 1). So, we can't use  to send multiple format files through the same Send pipeline.


What if we  want to send multiple format files through the same Send pipeline ?
    We can create a Send port for each format and add them to a Send Port Group

Even I too have this below question in my mind, any idea!

Why BizTalk doesn't provide this feature, BizTalk server is not supporting more than one send location for one send port?

Wednesday, January 6, 2016

Identity (===. !==) vs Equality (==, !=) operators in JavaScript



These operators behave identically to the equality operators except no type conversion is done, and the types must be the same to be considered equal.

Using the == operator (Equality)

     true == 1; //true, because 'true' is converted to 1 and then compared
     "2" == 2;  //true, because "2" is converted to 2 and then compared

Using the === operator (Identity)

     true === 1; //false
     "2" === 2;  //false

This is because the equality operator == does type coercion, meaning that the interpreter implicitly tries to convert the values before comparing.

On the other hand, the identity operator === does not do type coercion, and thus does not convert the values when comparing.