From a1386b9444a7abc3c8d75bff1ad4b14ba31bbd42 Mon Sep 17 00:00:00 2001 From: Rick Anderson Date: Thu, 25 Jun 2015 21:45:00 -0700 Subject: [PATCH] Update MVC with EF article to beta5 --- mvc/tutorials/mvc-with-entity-framework.rst | 44 ++-- .../sample/ContosoBooks.sln | 18 +- .../sample/global.json | 10 +- .../sample/src/ContosoBooks/.bowerrc | 3 + .../Preprocess/RazorPreCompilation.cs | 20 -- .../src/ContosoBooks/ContosoBooks.xproj | 4 +- .../Controllers/BookController.cs | 20 +- .../Controllers/HomeController.cs | 10 +- .../20150521200520_initial.Designer.cs | 71 ------ .../20150624041210_Initial.Designer.cs | 69 ++++++ ...0_initial.cs => 20150624041210_Initial.cs} | 4 +- .../Migrations/BookContextModelSnapshot.cs | 90 ++++---- .../src/ContosoBooks/Models/BookContext.cs | 2 +- .../src/ContosoBooks/Models/SampleData.cs | 46 ++-- .../src/ContosoBooks/Project_Readme.html | 203 ++++++++++++++++++ .../ContosoBooks/Properties/AppSettings.cs | 12 -- .../sample/src/ContosoBooks/Startup.cs | 25 ++- .../src/ContosoBooks/Views/Book/Index.cshtml | 5 +- .../src/ContosoBooks/Views/Home/About.cshtml | 8 +- .../ContosoBooks/Views/Home/Contact.cshtml | 8 +- .../src/ContosoBooks/Views/Home/Index.cshtml | 36 ++-- .../ContosoBooks/Views/Shared/Error.cshtml | 2 +- .../ContosoBooks/Views/Shared/_Layout.cshtml | 35 +-- ...lobalImport.cshtml => _ViewImports.cshtml} | 1 - .../sample/src/ContosoBooks/bower.json | 8 +- .../sample/src/ContosoBooks/config.json | 2 +- .../sample/src/ContosoBooks/gulpfile.js | 57 +++-- .../sample/src/ContosoBooks/hosting.ini | 2 + .../sample/src/ContosoBooks/package.json | 3 + .../sample/src/ContosoBooks/project.json | 34 ++- .../src/ContosoBooks/wwwroot/_references.js | 8 +- .../wwwroot/images/ASP-NET-Banners-02.png | Bin 8423 -> 8616 bytes .../src/ContosoBooks/wwwroot/js/site.js | 1 + .../src/ContosoBooks/wwwroot/web.config | 11 + 34 files changed, 560 insertions(+), 312 deletions(-) create mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/.bowerrc delete mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Compiler/Preprocess/RazorPreCompilation.cs delete mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.Designer.cs create mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.Designer.cs rename mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/{20150521200520_initial.cs => 20150624041210_Initial.cs} (98%) create mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Project_Readme.html delete mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Properties/AppSettings.cs rename mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/{_GlobalImport.cshtml => _ViewImports.cshtml} (64%) create mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/hosting.ini create mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/js/site.js create mode 100644 mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/web.config diff --git a/mvc/tutorials/mvc-with-entity-framework.rst b/mvc/tutorials/mvc-with-entity-framework.rst index 4623e288af..a0dc2b7704 100644 --- a/mvc/tutorials/mvc-with-entity-framework.rst +++ b/mvc/tutorials/mvc-with-entity-framework.rst @@ -1,13 +1,13 @@ Get Started with Entity Framework 7 Code using ASP.NET MVC 6 ============================================================ -By `Mike Wasson`_ +By `Mike Wasson`_ and `Rick Anderson`_ In this tutorial, you’ll create a simple web app using ASP.NET MVC and Entity Framework (EF). The app stores records in a SQL database and supports the basic CRUD operations (create, read, update, delete). .. note:: This tutorial uses Visual Studio 2015. If you are completely new to ASP.NET MVC or Visual Studio, read :doc:`../getting-started/first-mvc-app` first. -The sample app that you'll build manages a list of authors and books. Here is a screenshot of the app: +The sample app that you'll build manages a list of authors and books. Here is a screen shot of the app: .. image:: mvc-with-entity-framework/_static/screenshot1.png @@ -62,7 +62,7 @@ with this: :lines: 37-38 :dedent: 24 -This adds links to a Books page, which we haven’t created yet. (That will come later in tutorial.) +This adds a link to the Books page, which we haven’t created yet. (That will come later in tutorial.) Add Entity Framework -------------------- @@ -73,7 +73,7 @@ Open the *project.json* file. In the dependencies section, add the following lin "dependencies": { ... - "EntityFramework.SqlServer": "7.0.0-beta4" + "EntityFramework.SqlServer": "7.0.0-beta5" }, When you save *project.json*, Visual Studio automatically resolves the new package reference. @@ -92,7 +92,7 @@ We'll define a class for each. First, add a new folder to the project. In Soluti .. image:: mvc-with-entity-framework/_static/add-folder.png -.. note:: You can put model classes anywhere in your project. The "Models" folder is just a convention. +.. note:: You can put model classes anywhere in your project. The *Models* folder is just a convention. Right-click the *Models* folder and select **Add** > **New Item**. In the **Add New Item** dialog, select the **Class** template. In the **Name** edit box, type "Author.cs" and click OK. Replace the boilerplate code with: @@ -147,34 +147,36 @@ Add the following code at the end of the *Configure* method: .. literalinclude:: mvc-with-entity-framework/sample/src/ContosoBooks/Startup.cs :language: c# - :lines: 71 + :lines: 74 :dedent: 12 -Notice in *ConfigureServices* that we call ``Configuration.Get`` to get the database connection string. During development, this setting comes from config.json. When you deploy the app to a production environment, you would store the connection string in an environment variable on the host. If the Configuration API finds an environment variable with the same key, it returns the environment variable instead of the value that is in config.json. +Notice in *ConfigureServices* that we call ``Configuration.Get`` to get the database connection string. During development, this setting comes from the *config.json* file. When you deploy the app to a production environment, you set the connection string in an environment variable on the host. If the Configuration API finds an environment variable with the same key, it returns the environment variable instead of the value that is in *config.json*. Here is the complete *Startup.cs* after these changes: .. literalinclude:: mvc-with-entity-framework/sample/src/ContosoBooks/Startup.cs :language: c# - :emphasize-lines: 1,5,32-37,71 + :emphasize-lines: 1,5,32-37,74 Use data migrations to create the database ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ -Open *project.json*. In the "commands" section, add an entry for ``EntityFramework.Commands``: +Open *project.json*. +- In the "commands" and "dependencies" sections, add an entry for ``EntityFramework.Commands``. .. literalinclude:: mvc-with-entity-framework/sample/src/ContosoBooks/project.json :language: json - :lines: 21-25 - :dedent: 4 - :emphasize-lines: 4 + :emphasize-lines: 18,23 -Open a command prompt in the project directory (/ContosoBooks/src/ContosoBooks) and run the following commands: +Build the app. + +.. dnu restore removed + +Open a command prompt in the project directory (ContosoBooks/src/ContosoBooks) and run the following commands: .. code-block:: none - dnvm use default - dnu restore + dnvm use 1.0.0-beta5 dnx . ef migration add Initial dnx . ef migration apply @@ -182,7 +184,13 @@ The "``add Initial``" command adds code to the project that allows EF to update .. image:: mvc-with-entity-framework/_static/migrations.png -For more information about ``dnvm``, ``dnu``, and ``dnx``, see :ref:`DNX Overview `. +- **dnvm** : The .NET Version Manager, a set of command line utilities that are used to update and configure .NET Runtime. The command ``dnvm use 1.0.0-beta5`` instructs the .NET Version Manager to add the 1.0.0-beta5 ASP.NET 5 runtime to the ``PATH`` environment variable for the current shell. For ASP.NET 5 Beta 5, the following is displayed: + +.. code-block:: none + + Adding C:\\Users\\\\.dnx\\runtimes\\dnx-clr-win-x86.1.0.0-beta5\\bin to process PATH + +- **dnx . ef migration add Initial** : `DNX `_ is the .NET Execution Environment. The ``ef migration apply`` command runs pending migration code. For more information about ``dnvm``, ``dnu``, and ``dnx``, see :ref:`DNX Overview `. Add an index page ----------------- @@ -197,7 +205,7 @@ Replace the boilerplate code with the following: .. literalinclude:: mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/BookController.cs :language: c# - :lines: 1-26,149-150 + :lines: 1-26,161-162 Notice that we don't set any value for ``Logger`` and ``BookContext``. The dependency injection (DI) subsystem automatically sets these properties at runtime. DI also handles the object lifetimes, so you don't need to call ``Dispose``. For more information, see :ref:`Dependency Injection `. @@ -227,7 +235,7 @@ Add the following method to the ``BooksController`` class: This code looks up a book by ID. In the EF query: - The ``Include`` method tells EF to fetch the related ``Author`` entity. -- The ``SingleOrDefault`` method returns a single entity, or ``null`` if none is found. +- The ``SingleOrDefaultAsync`` method returns a single entity, or ``null`` if one is not found. If the EF query returns ``null``, the controller method returns ``HttpNotFound``, which ASP.NET translates into a 404 response. Otherwise, the controller passes *book* to a view, which renders the details page. Let’s add the view now. diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/ContosoBooks.sln b/mvc/tutorials/mvc-with-entity-framework/sample/ContosoBooks.sln index 7a77f387e9..08959039a3 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/ContosoBooks.sln +++ b/mvc/tutorials/mvc-with-entity-framework/sample/ContosoBooks.sln @@ -1,16 +1,16 @@  Microsoft Visual Studio Solution File, Format Version 12.00 # Visual Studio 14 -VisualStudioVersion = 14.0.22823.1 +VisualStudioVersion = 14.0.23019.3 MinimumVisualStudioVersion = 10.0.40219.1 -Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "src", "src", "{AD710406-FC30-4A6B-96BC-AD981A8861D7}" +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "src", "src", "{17564FAC-B6C3-4EB4-AF0B-FE8F00B527BA}" EndProject -Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{F778A387-EA47-489D-95B5-BC339F4801C7}" +Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "Solution Items", "Solution Items", "{9211E070-3BC1-4F10-9F21-7C5141550F42}" ProjectSection(SolutionItems) = preProject global.json = global.json EndProjectSection EndProject -Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "ContosoBooks", "src\ContosoBooks\ContosoBooks.xproj", "{573CDF65-E3B0-4BE5-AEEC-87A50C768B75}" +Project("{8BB2217D-0F2D-49D1-97BC-3654ED321F3B}") = "ContosoBooks", "src\ContosoBooks\ContosoBooks.xproj", "{03F588A7-3C46-492C-8E44-5A45D6F34C46}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -18,15 +18,15 @@ Global Release|Any CPU = Release|Any CPU EndGlobalSection GlobalSection(ProjectConfigurationPlatforms) = postSolution - {573CDF65-E3B0-4BE5-AEEC-87A50C768B75}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {573CDF65-E3B0-4BE5-AEEC-87A50C768B75}.Debug|Any CPU.Build.0 = Debug|Any CPU - {573CDF65-E3B0-4BE5-AEEC-87A50C768B75}.Release|Any CPU.ActiveCfg = Release|Any CPU - {573CDF65-E3B0-4BE5-AEEC-87A50C768B75}.Release|Any CPU.Build.0 = Release|Any CPU + {03F588A7-3C46-492C-8E44-5A45D6F34C46}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {03F588A7-3C46-492C-8E44-5A45D6F34C46}.Debug|Any CPU.Build.0 = Debug|Any CPU + {03F588A7-3C46-492C-8E44-5A45D6F34C46}.Release|Any CPU.ActiveCfg = Release|Any CPU + {03F588A7-3C46-492C-8E44-5A45D6F34C46}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE EndGlobalSection GlobalSection(NestedProjects) = preSolution - {573CDF65-E3B0-4BE5-AEEC-87A50C768B75} = {AD710406-FC30-4A6B-96BC-AD981A8861D7} + {03F588A7-3C46-492C-8E44-5A45D6F34C46} = {17564FAC-B6C3-4EB4-AF0B-FE8F00B527BA} EndGlobalSection EndGlobal diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/global.json b/mvc/tutorials/mvc-with-entity-framework/sample/global.json index e4370fd001..f1ad6f5698 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/global.json +++ b/mvc/tutorials/mvc-with-entity-framework/sample/global.json @@ -1,6 +1,8 @@ { - "projects": [ "src", "test" ], - "sdk": { - "version": "1.0.0-beta4" - } + "projects": [ "src", "test" ], + "sdk": { + "version": "1.0.0-beta5", + "runtime": "clr", + "architecture": "x86" + } } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/.bowerrc b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/.bowerrc new file mode 100644 index 0000000000..6406626abf --- /dev/null +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/.bowerrc @@ -0,0 +1,3 @@ +{ + "directory": "wwwroot/lib" +} diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Compiler/Preprocess/RazorPreCompilation.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Compiler/Preprocess/RazorPreCompilation.cs deleted file mode 100644 index 6e08691bb5..0000000000 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Compiler/Preprocess/RazorPreCompilation.cs +++ /dev/null @@ -1,20 +0,0 @@ -using System; -using System.Collections.Generic; -using System.Linq; -using System.Threading.Tasks; -using Microsoft.AspNet.Mvc; - -namespace ContosoBooks.Compiler.Preprocess -{ - // Uncomment the following class to enable pre-compilation of Razor views. - // Pre-compilation may reduce the time it takes to build and launch your project. - // Please note, in this pre-release of Visual Studio 2015, enabling pre-compilation may cause IntelliSense and build errors in views using Tag Helpers. - - //public class RazorPreCompilation : RazorPreCompileModule - //{ - // public RazorPreCompilation(IServiceProvider provider) : base(provider) - // { - // GenerateSymbols = true; - // } - //} -} diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/ContosoBooks.xproj b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/ContosoBooks.xproj index 5d1eb8e162..d345b1421a 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/ContosoBooks.xproj +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/ContosoBooks.xproj @@ -6,14 +6,14 @@ - 573cdf65-e3b0-4be5-aeec-87a50c768b75 + 03f588a7-3c46-492c-8e44-5a45d6f34c46 ContosoBooks ..\..\artifacts\obj\$(MSBuildProjectName) ..\..\artifacts\bin\$(MSBuildProjectName)\ 2.0 - 18289 + 8816 \ No newline at end of file diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/BookController.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/BookController.cs index 25bc7144e6..4258b53982 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/BookController.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/BookController.cs @@ -21,8 +21,8 @@ namespace ContosoBooks.Controllers public IActionResult Index() { - var books = BookContext.Books.Include(b => b.Author); - return View(books); + var books = BookContext.Books.Include(b => b.Author); + return View(books); } public async Task Details(int id) @@ -40,7 +40,7 @@ namespace ContosoBooks.Controllers public ActionResult Create() { - ViewBag.Items = GetAuthorsListItems(); + ViewBag.Items = GetAuthorsListItems(); return View(); } @@ -146,5 +146,17 @@ namespace ContosoBooks.Controllers Selected = author.AuthorID == selected }); } + + private IEnumerable GetAuthorsListItems2246(int selected = -1) + { + return BookContext.Authors + .OrderBy(author => author.LastName) + .Select(author => new SelectListItem + { + Text = String.Format("{0}, {1}", author.LastName, author.FirstMidName), + Value = author.AuthorID.ToString(), + Selected = author.AuthorID == selected + }); + } } -} +} \ No newline at end of file diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/HomeController.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/HomeController.cs index ca1fabbffb..9683e932a3 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/HomeController.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Controllers/HomeController.cs @@ -1,4 +1,8 @@ -using Microsoft.AspNet.Mvc; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Threading.Tasks; +using Microsoft.AspNet.Mvc; namespace ContosoBooks.Controllers { @@ -11,14 +15,14 @@ namespace ContosoBooks.Controllers public IActionResult About() { - ViewBag.Message = "Your application description page."; + ViewData["Message"] = "Your application description page."; return View(); } public IActionResult Contact() { - ViewBag.Message = "Your contact page."; + ViewData["Message"] = "Your contact page."; return View(); } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.Designer.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.Designer.cs deleted file mode 100644 index e167fffde5..0000000000 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.Designer.cs +++ /dev/null @@ -1,71 +0,0 @@ -using System; -using Microsoft.Data.Entity; -using Microsoft.Data.Entity.Metadata; -using Microsoft.Data.Entity.Metadata.Builders; -using Microsoft.Data.Entity.Relational.Migrations.Infrastructure; -using ContosoBooks.Models; - -namespace ContosoBooks.Migrations -{ - [ContextType(typeof(BookContext))] - partial class initial - { - public override string Id - { - get { return "20150521200520_initial"; } - } - - public override string ProductVersion - { - get { return "7.0.0-beta4-12943"; } - } - - public override IModel Target - { - get - { - var builder = new BasicModelBuilder() - .Annotation("SqlServer:ValueGeneration", "Sequence"); - - builder.Entity("ContosoBooks.Models.Author", b => - { - b.Property("AuthorID") - .GenerateValueOnAdd() - .Annotation("OriginalValueIndex", 0) - .Annotation("SqlServer:ValueGeneration", "Default"); - b.Property("FirstMidName") - .Annotation("OriginalValueIndex", 1); - b.Property("LastName") - .Annotation("OriginalValueIndex", 2); - b.Key("AuthorID"); - }); - - builder.Entity("ContosoBooks.Models.Book", b => - { - b.Property("AuthorID") - .Annotation("OriginalValueIndex", 0); - b.Property("BookID") - .GenerateValueOnAdd() - .Annotation("OriginalValueIndex", 1) - .Annotation("SqlServer:ValueGeneration", "Default"); - b.Property("Genre") - .Annotation("OriginalValueIndex", 2); - b.Property("Price") - .Annotation("OriginalValueIndex", 3); - b.Property("Title") - .Annotation("OriginalValueIndex", 4); - b.Property("Year") - .Annotation("OriginalValueIndex", 5); - b.Key("BookID"); - }); - - builder.Entity("ContosoBooks.Models.Book", b => - { - b.ForeignKey("ContosoBooks.Models.Author", "AuthorID"); - }); - - return builder.Model; - } - } - } -} diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.Designer.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.Designer.cs new file mode 100644 index 0000000000..3936b4b89b --- /dev/null +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.Designer.cs @@ -0,0 +1,69 @@ +using System; +using Microsoft.Data.Entity; +using Microsoft.Data.Entity.Metadata; +using Microsoft.Data.Entity.Relational.Migrations.Infrastructure; +using ContosoBooks.Models; + +namespace ContosoBooks.Migrations +{ + [ContextType(typeof(BookContext))] + partial class Initial + { + public override string Id + { + get { return "20150624041210_Initial"; } + } + + public override string ProductVersion + { + get { return "7.0.0-beta5-13518"; } + } + + public override void BuildTargetModel(ModelBuilder builder) + { + builder + .Annotation("SqlServer:DefaultSequenceName", "DefaultSequence") + .Annotation("SqlServer:Sequence:.DefaultSequence", "'DefaultSequence', '', '1', '10', '', '', 'Int64', 'False'") + .Annotation("SqlServer:ValueGeneration", "Sequence"); + + builder.Entity("ContosoBooks.Models.Author", b => + { + b.Property("AuthorID") + .GenerateValueOnAdd() + .StoreGeneratedPattern(StoreGeneratedPattern.Identity); + + b.Property("FirstMidName"); + + b.Property("LastName"); + + b.Key("AuthorID"); + }); + + builder.Entity("ContosoBooks.Models.Book", b => + { + b.Property("BookID") + .GenerateValueOnAdd() + .StoreGeneratedPattern(StoreGeneratedPattern.Identity); + + b.Property("AuthorID"); + + b.Property("Genre"); + + b.Property("Price"); + + b.Property("Title"); + + b.Property("Year"); + + b.Key("BookID"); + }); + + builder.Entity("ContosoBooks.Models.Book", b => + { + b.Reference("ContosoBooks.Models.Author") + .InverseCollection() + .ForeignKey("AuthorID"); + }); + } + } +} diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.cs similarity index 98% rename from mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.cs rename to mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.cs index 54dc2f76f5..d04c33bb59 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150521200520_initial.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/20150624041210_Initial.cs @@ -5,7 +5,7 @@ using Microsoft.Data.Entity.Relational.Migrations.Operations; namespace ContosoBooks.Migrations { - public partial class initial : Migration + public partial class Initial : Migration { public override void Up(MigrationBuilder migration) { @@ -30,8 +30,8 @@ namespace ContosoBooks.Migrations name: "Book", columns: table => new { - AuthorID = table.Column(type: "int", nullable: false), BookID = table.Column(type: "int", nullable: false), + AuthorID = table.Column(type: "int", nullable: false), Genre = table.Column(type: "nvarchar(max)", nullable: true), Price = table.Column(type: "decimal(18, 2)", nullable: false), Title = table.Column(type: "nvarchar(max)", nullable: true), diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/BookContextModelSnapshot.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/BookContextModelSnapshot.cs index af73930ada..20fcb843ae 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/BookContextModelSnapshot.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Migrations/BookContextModelSnapshot.cs @@ -1,7 +1,6 @@ using System; using Microsoft.Data.Entity; using Microsoft.Data.Entity.Metadata; -using Microsoft.Data.Entity.Metadata.Builders; using Microsoft.Data.Entity.Relational.Migrations.Infrastructure; using ContosoBooks.Models; @@ -10,52 +9,51 @@ namespace ContosoBooks.Migrations [ContextType(typeof(BookContext))] partial class BookContextModelSnapshot : ModelSnapshot { - public override IModel Model + public override void BuildModel(ModelBuilder builder) { - get - { - var builder = new BasicModelBuilder() - .Annotation("SqlServer:ValueGeneration", "Sequence"); - - builder.Entity("ContosoBooks.Models.Author", b => - { - b.Property("AuthorID") - .GenerateValueOnAdd() - .Annotation("OriginalValueIndex", 0) - .Annotation("SqlServer:ValueGeneration", "Default"); - b.Property("FirstMidName") - .Annotation("OriginalValueIndex", 1); - b.Property("LastName") - .Annotation("OriginalValueIndex", 2); - b.Key("AuthorID"); - }); - - builder.Entity("ContosoBooks.Models.Book", b => - { - b.Property("AuthorID") - .Annotation("OriginalValueIndex", 0); - b.Property("BookID") - .GenerateValueOnAdd() - .Annotation("OriginalValueIndex", 1) - .Annotation("SqlServer:ValueGeneration", "Default"); - b.Property("Genre") - .Annotation("OriginalValueIndex", 2); - b.Property("Price") - .Annotation("OriginalValueIndex", 3); - b.Property("Title") - .Annotation("OriginalValueIndex", 4); - b.Property("Year") - .Annotation("OriginalValueIndex", 5); - b.Key("BookID"); - }); - - builder.Entity("ContosoBooks.Models.Book", b => - { - b.ForeignKey("ContosoBooks.Models.Author", "AuthorID"); - }); - - return builder.Model; - } + builder + .Annotation("SqlServer:DefaultSequenceName", "DefaultSequence") + .Annotation("SqlServer:Sequence:.DefaultSequence", "'DefaultSequence', '', '1', '10', '', '', 'Int64', 'False'") + .Annotation("SqlServer:ValueGeneration", "Sequence"); + + builder.Entity("ContosoBooks.Models.Author", b => + { + b.Property("AuthorID") + .GenerateValueOnAdd() + .StoreGeneratedPattern(StoreGeneratedPattern.Identity); + + b.Property("FirstMidName"); + + b.Property("LastName"); + + b.Key("AuthorID"); + }); + + builder.Entity("ContosoBooks.Models.Book", b => + { + b.Property("BookID") + .GenerateValueOnAdd() + .StoreGeneratedPattern(StoreGeneratedPattern.Identity); + + b.Property("AuthorID"); + + b.Property("Genre"); + + b.Property("Price"); + + b.Property("Title"); + + b.Property("Year"); + + b.Key("BookID"); + }); + + builder.Entity("ContosoBooks.Models.Book", b => + { + b.Reference("ContosoBooks.Models.Author") + .InverseCollection() + .ForeignKey("AuthorID"); + }); } } } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/BookContext.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/BookContext.cs index 148c99f926..aa39630f16 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/BookContext.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/BookContext.cs @@ -7,4 +7,4 @@ namespace ContosoBooks.Models public DbSet Authors { get; set; } public DbSet Books { get; set; } } -} +} \ No newline at end of file diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/SampleData.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/SampleData.cs index 3f1bbf04fe..7e102cfe95 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/SampleData.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Models/SampleData.cs @@ -22,22 +22,42 @@ namespace ContosoBooks.Models new Author { LastName = "Cervantes", FirstMidName = "Miguel" }).Entity; context.Books.AddRange( - new Book() { - Title = "Pride and Prejudice", Year = 1813, Author = austen, - Price = 9.99M, Genre = "Comedy of manners" }, - new Book() { - Title = "Northanger Abbey", Year = 1817, Author = austen, - Price = 12.95M, Genre = "Gothic parody" }, - new Book() { - Title = "David Copperfield", Year = 1850, Author = dickens, - Price = 15, Genre = "Bildungsroman" }, - new Book() { - Title = "Don Quixote", Year = 1617, Author = cervantes, - Price = 8.95M, Genre = "Picaresque" } + new Book() + { + Title = "Pride and Prejudice", + Year = 1813, + Author = austen, + Price = 9.99M, + Genre = "Comedy of manners" + }, + new Book() + { + Title = "Northanger Abbey", + Year = 1817, + Author = austen, + Price = 12.95M, + Genre = "Gothic parody" + }, + new Book() + { + Title = "David Copperfield", + Year = 1850, + Author = dickens, + Price = 15, + Genre = "Bildungsroman" + }, + new Book() + { + Title = "Don Quixote", + Year = 1617, + Author = cervantes, + Price = 8.95M, + Genre = "Picaresque" + } ); context.SaveChanges(); } } } } -} +} \ No newline at end of file diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Project_Readme.html b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Project_Readme.html new file mode 100644 index 0000000000..bc23184530 --- /dev/null +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Project_Readme.html @@ -0,0 +1,203 @@ + + + + + Welcome to ASP.NET 5 + + + + + + + + + + diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Properties/AppSettings.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Properties/AppSettings.cs deleted file mode 100644 index be4c006971..0000000000 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Properties/AppSettings.cs +++ /dev/null @@ -1,12 +0,0 @@ -using System; -using System.Collections.Generic; -using System.Linq; -using System.Threading.Tasks; - -namespace ContosoBooks -{ - public class AppSettings - { - public string SiteTitle { get; set; } - } -} diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Startup.cs b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Startup.cs index b0df9c5d6a..f71fc042c4 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Startup.cs +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Startup.cs @@ -3,20 +3,22 @@ using Microsoft.AspNet.Builder; using Microsoft.AspNet.Diagnostics; using Microsoft.AspNet.Hosting; using Microsoft.Data.Entity; -using Microsoft.Framework.ConfigurationModel; +using Microsoft.Framework.Configuration; using Microsoft.Framework.DependencyInjection; using Microsoft.Framework.Logging; +using Microsoft.Framework.Runtime; namespace ContosoBooks { public class Startup { - public Startup(IHostingEnvironment env) + public Startup(IHostingEnvironment env, IApplicationEnvironment appEnv) { // Setup configuration sources. - Configuration = new Configuration() + var builder = new ConfigurationBuilder(appEnv.ApplicationBasePath) .AddJsonFile("config.json") .AddEnvironmentVariables(); + Configuration = builder.Build(); } public IConfiguration Configuration { get; set; } @@ -24,8 +26,6 @@ namespace ContosoBooks // This method gets called by the runtime. public void ConfigureServices(IServiceCollection services) { - services.Configure(Configuration.GetSubKey("AppSettings")); - // Add MVC services to the services container. services.AddMvc(); @@ -38,15 +38,15 @@ namespace ContosoBooks } // Configure is called after ConfigureServices is called. - public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerfactory) + public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory) { + loggerFactory.MinimumLevel = LogLevel.Information; + loggerFactory.AddConsole(); + // Configure the HTTP request pipeline. - // Add the console logger. - loggerfactory.AddConsole(minLevel: LogLevel.Verbose); - // Add the following to the request pipeline only in development environment. - if (env.IsEnvironment("Development")) + if (env.IsDevelopment()) { app.UseBrowserLink(); app.UseErrorPage(ErrorPageOptions.ShowAll); @@ -66,7 +66,10 @@ namespace ContosoBooks { routes.MapRoute( name: "default", - template: "{controller=Home}/{action=Index}/{id?}"); + template: "{controller=Book}/{action=Index}/{id?}"); + + // Uncomment the following line to add a route for porting Web API 2 controllers. + // routes.MapWebApiRoute("DefaultApi", "api/{controller}/{id?}"); }); SampleData.Initialize(app.ApplicationServices); } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Book/Index.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Book/Index.cshtml index bc52536b3c..adf66a010d 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Book/Index.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Book/Index.cshtml @@ -1,6 +1,6 @@ @model IEnumerable @{ - ViewBag.Title = "Books"; + ViewBag.Title = "Books"; }

Create New Book @@ -32,5 +32,4 @@ } - - + \ No newline at end of file diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/About.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/About.cshtml index 4b2d9e8440..9b9f0c498b 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/About.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/About.cshtml @@ -1,7 +1,9 @@ @{ - ViewBag.Title = "About"; + ViewData["Title"] = "About"; } -

@ViewBag.Title.

-

@ViewBag.Message

+

@ViewData["Title"].

+

@ViewData["Message"]

+ +Test

Use this area to provide additional information.

diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Contact.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Contact.cshtml index 01436993cf..15c12c6d12 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Contact.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Contact.cshtml @@ -1,8 +1,8 @@ @{ - ViewBag.Title = "Contact"; + ViewData["Title"] = "Contact"; } -

@ViewBag.Title.

-

@ViewBag.Message

+

@ViewData["Title"].

+

@ViewData["Message"]

One Microsoft Way
@@ -12,6 +12,6 @@
- Support: Support@example.com
+ Support: Support@example.com
Marketing: Marketing@example.com
diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Index.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Index.cshtml index 84847d7769..c03bc6f0cf 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Index.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Home/Index.cshtml @@ -1,5 +1,5 @@ @{ - ViewBag.Title = "Home Page"; + ViewData["Title"] = "Home Page"; }
-
-

This application consists of:

+
+

Application uses

    -
  • Sample pages showing basic nav
  • +
  • Sample pages using ASP.NET 5 (MVC 6)
  • +
  • Gulp and Bower for managing client-side resources
  • Theming using Bootstrap
-
+ + - diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/Error.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/Error.cshtml index 26ebcf0110..4852442680 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/Error.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/Error.cshtml @@ -1,5 +1,5 @@ @{ - ViewBag.Title = "Error"; + ViewData["Title"] = "Error"; }

Error.

diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/_Layout.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/_Layout.cshtml index 95f472661c..eb44d9427c 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/_Layout.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/Shared/_Layout.cshtml @@ -1,14 +1,13 @@ -@inject IOptions AppSettings - + - @ViewBag.Title - @AppSettings.Options.SiteTitle + @ViewData["Title"] - ContosoBooks - - + + @@ -18,7 +17,7 @@ - + @@ -30,13 +29,14 @@ - @AppSettings.Options.SiteTitle + ContosoBooks
@@ -45,33 +45,34 @@ @RenderBody()
-

© 2015 - @AppSettings.Options.SiteTitle

+

© 2015 - ContosoBooks

- - + + - + - + @RenderSection("scripts", required: false) diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/_GlobalImport.cshtml b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/_ViewImports.cshtml similarity index 64% rename from mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/_GlobalImport.cshtml rename to mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/_ViewImports.cshtml index 27d56c5c77..9da09fefa2 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/_GlobalImport.cshtml +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/Views/_ViewImports.cshtml @@ -1,3 +1,2 @@ @using ContosoBooks -@using Microsoft.Framework.OptionsModel @addTagHelper "*, Microsoft.AspNet.Mvc.TagHelpers" diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/bower.json b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/bower.json index 599b015f96..51002ed97b 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/bower.json +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/bower.json @@ -3,10 +3,10 @@ "private": true, "dependencies": { "bootstrap": "3.0.0", - "jquery": "1.10.2", - "jquery-validation": "1.11.1", - "jquery-validation-unobtrusive": "3.2.2", + "bootstrap-touch-carousel": "0.8.0", "hammer.js": "2.0.4", - "bootstrap-touch-carousel": "0.8.0" + "jquery": "2.1.4", + "jquery-validation": "1.11.1", + "jquery-validation-unobtrusive": "3.2.2" } } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/config.json b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/config.json index fc2d1d1920..18bf2120c3 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/config.json +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/config.json @@ -5,4 +5,4 @@ "Data": { "ConnectionString": "Server=(localdb)\\MSSQLLocalDB;Database=ContosoBooks;Trusted_Connection=True;MultipleActiveResultSets=true" } -} +} \ No newline at end of file diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/gulpfile.js b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/gulpfile.js index 4c1e6c7bc9..684c5ac2cf 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/gulpfile.js +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/gulpfile.js @@ -1,32 +1,45 @@ /// var gulp = require("gulp"), - rimraf = require("rimraf"), - fs = require("fs"); - -eval("var project = " + fs.readFileSync("./project.json")); + rimraf = require("rimraf"), + concat = require("gulp-concat"), + cssmin = require("gulp-cssmin"), + uglify = require("gulp-uglify"), + project = require("./project.json"); var paths = { - bower: "./bower_components/", - lib: "./" + project.webroot + "/lib/" + webroot: "./" + project.webroot + "/" }; -gulp.task("clean", function (cb) { - rimraf(paths.lib, cb); +paths.js = paths.webroot + "js/**/*.js"; +paths.minJs = paths.webroot + "js/**/*.min.js"; +paths.css = paths.webroot + "css/**/*.css"; +paths.minCss = paths.webroot + "css/**/*.min.css"; +paths.concatJsDest = paths.webroot + "js/site.min.js"; +paths.concatCssDest = paths.webroot + "css/site.min.css"; + +gulp.task("clean:js", function (cb) { + rimraf(paths.concatJsDest, cb); }); -gulp.task("copy", ["clean"], function () { - var bower = { - "bootstrap": "bootstrap/dist/**/*.{js,map,css,ttf,svg,woff,eot}", - "bootstrap-touch-carousel": "bootstrap-touch-carousel/dist/**/*.{js,css}", - "hammer.js": "hammer.js/hammer*.{js,map}", - "jquery": "jquery/jquery*.{js,map}", - "jquery-validation": "jquery-validation/jquery.validate.js", - "jquery-validation-unobtrusive": "jquery-validation-unobtrusive/jquery.validate.unobtrusive.js" - } - - for (var destinationDir in bower) { - gulp.src(paths.bower + bower[destinationDir]) - .pipe(gulp.dest(paths.lib + destinationDir)); - } +gulp.task("clean:css", function (cb) { + rimraf(paths.concatCssDest, cb); }); + +gulp.task("clean", ["clean:js", "clean:css"]); + +gulp.task("min:js", function () { + gulp.src([paths.js, "!" + paths.minJs], { base: "." }) + .pipe(concat(paths.concatJsDest)) + .pipe(uglify()) + .pipe(gulp.dest(".")); +}); + +gulp.task("min:css", function () { + gulp.src([paths.css, "!" + paths.minCss]) + .pipe(concat(paths.concatCssDest)) + .pipe(cssmin()) + .pipe(gulp.dest(".")); +}); + +gulp.task("min", ["min:js", "min:css"]); diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/hosting.ini b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/hosting.ini new file mode 100644 index 0000000000..126132d474 --- /dev/null +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/hosting.ini @@ -0,0 +1,2 @@ +server=Microsoft.AspNet.Server.WebListener +server.urls=http://localhost:5000 diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/package.json b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/package.json index 838ba76198..d4d71a996e 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/package.json +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/package.json @@ -3,6 +3,9 @@ "version": "0.0.0", "devDependencies": { "gulp": "3.8.11", + "gulp-concat": "2.5.2", + "gulp-cssmin": "0.1.7", + "gulp-uglify": "1.2.0", "rimraf": "2.2.8" } } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/project.json b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/project.json index ce683d455a..44c1bd9306 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/project.json +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/project.json @@ -3,26 +3,25 @@ "version": "1.0.0-*", "dependencies": { - "Microsoft.AspNet.Diagnostics": "1.0.0-beta4", - "Microsoft.AspNet.Mvc": "6.0.0-beta4" , - "Microsoft.AspNet.Mvc.TagHelpers": "6.0.0-beta4", - "Microsoft.AspNet.Server.IIS": "1.0.0-beta4", - "Microsoft.AspNet.Server.WebListener": "1.0.0-beta4", - "Microsoft.AspNet.StaticFiles": "1.0.0-beta4", - "Microsoft.AspNet.Tooling.Razor": "1.0.0-beta4", - "Microsoft.Framework.ConfigurationModel.Json": "1.0.0-beta4", - "Microsoft.Framework.CodeGenerators.Mvc": "1.0.0-beta4", - "Microsoft.Framework.Logging": "1.0.0-beta4", - "Microsoft.Framework.Logging.Console": "1.0.0-beta4", - "Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0-beta4", - "EntityFramework.SqlServer": "7.0.0-beta4" + "Microsoft.AspNet.Diagnostics": "1.0.0-beta5", + "Microsoft.AspNet.Mvc": "6.0.0-beta5", + "Microsoft.AspNet.Mvc.TagHelpers": "6.0.0-beta5", + "Microsoft.AspNet.Server.IIS": "1.0.0-beta5", + "Microsoft.AspNet.Server.WebListener": "1.0.0-beta5", + "Microsoft.AspNet.StaticFiles": "1.0.0-beta5", + "Microsoft.AspNet.Tooling.Razor": "1.0.0-beta5", + "Microsoft.Framework.Configuration.Json": "1.0.0-beta5", + "Microsoft.Framework.Logging": "1.0.0-beta5", + "Microsoft.Framework.Logging.Console": "1.0.0-beta5", + "Microsoft.VisualStudio.Web.BrowserLink.Loader": "14.0.0-beta5", + "EntityFramework.SqlServer": "7.0.0-beta5", + "EntityFramework.Commands": "7.0.0-beta5" }, "commands": { - "web": "Microsoft.AspNet.Hosting --server Microsoft.AspNet.Server.WebListener --server.urls http://localhost:5000", - "gen": "Microsoft.Framework.CodeGeneration", + "web": "Microsoft.AspNet.Hosting --config hosting.ini", "ef": "EntityFramework.Commands" - }, + }, "frameworks": { "dnx451": { }, @@ -42,7 +41,6 @@ "**.vspscc" ], "scripts": { - "postrestore": [ "npm install", "bower install" ], - "prepare": [ "gulp copy" ] + "prepublish": [ "npm install", "bower install", "gulp clean", "gulp min" ] } } diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/_references.js b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/_references.js index 4e6ad34f16..ad7d373bb5 100644 --- a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/_references.js +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/_references.js @@ -1,9 +1,3 @@ /// /// -/// -/// -/// -/// -/// -/// -/// +/// diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/images/ASP-NET-Banners-02.png b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/images/ASP-NET-Banners-02.png index 2f456c0bb828b910ceacacf5979f5b17544e3c5d..16c37fc55f207461c405d006868c8373e6c7761f 100644 GIT binary patch delta 7246 zcmZ8`XHb({v^MHNtbm3hMXHKQ6+~)4j}%29A|;dniZtl~>E%^9f^;Ml=|?ye2?QZ@ zLXqA=L!^dv`Z4a=YJl zy>WZi6AWMGk>=pwApa3R8FT`1M;t%^5~_$dSD&6!%D`uhqC|CkbP*pVq>qm@5&w#w zL;M!I0?2)lp`G0Rmx&N$@YpT-cttk8h~?l=vDS!)V3weFqJGXE?8Ude_3M3b5h|mw zA}$3z3*}8da%wwZw9%^EZ%)f}M!|m#W=P{IGXXYvA4@CT1Q+=Q{tCH!yGULVCJDP! zjP5x6kK)(}wCrGc8jE19Y@Fvd{}aUuhMEJwe!kucQEP8f$8iRd6svXjl609}xn%{q zpc)U-Z#ucdz)n(O1zW8fzj)Ps`&CuC<+BMxQ)0;li=Fc|lu06v`S6I*1~*^XqqR=` z5s-w{lv##1wc2{wpym(Owy;`RVm6zXv@>VHs1LiU0kK^@=RMRa+g}H!_F6$vv|r82<}T^CkC+20NS9^p zjicERxvSO^u$rY>#WgfuaIraTUEV%Mu1yVK?elaj{@gcdJY(Toc&Ofw>zQ0QSo8O6 z^ufppU;p3GE{^XqhCUNpckn>`z3&0*8-XfiB844Om7atN&8Pf_is9+k}{RJ{5 zQ{qWS+aA2Hg8m$nQuN0?h-h$2uo@P*ntu?@j`8c&;e9_l8C6&;fVO>H&Ev6^q%OTC zCsVWGyM>>zg*~sf$%=q@2SwjQyZ5ku@5hXKdZ@D<@ijBzgQHqU3m+|Y>wzaPYMQuQ z!PY>yC-Fxon>q|6m+ZFvnpm7mGW~?M%sOQ@3313{Eh7yxE2a8i`*WM88x)Byt$Rs1 z5Ti~X*k`D38~+_ZM1Am z`bdQ#z3>DUKiCk`=GV6{owBw4@<8(3 z9C$94vx~p=SMH{oZ^WSkYswsl#97{Y>gO)uYWw`BP^y(Tw8ze*zKC$( zNa-A+XgYCie2J}|gb45i9Eb1Hs2H1vyMfDV;vm*(sH->%B6K$SoEWf<`bc#NLC zYgsJe9~cGK2kLOi^@f~jYLa4n%gQk(2O-%_*8NR3iy>4>54$07!Whi&766b^h1y3? zWI;?jBKL^urHpF3FnZ&WLevov#K5R~(!H{%3xd81d4V1EQ}>FYUJ!5m)b3*+;8g|J zqXT-N< z{ZNeMK~@3zZz==zivBXXnERJ-n}$OYU6n%P9aBmYxKE{ll~);GD2pSfNeY3FvfNBZ zozcwsGL7BaQE6>5o2W=DPYE)Zw$(v7s>;vYCuBlRY56>8?)0@*&+#0nHJL^P4BO?*BZbFxUEef-(&y-Tab%NZ28<&^|7C z7iq;HvO8rES-@b?@F~NimFk7V-FMo>cWtSS)8TL*$2O)FO)e=o`KmfS8-=+h)8Pfv zZ#X@__Id@ryVaxhXTm7YmlOxhH?LT)9M(zR0=#C>#XF2_+FbBXFuB?xxV}g^{8jPk z6kXW--DTb`engA+7EgVqxvI^)xF@~43ckwlve0(1jyIAz{DKszuY7KVFKH|i$fJED zRpy1I;eRc&N^9+{qkJq*x$tN7xHe2bH2wcS}Dvp~aEAkIkAV1s`u$qmK z-G;!(YMZdNRq?@*@qj|f?H32;7`cTC%I6$+*?!&n7?xxn$sasv8p7gS993r)zQ3SkNQ0Y=CT5_k{%3?<)7Uc`O zt+Ey)vZE#Tw1$iHMfPPj&zOkHrN*|~WV(v3*%+-K%73AsX)NG3^8fX`>RO6)8o%L@ zfB^quQ(d*yH!R4Pn6R_cyEK=V<>DxV%y`&O)TSybY-y2UAF3ca(SCv7N%ymq`BV$3 zo7F3Q7lGPg{JGkN3ay~_2u2*z;eu#8OyQ}zupjQW(cqz5JNj)cnq94$>q6QVOtF5w z!<&^`Tyrq&$lct*Ry|(as%uKJE zRyt7ugu+IomrzifA$lZ|r1wt|08l*NjWPs`Rdkr%BlDglnQb*JT68*i-A%6~;J5^# z4&w_~F7};4fYmN~P#B#F*H3xKcdnphOFgJfD~#I%%NI!6N!a0ghDwv%?th_oLq&hZ zaRwG#(70bCTSLw2U)z$UuJ@<$Xjx6+m}o zcsf0>(Rrxtk=q9@d?H5r?;S#HORV5DS~KrcWsDcVJi#V!yU7*d7NVI_DkSa;_9E>HU z`ivSI7^UlqSwD&Q8+mvu77LP-O^)Mg5nyOK9i^F`nK66E{9~joj6Wot1uG*qJl?sX zGH3SU&V!4&hZ=f&G!jZp6!FjeL*C*G&kj4Q&I)bbIhqTKe4kfZRJjb?*vKodLZ9

#m5z~mOC0RsaMHiK4ZI(S8c{-=f2}|T5=-BJIy^ZnSQE7}H^A<+jryO5Uvyk24 z`BY2MbZMF&UbLxWz zMZ8@|7L^TS`)72zN!`$ocK)Xu+C*V?jozg1^vM84z`Ctln~qKJ`S@@cgc8`&FZCd9 zFLH@Afz3XNmY-KDj2NDo-a0Xmcc5xc0&|E4Tx`O>+wMRhftX-Tr_*BUyeMuTPi5hCkT}P{iOXg)##-aS^*3_SG3tL- z(D+*et(l%we_+2%)c0v5{eXsEgMFxXu`c`YEm$E#Wq@LQ&C?L4-;)!Oa)R3SxW zF6rmYsZP@;n%wI>IPa@3?Cg~Ooy}DeUZe^i8W*boFHDF$&p89-vQdbCCd+qPU}ok!^_D`h6!rGS;T*5SARusXJ_*3+YTKv^HuzfE*W_0@ zezgSwILAZ<=U=8eu2u^9HU^cumW~%K=n(~25V>fk*?!lB~o>yAsz#o&NlksO~7#mhoph)|aSMoL2!%y=5BO8{0 zp=qI2r#uplG82B2yY*RLH{ClUKe6l%NN59q_-`Oe1Nj0PUAvcPHTjWvIH1+LIcH}h zbYWF~PHR3kyW0N*$>SiQP%rm6c`PlxRSnu6&ko(+U>Y{7pbH7R0qd=oPzs0ivs_t` z&Wv?gn| zq1^r*f%1QU^~z$Ut7J*QzC{n+i2cD-lh*Y3W>??heR#t+o38B0j0g(^e?Qc}(z>>~ z)+koX#($ZcD}wwoydN05+`*$q1vW`?5G;miLB z?Wt>@xfA@*BVOc^25Q6zID20Et!M969VI}l-6P|Vglf{MXU(=|R-#ye00WY_V&05K zkFNpiyQbH!gd;puMrn;SUmkrrNO%-YDLY3CRc;!&g!)vPJ~JrKb}@vATLzAVH4AU% zRlHpAK%j9AY_Qrnv9O-d&cENXW$U4y>$Ncs=@HL zQ!KiCPPo@3*wHi{C;)%?LX8ur$@RCFM_4x4=9pXk`LEIn9DKF{TTEZejFhM5)mKwE z@edBh!W?!7z>oFlD7r{62Smc&@3*_WWR8x>W3ei=!Rjd3rdDbiUSd9-RsoW9tXr z+E6_1G~?N@*O4d%e`98+@;zvBHYNJBSUqf}L^U?ruXm*{47X+Fi`jbsB*=#o%=zls z*NMOT99NLFdh0__()NyVT&@b0i3br)nb1IT@6YZ}efLroVj|x83E(yrEnhNtUaQYdowrjiT9FE4K)n~#wLd@7M!H#(_tP4RZhp^X&5!~^o!5?Wbt zI{Icsj9`z()li_lLdRqwXZ@JX8G%q)=W5vX?C)Np{e6^?c@UH*!QO0+JXsnvCafMx zKLDa;DjyL#dhV&2!@SqtPZmI3K^Nbv*RmxsRFln6o5_BVOw3^E<955eQ{Al;9x%Z2 zf|x6IboFpahB>Wx;acR9)O+CbOtoJ~6NTV3x6JDv2V!Ng^^xr3Um41M^spjPPKnsE zo*g1_egq?OToI+lCqBBFQY?sIenZS)XYPW~-?qqJwrtRIZu69rl=*sGOmOZt6={sY zhgP(-+#_epsd0TW*7lgmvh`j7?#r6jjQ@}r4n@?C#0M=*Hi|4BJk{onSXmu+kyal1 zekg<|a2oa@YhA~LN`CAOo+sJqCn#~fOf1a{lwnxf__&XoRW*Rn}t?Nb18mWni%(q@GKh%`w2UW+)M-5wf+g zo&Qq=6x*styWCMR#~WK57JR4uW6b=?-qE~}G(pdTD0)=hoSCd6d)0wqJQ}m~xy;Jv zIAizx1L9H}UBQ?OyA6cACXi4*TcW2y8rqQD$=pmjKOq2pB!$XCsh%CmX4^p_$w!wr z5h)eooj3H;p>)}803w?Hr~~_?5>}1*G<5Vv-mi|gmp7UcUvg&arP?HDoE_N5A6MLASpvF5oKU8&q`K>Vpze5>#$4__2K6 z=v}(Bf4lkvql2YVf^3X%_D4yMRN)NNc&c>dv`zg*==vw|CTCi#8o*B*tqnjit6XKdic_mx zGCbNVZe*Ly{abmHj=n})TrPsH`2YD5te64-%}4FC64q1blZjL%7VOyqljZ(obZr=!R{9k$@3i> zg{L5eqs^cpkZO**eT@ttmKAW9Opv=8yaMDTefrr&^%-c;hr~X?bh91ieAT364a|3Q zH+`A7zGiK273s+*a6Sz61+Cp|Z-Yl(k69AAZ@5DqWJS zqMk?u;-!`8Ev=C|whl{d2B@cXo(GCB;96l8Jc)4@e7sVlZ10>X7tWtm+bFe-k6rXN zh`ZDa-99TI85EARt?qq~$ZjxxddaA@#U|lgB#h8@JaIU@Aw^psGj*WC%dKiBad|-S z6mgsw?Sw{4Gq>m0Lml+tSy`d!2pb(7#_L8GKbI}{%Y+6ChJz6xInAf)Vj(|v%yC(0 z1om8L3%2PCBq4XFo&aGQ4IMKn_{GcKRRdGW`6)EtWPt&B@k0wwmJd>~eO$9ka>rnT zj-3~I9~FpSnw{%&4M~ie5}w=yvKp;h6U8|({Bh+o!AdnX(_z9rKr;(ZB22JH2l@;>&KWdI>EHc>NG+(YiCj+_wUt45lL(#*x#%-B}gf+W~t3;3C zvYQN9ie)Ck$3*2jNbvBv%=cTH2#|S0tna7`D#~?(Pk>Zxy)#Op1y^Duh zM_)S~>cEeh2uto4p`FUFE<%-L(41YEitc~@_@3Z61MN(-a*R+42xGaca&UC z_5a*FcHts;A9=L5B8XJX2Qv?{iMXmpoe2K7YsdJdw?3BR;J9L=cja^iHz%gCEl^3k zy7q$-$9>;A1_EM~bQlndR)ff5h%kYXDl@ zbdT?#ov^6g4qxhD9B&k2I8P!zi-{w`B{YuBWe~qb?f%coe=5VC1K}&7|9_;lXUDcT r{-4bD|L;Nn=lvDouYO00og9RJp2_r#ai<+CcpQ)QP4!TJKY#Z>7sDP0 literal 8423 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 J{Ep+x{{=AZWe)%V diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/js/site.js b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/js/site.js new file mode 100644 index 0000000000..82ecce7b4a --- /dev/null +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/js/site.js @@ -0,0 +1 @@ +// Write your Javascript code. diff --git a/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/web.config b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/web.config new file mode 100644 index 0000000000..8e3f2a69d7 --- /dev/null +++ b/mvc/tutorials/mvc-with-entity-framework/sample/src/ContosoBooks/wwwroot/web.config @@ -0,0 +1,11 @@ + + + + + + + + + + +