-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathStartup.cs
More file actions
64 lines (56 loc) · 2.22 KB
/
Startup.cs
File metadata and controls
64 lines (56 loc) · 2.22 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
using System.IO;
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using Microsoft.Data.Sqlite;
using Dapper;
using Newtonsoft.Json;
using Newtonsoft.Json.Serialization;
using net_assignment.Models;
namespace net_assignment
{
public class Startup
{
private string dbFile = Path.GetTempPath() + "net_assignment.sqlite";
// This method gets called by the runtime. Use this method to add services to the container.
// For more information on how to configure your application, visit https://go.microsoft.com/fwlink/?LinkID=398940
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc()
.AddJsonOptions(opts =>
{
opts.SerializerSettings.ContractResolver = new CamelCasePropertyNamesContractResolver();
opts.SerializerSettings.NullValueHandling = NullValueHandling.Ignore;
});
services.AddOptions();
services.Configure<DBOptions>(opts =>
{
opts.ConnectionString = "Data Source=" + dbFile;
});
services.AddSingleton<IRepository<Contact, long>, ContactRepository>();
}
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerFactory)
{
if (!File.Exists(dbFile))
{
using (var c = new SqliteConnection("Data Source=" + dbFile))
{
c.Open();
var i = c.Execute(@"CREATE TABLE Contact(
Id integer primary key AUTOINCREMENT,
FirstName text not null,
LastName text not null,
Email text not null,
Phone text,
City text
)");
System.Console.WriteLine("New DB created");
}
}
System.Console.WriteLine("DB file location: " + dbFile);
loggerFactory.AddConsole();
app.UseMvc();
}
}
}