Wednesday, December 31, 2014

Up and running with ASP.net vNext

Up and running with ASP.net vNext

Setting up environment, writing c# code in Brackets and running in command prompt.


For so long now you have been working on OSX and UNIX, but want to taste some Microsoft’s cutting edged technologies. By which I mean you want to end up writing some code in C#. Now the burning question is, how am I going to even write C# code without Visual Studio? And moreover my OS doesn’t support running Microsoft’s products. Well! You don’t have to whine anymore because I’ve got a good news for you.  If you attended the Microsoft’s virtual event called Connect(); earlier November 2014, you may have come across knowing that ASP.net 5 has gone open source. It is known as ASP.net vNext.

Event videos can be found in this link below


Link to the GitHub repository for ASP.net vNext is down below


If you’ve already browsed the repository and read the documentation, you may have seen the minimum requirements and tools to run ASP.net vNext applications in OSX and UNIX operating systems.

In short all you have to do is to install two things in order to create an environment in which you can run C# applications. One of those is KVM (K Version Manager) which basically provides you with .net framework libraries. And the second one is KRE (K Runtime Environment) which is just a runtime environment provider for the framework. It’s just like you have to install JDK and JRE for building and running JAVA applications. So all the hard work is done and time to write some C#.

Before that lets say I don’t have Visual Studio installed in my windows (Of course you can’t install this mind blowing IDE in OSX and UNIX). However I want to take the full advantage of IntelliSense supported in Visual Studio. Let’s take some tiny steps in building our own Visual Studio. First of all choose any advance text editing tool you like. Not just any though, to have the full IntelliSense support you’ve to choose between these advance text editing tools. Don’t worry Sublime Text is one of them and the rest are

·          Atom
·          Brackets
·          Emacs
·          Vim

I choose Brackets since it has some features that fits my needs. Okay so I’ve installed Brackets and fired it up. Here what you will see at the first run.


Let’s click on the icon that says Extension Manager. In this window you can install some extensions for Brackets which will ultimately make your development life easier.

So why would I go to the Extension Manger window? Of course for installing an extension. But which one? The name of the extension is OmniSharp. 



You can visit the official website of this project by going to


As you will see the tag line, it says

OmniSharp - Cross platform .NET development
.NET in Your Editor of Choice

So it’s just an extension provider for your favorite text editor which will enable the IntelliSense support for .net applications. It provides more features than just the IntelliSense support. I leave the rest for you to discover. So far so good.

You are almost ready, in windows let’s run the command prompt in administrative mode. Copy and paste the following command and hit enter

@powershell -NoProfile -ExecutionPolicy unrestricted -Command "iex ((new-object net.webclient).DownloadString('https://raw.githubusercontent.com/aspnet/Home/master/kvminstall.ps1'))"

This command will install the KVM (k Version Manager) in your system.



Again to install the KRE (K Runtime Environment), fire up another command prompt and run the following command

kvm upgrade



Now clone the Asp.net vNext home repository into your desktop.



If you browse the Home folder, you will find three subfolders under the samples folder. These are

·          ConsoleApp
·          HelloMVC
·          HelloWeb




Well, if you want to write a console application you will work in the ConsoleApp folder, the HelloMVC is for creating an Asp.net MVC app and the HelloWeb is just a basic web application skeleton which will just show a static page if you run it.

Now let’s make a traditional “Hello World” application. Before that let’s go inside of the ConsoleApp folder from the command prompt and run the command below

kpm restore

It will restore the packages required by that sample. All the command does is to simply look at the project.json file and download and add the dependencies provided there. Just like nuget package manager.


Now open the ConsoleApp folder in brackets and modify the Program.cs file inside that. Change the text inside the Console.WriteLine method to “Hello from ASP.NET vNext!” and save it.



Finally it’s time to run the console application. To do that just type the command below in the command prompt

k run

It will build and run the console application inside the command prompt and you will get your “Hello from ASP.NET vNext!” string printed on the console.



Building and Running an Asp.net MVC application


Just like the console application, let’s change our directory and go inside HelloMVC folder and run the command below to restore the packages required by the sample.

kpm restore

Now open the folder in Brackets and you will see a MVC application skeleton with a simple POCO class named User inside the Models folder, a HomeController inside the controllers and Index.cshtml inside the Home folder under the Views folder. We also have a _Layout.cshtml file under shared folder which basically just works like a master page for your application.


Rather wasting time, let’s create a POCO class of our own called Employee and add this properties down there.



Now create a controller named EmployeesController and define an Index method which will be responsible for returning a list of predefined employees into the view.



Time to create the view in which we will show the list of employees in a tabular manner. Create an Employees folder under Views and add an Index.cshtml file there. Write the code below 


Our simple MVC application is ready to run. Running a web application is slightly different from running a console app, instead of k run you will have to type the command below and hit enter

k web


The command will create a server and will an open a listening port on http://localhost:5001
Open your favorite browser and browse the link. It will show you the home page. Let’s see our Tabular Employee list. For that go to http://localhost:5001/EmployeesThere you will see your Tabluar employee list.


So here you go. I’ve shown you how you can both modify, build and run your own Console and ASP.net MVC application with the help of ASP.net vNext.

I hope you enjoyed the post. I’ll come again with interesting posts like this. Till then Happy Coding and Happy New Year!

Friday, September 5, 2014

Providers that make your life easy (Part III)

Chapter – VI
Providers that make your life easy (Part III)

Finally we are ready to talk about Angular.js providers. To be precise there are five types of providers by which you can provide services or information as data [don’t mix up services with Angular’s own service provider] throughout your application. All you have to do is to define a service type in your application once and use that for lifetime anywhere in your app. Service Types are

§  Factory
§  Service
§  Provider
§  Value
§  Constant

Objects are main delivery vehicles to ride through different parts of your application and deliver information or services. Angular service providers are ways of creating service objects in some different ways. 


Factory

First in the list is the factory. As its’ name goes, creating services with it follows factory function pattern. We discussed about factory function as a way of creating an object in first part.

[Read about creating an object using factory function in this link

Nothing new here except for some syntactical sugar on top of the factory function. So if you have an Angular module defined in your app, creating a service using the factory service in that module is something like this,

var app = angular.module('app', []);

app.factory('movieFactory',function() {
    return {
        movies: [
            { title: "Die Hard", role: "Officer John McClane", released: "1988" },
            { title: "Unbreakable", role: "David Dunn", released: "2000" },
            { title: "The Sixth Sense", role: "Dr. Malcolm Crowe", released: "1999" },
            { title: "Armageddon", role: "Harry Stamper", released: "1998" },
            { title: "Twelve Monkeys", role: "James Cole", released: "1995" }
        ]
    };
});


app.controller('movieController', function ($scope, movieFactory) {
    $scope.movies = movieFactory.movies;
});

Up there I’ve got a module named app and we declared a factory service provider in that. Also we have a controller there. In the above example I’ve just made a service provider with the help of angular factory provider. We exposed a movies service with our factory. We simply created a movies array of object literals and returned it.

Now if any controller wants to use our movies service, it will have to inject the movieFactory first into the controller [see the movieController function parameter]. Then we bind the movies acquired from our movieFactory's movies array into our $scope.movies model. That’s it we are good to go, if we write our html as follows,

<div ng-controller="movieController">
        <h1><em>My Favourite Bruce Willis Movies</em></h1>
        <div ng-repeat="movie in movies">
            <div>{{movie.title}}</div>
            <div>{{movie.role}}</div>
            <div>{{movie.released}}</div>
            <hr/>
        </div>
    </div>

We will get an output like,



Service

So factory service provider is a good way of exposing a service. But you may not want to use the factory pattern as a way of exposing a service. Rather you may want to take advantage of the constructor function pattern as a way of creating a service, which is simply called service.

[Read about creating an object with construction function in this link

If you use constructor function pattern your service provider will look like,
var app = angular.module('app', []);

app.service('movieService',function() {
    this.movies = [
        { title: "Die Hard", role: "Officer John McClane", released: "1988" },
        { title: "Unbreakable", role: "David Dunn", released: "2000" },
        { title: "The Sixth Sense", role: "Dr. Malcolm Crowe", released: "1999" },
        { title: "Armageddon", role: "Harry Stamper", released: "1998" },
        { title: "Twelve Monkeys", role: "James Cole", released: "1995" }
    ];
});


app.controller('movieController', function ($scope, movieService) {
    $scope.movies = movieService.movies;
});

Which is just the syntactical sugar over

var app = angular.module('app', []);

function movieService() {
    this.movies = [
        { title: "Die Hard", role: "Officer John McClane", released: "1988" },
        { title: "Unbreakable", role: "David Dunn", released: "2000" },
        { title: "The Sixth Sense", role: "Dr. Malcolm Crowe", released: "1999" },
        { title: "Armageddon", role: "Harry Stamper", released: "1998" },
        { title: "Twelve Monkeys", role: "James Cole", released: "1995" }
    ];
}

app.factory('movieFatory', function () {
    return new movieService();
});

app.controller('movieController', function ($scope, movieFatory) {
    $scope.movies = movieFatory.movies;
});


Provider

Then we’ve a skeleton way of creating a service which is called provider. Angular’s provider exposes a get function by which we can get a reference of our service. Using provider for building the movies service will look like,
var app = angular.module('app', []);

function movieService() {
    this.movies = [
        { title: "Die Hard", role: "Officer John McClane", released: "1988" },
        { title: "Unbreakable", role: "David Dunn", released: "2000" },
        { title: "The Sixth Sense", role: "Dr. Malcolm Crowe", released: "1999" },
        { title: "Armageddon", role: "Harry Stamper", released: "1998" },
        { title: "Twelve Monkeys", role: "James Cole", released: "1995" }
    ];
}

app.provider('movieProvider', function() {
    this.$get = function getMovieService () {
        return new movieService();
    };
});

app.controller('movieController', function ($scope, movieProvider) {
    $scope.movies = movieProvider.movies;
});


Constant & Value

Finally we’ve our two providers. They are value and constant providers. They are almost same except for the fact that constants cannot be changed once it is set and values cannot be injected in any configurations [we will discuss about how to inject constants in Angular configuration later].
So let me finish by giving you two simple examples of these two. For declaring a constant service we will write,

app.value('actorName', 'Bruce Willis');
app.controller('movieController', function ($scope, movieProvider, actorName) {
    $scope.movies = movieProvider.movies;
    $scope.actor = actorName;
});

Here, we’ve created a value service provider which will provide us an actor name in our controller so that we could use it in our view like

<div ng-controller="movieController">
        <h1><em>My Favourite {{actor}} Movies</em></h1>
        <div ng-repeat="movie in movies">
            <div>{{movie.title}}</div>
            <div>{{movie.role}}</div>
            <div>{{movie.released}}</div>
            <hr/>
        </div>
    </div>

And last of all we can create a constant service provider similarly like the value provider service as

app.constant('actorName', 'Bruce Willis');
app.controller('movieController', function ($scope, movieProvider, actorName) {
    $scope.movies = movieProvider.movies;
    $scope.actor = actorName;
});

And the html is same as it’s in the value service provider. Later we will see how we can inject configuration settings in an Angular app through constant service providers.

I guess now you are clear about this hard to catch topics of Angular. I tried to manage simple example of them for you. Hope you like them. See you in the next post with a new topic.