narsil/Tanshu.Accounts.SqlDAO/Fluent/Fixtures.cs

330 lines
14 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using FluentNHibernate.Automapping;
using Tanshu.Accounts.Contracts;
using FluentNHibernate.Cfg;
using FluentNHibernate.Cfg.Db;
using Tanshu.Accounts.Conventions;
using Tanshu.Accounts.Entities;
using NHibernate.Tool.hbm2ddl;
using NHibernate;
using NHibernate.Cfg;
using Tanshu.Accounts.Entities.Auth;
namespace Tanshu.Accounts.SqlDAO
{
public static class Fixtures
{
public static bool CreateSchema()
{
var cfg = SessionManager.Configuration;
new SchemaExport(cfg).Execute(true, true, true);
new SchemaExport(cfg).Execute(true, true, false);
// next line is just for checking how the nhibernate xml configuration files look
//persistenceModel.WriteMappingsTo(@"C:\Temp");
Fixtures.InsertRole();
Fixtures.InsertUser();
Fixtures.InsertGroup();
Fixtures.InsertUserGroup();
Fixtures.InsertRoleGroup();
Fixtures.InsertCustomer();
Fixtures.InsertTax();
Fixtures.InsertWaiter();
Fixtures.InsertPrintLocation();
Fixtures.InsertSettleOption();
InsertFoodTable();
InsertProductGroup();
InsertProductBeer();
InsertModifier();
InsertProductGroupModifier();
return true;
}
#region role
public static void InsertRole()
{
using (var session = SessionManager.Session)
{
session.Save(GetRole(1, "Sales/Checkout"));
session.Save(GetRole(2, "Sales/SalesBill"));
session.Save(GetRole(3, "Sales/SaleDetail"));
session.Save(GetRole(4, "Sales/VoidPrintedBill"));
session.Save(GetRole(5, "Sales/EditBill"));
session.Save(GetRole(6, "Sales/PrintKOT"));
session.Save(GetRole(7, "Sales/PrintBill"));
session.Save(GetRole(8, "Sales/EditPrintedProduct"));
session.Save(GetRole(9, "Sales/ChangeRate"));
session.Save(GetRole(10, "Master/Products"));
session.Save(GetRole(11, "Security/ManageRoles"));
session.Save(GetRole(12, "Log/View"));
session.Save(GetRole(13, "Master/Owner"));
}
}
private static Role GetRole(int roleID, string name)
{
return new Role()
{
RoleID = roleID,
Name = name
};
}
#endregion
#region user
public static void InsertUser()
{
using (var session = SessionManager.Session)
{
session.Save(GetUser(1, "admin", "password"));
}
}
private static User GetUser(int userID, string name, string password)
{
return new User()
{
UserID = userID,
Name = name,
Password = Tanshu.Common.Md5.Hash(password, "v2"),
LockedOut = false
};
}
#endregion
#region group
public static void InsertGroup()
{
using (var session = SessionManager.Session)
{
session.Save(GetGroup(1, "owner"));
session.Save(GetGroup(2, "waiter"));
session.Save(GetGroup(3, "captain"));
session.Save(GetGroup(4, "manager"));
session.Save(GetGroup(5, "controller"));
session.Save(GetGroup(6, "accountant"));
}
}
private static Group GetGroup(int groupID, string name)
{
return new Group()
{
GroupID = groupID,
Name = name
};
}
#endregion
#region user_group
public static void InsertUserGroup()
{
using (var session = SessionManager.Session)
{
var admin = session.Get<User>(1);
var list = session.CreateCriteria<Group>()
.List<Group>();
foreach (var item in list)
{
session.Save(new UserGroup()
{
User = admin,
Group = item
});
}
}
}
#endregion
#region role_group
public static void InsertRoleGroup()
{
using (var session = SessionManager.Session)
{
var owner = session.Get<Group>(1);
var list = session.CreateCriteria<Role>()
.List<Role>();
foreach (var item in list)
{
session.Save(new RoleGroup()
{
Role = item,
Group = owner
});
}
}
}
#endregion
#region customer
public static void InsertCustomer()
{
using (var session = SessionManager.Session)
{
session.Save(new Customer()
{
CustomerID = 1,
Code = 1,
Name = "Cash",
Address = "",
Important = false,
Phone = "",
Remarks = ""
});
}
}
#endregion
#region tax
public static void InsertTax()
{
using (var session = SessionManager.Session)
{
session.Save(new Tax()
{
TaxID = 1,
Name = "VAT + SC 12.5%",
Rate = .13125M
});
session.Save(new Tax()
{
TaxID = 1,
Name = "VAT + SC 25%",
Rate = .2625M
});
session.Save(new Tax()
{
TaxID = 1,
Name = "Service Tax 10.3%",
Rate = .103M
});
}
}
#endregion
#region waiter
public static void InsertWaiter()
{
using (var session = SessionManager.Session)
{
session.Save(new Waiter()
{
WaiterID = 1,
Name = "Waiter",
});
}
}
#endregion
#region print_location
public static void InsertPrintLocation()
{
using (var session = SessionManager.Session)
{
session.Save(new PrintLocation()
{
PrintLocationID = 1,
Location = "Ground",
Copies = 2,
Printer = @"\\gandalf\kitchen",
ProductGroup = null,
CutCode = "\n\r\n\r\n\r\n\r\n\r\n\r" + (char)29 + (char)86 + (char)49
});
}
}
#endregion
#region settle_option
public static void InsertSettleOption()
{
using (var session = SessionManager.Session)
{
session.Save(SettleOptionFactory.OUnsettled);
session.Save(SettleOptionFactory.OCash);
session.Save(SettleOptionFactory.OCreditCard);
session.Save(SettleOptionFactory.ONoCharge);
session.Save(SettleOptionFactory.OBillToCompany);
session.Save(SettleOptionFactory.OStaff);
}
}
#endregion
#region food_table
public static void InsertFoodTable()
{
using (var session = SessionManager.Session)
{
session.Save(new FoodTable() { FoodTableID = 1, Name = "1" });
session.Save(new FoodTable() { FoodTableID = 2, Name = "2" });
session.Save(new FoodTable() { FoodTableID = 3, Name = "3" });
session.Save(new FoodTable() { FoodTableID = 4, Name = "4" });
session.Save(new FoodTable() { FoodTableID = 5, Name = "5" });
session.Save(new FoodTable() { FoodTableID = 6, Name = "6" });
session.Save(new FoodTable() { FoodTableID = 7, Name = "7" });
session.Save(new FoodTable() { FoodTableID = 8, Name = "8" });
session.Save(new FoodTable() { FoodTableID = 9, Name = "9" });
session.Save(new FoodTable() { FoodTableID = 10, Name = "10" });
}
}
#endregion
#region product_group
public static void InsertProductGroup()
{
using (var session = SessionManager.Session)
{
session.Save(new ProductGroup() { ProductGroupID = 1, Name = "Beer", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 2, Name = "Imported Alcohol", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 3, Name = "IMFL Alcohol", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 4, Name = "Cocktails", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 5, Name = "Indian Starters", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 6, Name = "International Starters", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 7, Name = "Indian Maincourse", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 8, Name = "International Maincourse", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 9, Name = "Pastas", DiscountLimit = 0, IsModifierCompulsory = false });
session.Save(new ProductGroup() { ProductGroupID = 10, Name = "Desserts", DiscountLimit = 0, IsModifierCompulsory = false });
}
}
#endregion
#region product_group
public static void InsertProductBeer()
{
using (var session = SessionManager.Session)
{
var tax = session.Get<Tax>(2);
var pg = session.Get<ProductGroup>(1);
session.Save(new Product() { ProductID = 1, Code = 1, Name = "Wheat Beer", Units = ".5L Mug", SalePrice = 185, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 2, Code = 2, Name = "Light Beer", Units = ".5L Mug", SalePrice = 160, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 3, Code = 3, Name = "Dark Beer", Units = ".5L Mug", SalePrice = 160, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 4, Code = 4, Name = "Premium Beer", Units = ".5L Mug", SalePrice = 185, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 5, Code = 5, Name = "Wheat Beer", Units = "2L Pcr", SalePrice = 650, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 6, Code = 6, Name = "Light Beer", Units = "2L Pcr", SalePrice = 550, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 7, Code = 7, Name = "Dark Beer", Units = "2L Pcr", SalePrice = 550, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
session.Save(new Product() { ProductID = 8, Code = 8, Name = "Premium Beer", Units = "2L Pcr", SalePrice = 650, ServiceCharge = .1M, Discontinued = false, MaximumLevel = 0, MinimumLevel = 0, ProductGroup = pg, SortOrder = 1, Tax = tax });
}
}
#endregion
#region modifiers
public static void InsertModifier()
{
using (var session = SessionManager.Session)
{
session.Save(new Modifier() { ModifierID = 1, Name = "On the Rocks" });
session.Save(new Modifier() { ModifierID = 2, Name = "Frozen" });
session.Save(new Modifier() { ModifierID = 3, Name = "Soda" });
session.Save(new Modifier() { ModifierID = 4, Name = "Water" });
session.Save(new Modifier() { ModifierID = 5, Name = "Spicy" });
session.Save(new Modifier() { ModifierID = 6, Name = "HOLD" });
}
}
#endregion
#region product_group_modifiers
public static void InsertProductGroupModifier()
{
using (var session = SessionManager.Session)
{
using (var trans = session.BeginTransaction())
{
foreach (var item in session.CreateCriteria<Modifier>().List<Modifier>())
{
session.Save(new ProductGroupModifier() { Modifier = item });
}
trans.Commit();
}
}
}
#endregion
}
}