1
0
mirror of https://bitbucket.org/anguist/ntpa synced 2025-10-26 21:19:05 +00:00
Files
ntpa/Ntp.Analyzer.Process/Description/PeerGraphPageJob.cs
2016-05-22 23:40:47 +02:00

94 lines
3.2 KiB
C#

//
// GraphPageJob.cs
//
// Author:
// Carsten Sonne Larsen <cs@innolan.dk>
//
// Copyright (c) 2013-2016 Carsten Sonne Larsen
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
using System;
using System.Collections.Generic;
using System.Linq;
using Ntp.Analyzer.Config.Destination;
using Ntp.Analyzer.Config.Graph;
using Ntp.Analyzer.Config.Page;
using Ntp.Analyzer.Data;
using Ntp.Analyzer.Localize;
using Ntp.Analyzer.Objects;
using Ntp.Analyzer.Page;
using Ntp.Log;
using Ntp.Process;
namespace Ntp.Analyzer.Process.Description
{
public class PeerGraphPageJob : StreamJob
{
public PeerGraphPageJob(PeerGraphPageConfiguration config, LogBase log)
: base(config, log)
{
this.config = config;
}
private readonly PeerGraphPageConfiguration config;
public override ThreadType ThreadType
{
get { return ThreadType.MultiThreaded; }
}
public override string JobType
{
get { return "Peer graph pages build"; }
}
public override int Priority
{
get { return 18; }
}
protected override void InternalExecute()
{
Host host = DataFace.Instance.Hosts.SingleOrDefault(h => h.Id == config.HostId);
if (host == null)
{
Log.WriteLine(String.Format(LogMessage.HostNotFound, config.HostId), Severity.Warn);
return;
}
IEnumerable<PeerActivity> peers = DataFace.Instance.PeerActivities.
Where(p => p.Host == host && p.IsActive);
foreach (PeerActivity entry in peers)
{
foreach (GraphSetConfiguration graphSet in config.GraphSets)
{
foreach (GraphBaseConfiguration graph in graphSet.Graphs)
{
var builder = new GraphPageBuilder(config, entry.Peer, entry.Name, graphSet, graph);
string file = config.GetFileName(host, entry.Name, graphSet, graph);
SaveStream(builder, file);
}
}
}
}
}
}