webroot/http/serverlog.ps1
@"
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>7 Days To Die - Cindar's World</title> <!--STYLESHEET--> <!--=================================================--> <!--Open Sans Font [ OPTIONAL ]--> <link href='https://fonts.googleapis.com/css?family=Open+Sans:400,300,600,700' rel='stylesheet' type='text/css'> <!--Bootstrap Stylesheet [ REQUIRED ]--> <link href="css/bootstrap.min.css" rel="stylesheet"> <!--Nifty Stylesheet [ REQUIRED ]--> <link href="css/nifty.min.css" rel="stylesheet"> <!--Nifty Premium Icon [ DEMONSTRATION ]--> <link href="css/demo/nifty-demo-icons.min.css" rel="stylesheet"> <!--Demo [ DEMONSTRATION ]--> <link href="css/demo/nifty-demo.min.css" rel="stylesheet"> <!--Morris.js [ OPTIONAL ]--> <link href="plugins/morris-js/morris.min.css" rel="stylesheet"> <!--Magic Checkbox [ OPTIONAL ]--> <link href="plugins/magic-check/css/magic-check.min.css" rel="stylesheet"> <!-- Font Awesome --> <link href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/4.7.0/css/font-awesome.css" rel="stylesheet"> <!--JAVASCRIPT--> <!--=================================================--> <!--Pace - Page Load Progress Par [OPTIONAL]--> <link href="plugins/pace/pace.min.css" rel="stylesheet"> <script src="plugins/pace/pace.min.js"></script> <!--jQuery [ REQUIRED ]--> <script src="js/jquery.min.js"></script> <!--BootstrapJS [ RECOMMENDED ]--> <script src="js/bootstrap.min.js"></script> <!--NiftyJS [ RECOMMENDED ]--> <script src="js/nifty.min.js"></script> <!--=================================================--> <!--Demo script [ DEMONSTRATION ]--> <script src="js/demo/nifty-demo.min.js"></script> </head> <!--TIPS--> <!--You may remove all ID or Class names which contain "demo-", they are only used for demonstration. --> <body> <div id="container" class="effect aside-float aside-bright mainnav-lg"> <!--NAVBAR--> <!--===================================================--> <header id="navbar"> <div id="navbar-container" class="boxed"> <!--Brand logo & name--> <!--================================--> <div class="navbar-header"> <a href="index.html" class="navbar-brand"> <img src="img/7dtd_logo.png" class="brand-icon"> <div class="brand-title"> <span class="brand-text">Cindar's World</span> </div> </a> </div> <!--================================--> <!--End brand logo & name--> <!--Navbar Dropdown--> <!--================================--> <div class="navbar-content clearfix"> <ul class="nav navbar-top-links pull-left"> <!--Navigation toggle button--> <!--~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~--> <li class="tgl-menu-btn"> <a class="mainnav-toggle" href="#"> <i class="demo-pli-view-list"></i> </a> </li> <!--~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~--> <!--End Navigation toogle button--> </ul> <ul class="nav text-center"> <!--Updated Timer--> <!--~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~--> <li> <div class="username">Last Updated: 12/19/2017 14:22</div></center> </li> <!--~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~--> <!--End Updated Timer--> </ul> </div> <!--================================--> <!--End Navbar Dropdown--> </div> </header> <!--===================================================--> <!--END NAVBAR--> <div class="boxed"> <!--CONTENT CONTAINER--> <!--===================================================--> <div id="content-container"> <!--Page content--> <!--===================================================--> <div id="page-content"> <div class="row"> <div class="col-lg-12"> <!-- Timeline --> <!--===================================================--> <div class="timeline"> <!-- Timeline header --> <div class="timeline-header"> <div class="timeline-header-title bg-purple">Server Started</div> </div> $( #Init Variables $PlayerNames = @{} #Get Most Recent Log Then Reverse The Contents So Newest Info Is Written To Site First $Log = Get-ChildItem "C:\Games\7DaysToDie\7DaysToDieServer_Data" | Where {$_.Name -like "*output_log__*"} | Select -last 1 $LogContents = $(Get-Content "C:\Games\7DaysToDie\7DaysToDieServer_Data\$Log") #[array]::Reverse($LogContents) - Will Reverse When Ready To Read Log Backwards $LogContents | ForEach-Object { #Clear Parse Buffer $Command = "" #Parse The Statement Against Known Server Events Switch -Wildcard ($_) { #Server Started "*GameServer.LogOn successful*" { #Parse The Date $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-success'><i class='fa fa-play-circle fa-2x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" "<p class='text-main text-semibold'>Server Event - Server Started</p>" "<span>Let the mayhem begin!</span>" "</div>" "</div>" } #Shutdown Requested "*Executing command 'shutdown'*" { #Get Variables $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) $SteamID = $($_.Split(" ")[8]) $SteamURL = "http://steamcommunity.com/profiles/" + $SteamID + "?xml=1" $SteamProfile = $(([xml](Invoke-WebRequest -URI $SteamURL).Content).Profile) $PlayerName = $($SteamProfile.steamid.'#cdata-section') $AvatarIcon = $($SteamProfile.avatarIcon.'#cdata-section') #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-danger'><i class='fa fa-arrow-circle-down fa-2x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" "<p class='text-main text-semibold'>Server Event - Admin Shutdown Initiated</p>" "<img class='img-xs img-circle' src=$AvatarIcon>" "<span>$PlayerName shut down all the fun.</span>" "</div>" "</div>" } #Server Stopped "*OnApplicationQuit*" { #Parse The Date $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-danger'><i class='fa fa-stop-circle fa-2x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" "<p class='text-main text-semibold'>Server Event - Server Stopped</p>" "<span>We'll return shortly after these messages.......if our admin is paying any attention.</span>" "</div>" "</div>" } #Player Joined "*[INF] Player Connected,*" { #Get Variables $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) $PlayerName = $($_.Split(",")[2].split("=")[1]) $SteamID = $($_.Split(",")[3].split("=")[1]) $SteamURL = "http://steamcommunity.com/profiles/" + $SteamID + "?xml=1" $SteamProfile = $(([xml](Invoke-WebRequest -URI $SteamURL).Content).Profile) $AvatarIcon = $($SteamProfile.avatarIcon.'#cdata-section') #Add Player To Hash Table For Lookup Later If($($PlayerNames.Get_Item("$PlayerName")) -eq $null) {$PlayerNames.Add("$PlayerName", "$SteamID")} #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-info'><i class='fa fa-sign-in fa-2x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" $( #Lookup To See If Player Is Too New To Get A Profile From Or Is A Child Profile If($AvatarIcon -eq $null) { "<img class='img-xs img-circle' src=>" } Else { "<img class='img-xs img-circle' src=$AvatarIcon>" } ) "$PlayerName Joined To Kill Some Zombies!" "</div>" "</div>" } #Player Died "*GMSG: Player*died*" { #Get Variables $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) $PlayerName = $($_.Split("'")[1]) $SteamID = $PlayerNames.Get_Item("$PlayerName") $SteamURL = "http://steamcommunity.com/profiles/" + $SteamID + "?xml=1" $SteamProfile = $(([xml](Invoke-WebRequest -URI $SteamURL).Content).Profile) $AvatarIcon = $($SteamProfile.avatarIcon.'#cdata-section') #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-info'><i class='fa fa-frown-o fa-2x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" $( #Lookup To See If Player Is Too New To Get A Profile From Or Is A Child Profile If($AvatarIcon -eq $null) { "<img class='img-xs img-circle' src=>" } Else { "<img class='img-xs img-circle' src=$AvatarIcon>" } ) "$PlayerName Died!" "</div>" "</div>" } #Player Left "*INF Player*disconnected after*" { #Get Variables $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) $PlayerName = $($_.Split(" ")[4]) $LastedTime = $($_.Split(" ")[7]) + " " + $($_.Split(" ")[8]) $SteamID = $PlayerNames.Get_Item("$PlayerName") $SteamURL = "http://steamcommunity.com/profiles/" + $SteamID + "?xml=1" $SteamProfile = $(([xml](Invoke-WebRequest -URI $SteamURL).Content).Profile) $AvatarIcon = $($SteamProfile.avatarIcon.'#cdata-section') #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-info'><i class='fa fa-sign-out fa-2x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" $( If($LastedTime -lt 60) { "<p class='text-main text-semibold'>Weak Sauce!</p>" #Lookup To See If Player Is Too New To Get A Profile From Or Is A Child Profile If($AvatarIcon -eq $null) { "<img class='img-xs img-circle' src=>" } Else { "<img class='img-xs img-circle' src=$AvatarIcon>" } "$PlayerName could only handle $LastedTime before he bounced, so weak bra!" } ElseIf($LastedTime -lt 180) { "<p class='text-main text-semibold'>At Least You Did Something Before You Got Off!</p>" #Lookup To See If Player Is Too New To Get A Profile From Or Is A Child Profile If($AvatarIcon -eq $null) { "<img class='img-xs img-circle' src=>" } Else { "<img class='img-xs img-circle' src=$AvatarIcon>" } "$PlayerName could only handle $LastedTime before he bounced, so weak bra!" } Else { "<p class='text-main text-semibold'>You Deserve A Vacation!</p>" #Lookup To See If Player Is Too New To Get A Profile From Or Is A Child Profile If($AvatarIcon -eq $null) { "<img class='img-xs img-circle' src=>" } Else { "<img class='img-xs img-circle' src=$AvatarIcon>" } "$PlayerName crushed it for $LastedTime before he decided to take a well deserved break." } ) "</div>" "</div>" } #Player Ban - NEEDS UPDATE "BANBANBAN" { #Parse The Date #$TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) #Parse The Command And Write The HTML #"<div class='timeline-entry'>" # "<div class='timeline-stat'>" # "<div class='timeline-icon bg-warning'><i class='fa fa-ban fa-2x'></i></div>" # "<div class='timeline-time'>" # IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} # ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} # ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} # ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} # "</div>" # "</div>" # "<div class='timeline-label'>" # "<p class='text-main text-semibold'>Ban Hammer Swung</p>" # "<span>$PlayerName just got ban hammered.....sucks to be you $PlayerName.</span>" # "</div>" #"</div>" } #Deny Admin Command "*Denying command*" { #Get The Variables $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) $PlayerName = $(($_ -Split 'client')[1].TrimStart()) $DeniedCommand = $($_.Split("'")[1]) #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-warning'><i class='demo-psi-speech-bubble-3 icon-lg'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} "</div>" "</div>" "<div class='timeline-label'>" "$PlayerName Tried To Cheat The System By Executing: $DeniedCommand, But Was Caught And Publicly Shamed Instead." "</div>" "</div>" } #Render Map "*Executing command 'rendermap'*" { #Get Variables $TimeDelta = $((Get-Date) - [datetime]$($_.Split(" ")[0])) $SteamID = $($_.Split(" ")[8]) $SteamURL = "http://steamcommunity.com/profiles/" + $SteamID + "?xml=1" $SteamProfile = $(([xml](Invoke-WebRequest -URI $SteamURL).Content).Profile) $PlayerName = $($SteamProfile.steamid.'#cdata-section') $AvatarIcon = $($SteamProfile.avatarIcon.'#cdata-section') #Parse The Command And Write The HTML "<div class='timeline-entry'>" "<div class='timeline-stat'>" "<div class='timeline-icon bg-info'><i class='fa fa-map-o fa-1x'></i></div>" "<div class='timeline-time'>" IF($($TimeDelta.Days) -gt 0){"$($TimeDelta.Days) days ago"} ElseIf($($TimeDelta.Hours) -gt 0) {"$($TimeDelta.Hours)h ago"} ElseIf($($TimeDelta.Minutes) -gt 0){"$($TimeDelta.Minutes) mins ago"} ElseIf($($TimeDelta.Minutes) -lt 0){"just now"} "</div>" "</div>" "<div class='timeline-label'>" "<p class='text-main text-semibold'>Server Event - Render Map to Website</p>" "<img class='img-xs img-circle' src=$AvatarIcon>" "<span>$PlayerName just decided to slowed down the entire server so he could update the map on the website. *golf clap*</span>" "</div>" "</div>" } #Ignore default {} } } ) </div> <!--===================================================--> <!-- End Timeline --> </div> </div> </div> <!--===================================================--> <!--End page content--> </div> <!--===================================================--> <!--END CONTENT CONTAINER--> <!--MAIN NAVIGATION--> <!--===================================================--> <nav id="mainnav-container"> <div id="mainnav"> <!--Menu--> <!--================================--> <div id="mainnav-menu-wrap"> <div class="nano"> <div class="nano-content"> <!--Widget--> <!--================================--> <div class="mainnav-widget"> <!-- Show the button on collapsed navigation --> <div class="show-small"> <a href="#" data-toggle="menu-widget" data-target="#demo-wg-server"> <i class="demo-pli-monitor-2"></i> </a> </div> <!-- Hide the content on collapsed navigation --> <div id="demo-wg-server" class="hide-small mainnav-widget-content"> <ul class="list-group"> <li> $( #Determine If Main Server Is Up Or Down If((Get-NetTCPConnection | Where {$_.OwningProcess -eq $((Get-Process | Where {$_.ProcessName -like '7DaysToDieServer'}).ID)} | Where {$_.LocalPort -eq '26900'} | Measure-Object).Count -gt 0) { '<span class="label label-success pull-right">UP</span>' } Else { '<span class="label label-danger pull-right">DOWN</span>' } ) <p>Main Server</p> </li> <li> $( #Determine If Main Server Is Up Or Down If((Get-NetTCPConnection | Where {$_.OwningProcess -eq $((Get-Process | Where {$_.ProcessName -like '7DaysToDieServer'}).ID)} | Where {$_.LocalPort -eq '26901'} | Measure-Object).Count -gt 0) { '<span class="label label-success pull-right">UP</span>' } Else { '<span class="label label-danger pull-right">DOWN</span>' } ) <p>Test Server</p> </li> </ul> </div> </div> <!--================================--> <!--End widget--> <ul id="mainnav-menu" class="list-group"> <!--Category name--> <li class="list-header">Navigation</li> <!--Menu list item--> <li> <a href="index.ps1"> <i class="demo-psi-home"></i> <span class="menu-title"> <strong>Dashboard</strong> </span> </a> </li> <!--Menu list item--> <li> <a href="maps.ps1"> <i class="fa fa-map-o" aria-hidden="true"></i> <span class="menu-title"> <strong>Server Map</strong> </span> </a> </li> <!--Menu list item--> <li class="active-link"> <a href="serverlog.ps1"> <i class="fa fa-file-text-o" aria-hidden="true"></i> <span class="menu-title"> <strong>Server Log Feed</strong> </span> </a> </li> <!--Menu list item--> <li> <a href="controlpanel.ps1"> <i class="fa fa-terminal" aria-hidden="true"></i> <span class="menu-title"> <strong>Control Panel</strong> </span> </a> </li> </ul> </div> </div> </div> <!--================================--> <!--End menu--> </div> </nav> <!--===================================================--> <!--END MAIN NAVIGATION--> </div> <!-- FOOTER --> <!--===================================================--> <footer id="footer"> <!-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ --> <!-- Remove the class "show-fixed" and "hide-fixed" to make the content always appears. --> <!-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ --> <p class="pad-lft">© 2017 Sean Davis</p> </footer> <!--===================================================--> <!-- END FOOTER --> <!-- SCROLL PAGE BUTTON --> <!--===================================================--> <button class="scroll-top btn"> <i class="pci-chevron chevron-up"></i> </button> <!--===================================================--> </div> <!--===================================================--> <!-- END OF CONTAINER --> </body> </html> "@ 1 |