本文整理汇总了C#中Allegiance.CommunitySecuritySystem.DataAccess.CSSDataContext类的典型用法代码示例。如果您正苦于以下问题:C# CSSDataContext类的具体用法?C# CSSDataContext怎么用?C# CSSDataContext使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
CSSDataContext类属于Allegiance.CommunitySecuritySystem.DataAccess命名空间,在下文中一共展示了CSSDataContext类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: LoadPlayerDataResponse
public LoadPlayerDataResponse(LoadPlayerDataRequest playerData)
{
using (CSSStatsDataContext statsDB = new CSSStatsDataContext())
{
using (CSSDataContext db = new CSSDataContext())
{
var login = Login.FindLoginByUsernameOrCallsign(db, playerData.LoginUsername);
if (login == null)
{
Succeeded = false;
ErrorMessage = "Couldn't find player's login user id.";
return;
}
ScoreQueue scoreQueue = statsDB.ScoreQueues.FirstOrDefault(p => p.LoginId == login.Id && p.GameGuid == playerData.GameGuid);
if (scoreQueue == null)
{
statsDB.ScoreQueues.InsertOnSubmit(new ScoreQueue()
{
LoginId = login.Id,
GameGuid = playerData.GameGuid,
Score = playerData.Score,
PilotBaseKills = playerData.PilotBaseKills,
PilotBaseCaptures = playerData.PilotBaseCaptures,
WarpsSpotted = playerData.WarpsSpotted,
AsteroidsSpotted = playerData.AsteroidsSpotted,
MinerKills = playerData.MinerKills,
BuilderKills = playerData.BuilderKills,
LayerKills = playerData.LayerKills,
CarrierKills = playerData.CarrierKills,
PlayerKills = playerData.PlayerKills,
BaseKills = playerData.BaseKills,
BaseCaptures = playerData.BaseCaptures,
TechsRecovered = playerData.TechsRecovered,
Flags = playerData.Flags,
Artifacts = playerData.Artifacts,
Rescues = playerData.Rescues,
Kills = playerData.Kills,
Assists = playerData.Assists,
Deaths = playerData.Deaths,
Ejections = playerData.Ejections,
Win = playerData.Win,
Lose = playerData.Lose,
CommandWin = playerData.CommandWin,
CommandLose = playerData.CommandLose,
TimePlayed = playerData.TimePlayed,
TimeCommanded = playerData.TimeCommanded,
CommandCredit = playerData.CommandCredit,
CombatRating = playerData.CombatRating
});
}
statsDB.SubmitChanges();
}
}
this.Succeeded = true;
}
示例2: GetGroupMessages
public static List<IMessage> GetGroupMessages(CSSDataContext db, string callsign)
{
var messages = new List<IMessage>();
var aliases = Alias.ListAliases(db, callsign);
foreach (var alias in aliases)
{
messages.AddRange(
alias.GroupMessage_Alias.Where(p => p.DateViewed == null).Select(p => (IMessage) p.GroupMessage).ToList()
);
//messages.AddRange(alias.GroupMessages
// .Where(
// p => p.DateExpires <= DateTime.Now
// && p.DateToSend >= DateTime.Now
// && p.GroupMessage_Alias
// .FirstOrDefault(r => r.Alias == alias && r.DateViewed == null) != null)
// .Select(q => (IMessage)q).ToList());
foreach (var gma in alias.GroupMessage_Alias.Where(p => p.DateViewed == null && messages.Select(q => q.Id).Contains(p.GroupMessageId)))
{
//if (messages.FirstOrDefault(p => p.Id == gma.GroupMessageId) != null)
gma.DateViewed = DateTime.Now;
}
db.SubmitChanges();
}
return messages;
}
示例3: btnSaveNewGroup_Click
protected void btnSaveNewGroup_Click(object sender, EventArgs e)
{
using(CSSDataContext db = new CSSDataContext())
{
if (db.Groups.FirstOrDefault(p => p.Name == txtName.Text.Trim()) != null)
{
lblErrorText.Text = "The group or squad name you specified: " + txtName.Text + " already exists.";
return;
}
if (db.Groups.FirstOrDefault(p => p.Tag == txtTag.Text.Trim()) != null)
{
lblErrorText.Text = "The tag name you specified: " + txtTag.Text + " already exists.";
return;
}
db.Groups.InsertOnSubmit(new Group()
{
Name = txtName.Text.Trim(),
DateCreated = DateTime.Now,
IsSquad = chkIsSquad.Checked,
Tag = txtTag.Text
});
db.SubmitChanges();
this.DataBind();
}
}
示例4: Handle
public static bool Handle(HttpContext context, int lobbyId, string filename)
{
using (var db = new CSSDataContext())
{
if (filename.Contains(".."))
throw new Exception("Could not load path.");
var lobby = db.Lobbies.Single(p => p.IsEnabled && p.Id == lobbyId);
var filepath = Path.Combine(lobby.BasePath, filename);
//If file is not found, attempt to send file from the default path
var info = new FileInfo(filepath);
if (!info.Exists)
{
filepath = Path.Combine(ConfigurationManager.AppSettings["DefaultLobbyPath"], filename);
info = new FileInfo(filepath);
if (!info.Exists)
throw new FileNotFoundException();
}
//Transmit the file
context.Response.Clear();
context.Response.ContentType = "application/octet-stream";
context.Response.AddHeader("Content-Length", info.Length.ToString());
context.Response.AddHeader("Content-Disposition",
string.Format("attachment; filename=\"{0}\"",
Path.GetFileName(filename)));
context.Response.TransmitFile(filepath);
}
return true;
}
示例5: cvCaptcha_ServerValidate
protected void cvCaptcha_ServerValidate(object source, ServerValidateEventArgs args)
{
bool isValid = false;
if (ViewState["captchaToken"] != null)
{
Guid captchaToken = (Guid)ViewState["captchaToken"];
using (CSSDataContext db = new CSSDataContext())
{
var captcha = db.Captchas.FirstOrDefault(p => p.Id == captchaToken);
//args.Value
//CustomValidator cvCaptcha = (CustomValidator)source;
//TextBox txtValidationCode = (TextBox) cvCaptcha.ControlToValidate;
if (captcha != null && args.Value.Equals(captcha.Answer, StringComparison.InvariantCultureIgnoreCase) == true)
{
isValid = true;
}
}
}
if (isValid == false)
ViewState["captchaToken"] = null;
args.IsValid = isValid;
}
示例6: CreateUser
public static void CreateUser(string user, string password, string email)
{
using (var db = new CSSDataContext())
{
var identity = new Identity()
{
DateLastLogin = DateTime.Now,
LastGlobalMessageDelivery = DateTime.Now
};
var login = new Login()
{
Username = user,
Password = Hash(password),
Email = email,
DateCreated = DateTime.Now,
};
var alias = new Alias()
{
Callsign = user,
DateCreated = DateTime.Now,
IsDefault = true,
IsActive = true
};
login.Aliases.Add(alias);
identity.Logins.Add(login);
login.Lobby_Logins.Add(new Lobby_Login() { Lobby = db.Lobbies.First(p => p.Name == "Production") });
db.Identities.InsertOnSubmit(identity);
db.SubmitChanges();
}
}
示例7: TestCheckForUpdates
public void TestCheckForUpdates()
{
int lobbyId = 0;
using (var db = new CSSDataContext())
{
//Create autoupdate files
var file = new AutoUpdateFile() { Filename = "mdl", IsProtected = true };
db.AutoUpdateFiles.InsertOnSubmit(file);
var lobby = db.Lobbies.FirstOrDefault();
lobbyId = lobby.Id;
file.AutoUpdateFile_Lobbies.Add(new AutoUpdateFile_Lobby()
{
CurrentVersion = "1.0",
DateCreated = DateTime.Now,
DateModified = DateTime.Now,
Lobby = lobby,
ValidChecksum = "VALID"
});
db.SubmitChanges();
}
var clientService = new ClientService();
var files = clientService.CheckForUpdates(lobbyId);
var fileResult = files.Files.FirstOrDefault();
Assert.AreEqual(1, files.Files.Count);
Assert.IsTrue(fileResult.IsProtected);
Assert.AreEqual("mdl", fileResult.Filename);
Assert.AreEqual("VALID", fileResult.ValidChecksum.Trim());
Assert.AreEqual("1.0", fileResult.CurrentVersion);
Assert.AreEqual(lobbyId, fileResult.LobbyId);
}
示例8: btnSubmit_Click
protected void btnSubmit_Click(object sender, EventArgs e)
{
using(CSSDataContext db = new CSSDataContext())
{
// If the page loaded, then don't worry about the date at this point, they'll get a free ride if
// they camped on the page for a while. The date is just to keep the enemy from getting a hold
// of an old email and coming back in with it.
var logins = db.Logins.Where(p => p.PasswordResetGuid == new Guid(Request.Params["resetGuid"]));
foreach(var login in logins)
{
CssMembershipProvider cssMembershipProvider = new CssMembershipProvider();
string tempPassword = cssMembershipProvider.ResetPassword(login.Username, null);
cssMembershipProvider.ChangePassword(login.Username, tempPassword, txtPassword.Text);
}
db.Refresh(System.Data.Linq.RefreshMode.OverwriteCurrentValues, logins);
foreach (var login in logins)
{
// Keep anyone from reusing an old password reset mail.
login.PasswordResetGuid = Guid.Empty;
}
db.SubmitChanges();
}
divResetPassword.Visible = false;
divResetSuccess.Visible = true;
}
示例9: Write
public static bool Write(CSSDataContext db, LogType type, string message, bool submit)
{
try
{
db.Logs.InsertOnSubmit(new Log()
{
DateOccurred = DateTime.Now,
Message = message,
Type = (byte)type
});
if (submit)
db.SubmitChanges();
Console.WriteLine(String.Format("{0}: {1} {2}", DateTime.Now, type.ToString(), message));
return true;
}
catch(Exception error)
{
var errorMessage = new StringBuilder()
.AppendLine("Failed to write data to log:")
.Append("Type: ").AppendLine(type.ToString())
.Append("Message: ").AppendLine(message);
Debug.WriteLine(errorMessage);
Error.Write(db, new Exception(errorMessage.ToString(), error), submit);
return false;
}
}
示例10: Verify
/// <summary>
/// Calls BlackboxServer module to verify login and retrieve blackbox information.
/// </summary>
internal LoginResult Verify(bool useDebugBlackbox)
{
byte[] data;
var alias = Alias;
string ipAddress = "127.0.0.1";
if (HttpContext.Current != null)
ipAddress = HttpContext.Current.Request.UserHostAddress;
var result = Validation.CreateSession(ipAddress, Username, Password, LobbyId, useDebugBlackbox, ref alias, out data);
int rank = 0;
using (CSSDataContext db = new CSSDataContext())
{
var rankDetail = DataAccess.Alias.GetRankForCallsign(db, alias);
if (rankDetail != null)
rank = (int)rankDetail.Rank;
}
return new LoginResult()
{
Status = result,
BlackboxData = data,
AcceptedAlias = alias,
Rank = rank
};
}
示例11: BindData
private void BindData()
{
using (CSSDataContext db = new CSSDataContext())
{
gvPolls.DataSource = db.Polls.OrderByDescending(p => p.DateExpires);
gvPolls.DataBind();
}
}
示例12: Clean
public static void Clean()
{
using (var db = new CSSDataContext())
{
db.Logs.DeleteAllOnSubmit(db.Logs.Where(p => p.DateOccurred < DateTime.Now.AddDays(-30)));
db.SubmitChanges();
}
}
示例13: Clean
public static void Clean()
{
using (var db = new CSSDataContext())
{
db.LogIPs.DeleteAllOnSubmit(db.LogIPs.Where(p => p.LastAccessed < DateTime.Now.AddDays(-180)));
db.SubmitChanges();
}
}
示例14: ListBans
internal static List<Ban> ListBans(string alias)
{
using (var db = new CSSDataContext())
{
var login = Login.FindLoginByUsernameOrCallsign(db, alias);
return login.Identity.Bans.ToList();
}
}
示例15: FindLoginByUsernameOrCallsign
public static Login FindLoginByUsernameOrCallsign(CSSDataContext db, string usernameOrCallsign)
{
var login = FindLoginByUsername(db, usernameOrCallsign);
if (login == null)
login = FindLoginByCallsign(db, usernameOrCallsign);
return login;
}