mirror of
https://github.com/SerenityOS/serenity
synced 2024-10-15 20:33:10 +00:00
ProcessManager: Remove SocketModel and NetworkAdapterModel
These are trivially replaced by GJsonArrayModels :^)
This commit is contained in:
parent
6e50631e35
commit
0f0a528323
|
@ -11,8 +11,6 @@ OBJS = \
|
|||
ProcessFileDescriptorMapWidget.o \
|
||||
ProcessFileDescriptorMapModel.o \
|
||||
NetworkStatisticsWidget.o \
|
||||
NetworkAdapterModel.o \
|
||||
SocketModel.o \
|
||||
main.o
|
||||
|
||||
APP = ProcessManager
|
||||
|
|
|
@ -1,102 +0,0 @@
|
|||
#include "NetworkAdapterModel.h"
|
||||
#include <AK/JsonObject.h>
|
||||
#include <AK/StringBuilder.h>
|
||||
#include <LibCore/CFile.h>
|
||||
|
||||
void NetworkAdapterModel::update()
|
||||
{
|
||||
CFile file("/proc/net/adapters");
|
||||
if (!file.open(CIODevice::ReadOnly)) {
|
||||
dbg() << "Unable to open " << file.filename();
|
||||
return;
|
||||
}
|
||||
|
||||
auto json = JsonValue::from_string(file.read_all());
|
||||
|
||||
ASSERT(json.is_array());
|
||||
m_netadapters = json.as_array();
|
||||
|
||||
did_update();
|
||||
}
|
||||
|
||||
int NetworkAdapterModel::row_count(const GModelIndex&) const
|
||||
{
|
||||
return m_netadapters.size();
|
||||
}
|
||||
|
||||
String NetworkAdapterModel::column_name(int column) const
|
||||
{
|
||||
switch (column) {
|
||||
case Column::Name:
|
||||
return "Name";
|
||||
case Column::ClassName:
|
||||
return "Class";
|
||||
case Column::MacAddress:
|
||||
return "MAC";
|
||||
case Column::IpAddress:
|
||||
return "IP";
|
||||
case Column::PacketsIn:
|
||||
return "Pkt In";
|
||||
case Column::PacketsOut:
|
||||
return "Pkt Out";
|
||||
case Column::BytesIn:
|
||||
return "Bytes In";
|
||||
case Column::BytesOut:
|
||||
return "Bytes Out";
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
}
|
||||
|
||||
GModel::ColumnMetadata NetworkAdapterModel::column_metadata(int column) const
|
||||
{
|
||||
switch (column) {
|
||||
case Column::Name:
|
||||
return { 32, TextAlignment::CenterLeft };
|
||||
case Column::ClassName:
|
||||
return { 120, TextAlignment::CenterLeft };
|
||||
case Column::MacAddress:
|
||||
return { 90, TextAlignment::CenterLeft };
|
||||
case Column::IpAddress:
|
||||
return { 80, TextAlignment::CenterLeft };
|
||||
case Column::PacketsIn:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::PacketsOut:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::BytesIn:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::BytesOut:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
GVariant NetworkAdapterModel::data(const GModelIndex& index, Role role) const
|
||||
{
|
||||
auto& adapter_object = m_netadapters.at(index.row()).as_object();
|
||||
if (role == GModel::Role::Display) {
|
||||
switch (index.column()) {
|
||||
case Column::Name:
|
||||
return adapter_object.get("name").to_string();
|
||||
case Column::ClassName:
|
||||
return adapter_object.get("class_name").to_string();
|
||||
case Column::MacAddress:
|
||||
return adapter_object.get("mac_address").to_string();
|
||||
case Column::IpAddress:
|
||||
return adapter_object.get("ipv4_address").to_string();
|
||||
case Column::PacketsIn:
|
||||
return adapter_object.get("packets_in").to_u32();
|
||||
case Column::PacketsOut:
|
||||
return adapter_object.get("packets_out").to_u32();
|
||||
case Column::BytesIn:
|
||||
return adapter_object.get("bytes_in").to_u32();
|
||||
case Column::BytesOut:
|
||||
return adapter_object.get("bytes_out").to_u32();
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
}
|
||||
return {};
|
||||
}
|
|
@ -1,33 +0,0 @@
|
|||
#pragma once
|
||||
|
||||
#include <AK/JsonArray.h>
|
||||
#include <LibGUI/GModel.h>
|
||||
|
||||
class NetworkAdapterModel final : public GModel {
|
||||
public:
|
||||
enum Column {
|
||||
Name,
|
||||
ClassName,
|
||||
MacAddress,
|
||||
IpAddress,
|
||||
PacketsIn,
|
||||
PacketsOut,
|
||||
BytesIn,
|
||||
BytesOut,
|
||||
__Count
|
||||
};
|
||||
|
||||
static NonnullRefPtr<NetworkAdapterModel> create() { return adopt(*new NetworkAdapterModel); }
|
||||
virtual ~NetworkAdapterModel() override {}
|
||||
|
||||
virtual int row_count(const GModelIndex& = GModelIndex()) const override;
|
||||
virtual int column_count(const GModelIndex& = GModelIndex()) const override { return Column::__Count; }
|
||||
virtual String column_name(int) const override;
|
||||
virtual ColumnMetadata column_metadata(int) const override;
|
||||
virtual GVariant data(const GModelIndex&, Role = Role::Display) const override;
|
||||
virtual void update() override;
|
||||
|
||||
private:
|
||||
NetworkAdapterModel() {}
|
||||
JsonArray m_netadapters;
|
||||
};
|
|
@ -1,8 +1,7 @@
|
|||
#include "NetworkStatisticsWidget.h"
|
||||
#include "NetworkAdapterModel.h"
|
||||
#include "SocketModel.h"
|
||||
#include <LibGUI/GBoxLayout.h>
|
||||
#include <LibGUI/GGroupBox.h>
|
||||
#include <LibGUI/GJsonArrayModel.h>
|
||||
#include <LibGUI/GTableView.h>
|
||||
|
||||
NetworkStatisticsWidget::NetworkStatisticsWidget(GWidget* parent)
|
||||
|
@ -21,7 +20,18 @@ NetworkStatisticsWidget::NetworkStatisticsWidget(GWidget* parent)
|
|||
|
||||
m_adapter_table_view = new GTableView(adapters_group_box);
|
||||
m_adapter_table_view->set_size_columns_to_fit_content(true);
|
||||
m_adapter_table_view->set_model(NetworkAdapterModel::create());
|
||||
|
||||
Vector<GJsonArrayModel::FieldSpec> net_adapters_fields = {
|
||||
{ "name", "Name", TextAlignment::CenterLeft },
|
||||
{ "class_name", "Class", TextAlignment::CenterLeft },
|
||||
{ "mac_address", "MAC", TextAlignment::CenterLeft },
|
||||
{ "ipv4_address", "IPv4", TextAlignment::CenterLeft },
|
||||
{ "packets_in", "Pkt In", TextAlignment::CenterRight },
|
||||
{ "packets_out", "Pkt Out", TextAlignment::CenterRight },
|
||||
{ "bytes_in", "Bytes In", TextAlignment::CenterRight },
|
||||
{ "bytes_out", "Bytes Out", TextAlignment::CenterRight },
|
||||
};
|
||||
m_adapter_table_view->set_model(GJsonArrayModel::create("/proc/net/adapters", move(net_adapters_fields)));
|
||||
|
||||
auto* sockets_group_box = new GGroupBox("Sockets", this);
|
||||
sockets_group_box->set_layout(make<GBoxLayout>(Orientation::Vertical));
|
||||
|
@ -31,7 +41,21 @@ NetworkStatisticsWidget::NetworkStatisticsWidget(GWidget* parent)
|
|||
|
||||
m_socket_table_view = new GTableView(sockets_group_box);
|
||||
m_socket_table_view->set_size_columns_to_fit_content(true);
|
||||
m_socket_table_view->set_model(SocketModel::create());
|
||||
|
||||
Vector<GJsonArrayModel::FieldSpec> net_tcp_fields = {
|
||||
{ "peer_address", "Peer", TextAlignment::CenterLeft },
|
||||
{ "peer_port", "Port", TextAlignment::CenterRight },
|
||||
{ "local_address", "Local", TextAlignment::CenterLeft },
|
||||
{ "local_port", "Port", TextAlignment::CenterRight },
|
||||
{ "state", "State", TextAlignment::CenterLeft },
|
||||
{ "ack_number", "Ack#", TextAlignment::CenterRight },
|
||||
{ "sequence_number", "Seq#", TextAlignment::CenterRight },
|
||||
{ "packets_in", "Pkt In", TextAlignment::CenterRight },
|
||||
{ "packets_out", "Pkt Out", TextAlignment::CenterRight },
|
||||
{ "bytes_in", "Bytes In", TextAlignment::CenterRight },
|
||||
{ "bytes_out", "Bytes Out", TextAlignment::CenterRight },
|
||||
};
|
||||
m_socket_table_view->set_model(GJsonArrayModel::create("/proc/net/tcp", move(net_tcp_fields)));
|
||||
|
||||
m_update_timer = new CTimer(
|
||||
1000, [this] {
|
||||
|
|
|
@ -1,120 +0,0 @@
|
|||
#include "SocketModel.h"
|
||||
#include <AK/JsonObject.h>
|
||||
#include <AK/StringBuilder.h>
|
||||
#include <LibCore/CFile.h>
|
||||
|
||||
void SocketModel::update()
|
||||
{
|
||||
CFile file("/proc/net/tcp");
|
||||
if (!file.open(CIODevice::ReadOnly)) {
|
||||
dbg() << "Unable to open " << file.filename();
|
||||
return;
|
||||
}
|
||||
|
||||
auto json = JsonValue::from_string(file.read_all());
|
||||
|
||||
ASSERT(json.is_array());
|
||||
m_sockets = json.as_array();
|
||||
|
||||
did_update();
|
||||
}
|
||||
|
||||
int SocketModel::row_count(const GModelIndex&) const
|
||||
{
|
||||
return m_sockets.size();
|
||||
}
|
||||
|
||||
String SocketModel::column_name(int column) const
|
||||
{
|
||||
switch (column) {
|
||||
case Column::PeerAddress:
|
||||
return "Peer";
|
||||
case Column::PeerPort:
|
||||
return "Port";
|
||||
case Column::LocalAddress:
|
||||
return "Local";
|
||||
case Column::LocalPort:
|
||||
return "Port";
|
||||
case Column::State:
|
||||
return "State";
|
||||
case Column::SeqNumber:
|
||||
return "Seq#";
|
||||
case Column::AckNumber:
|
||||
return "Ack#";
|
||||
case Column::PacketsIn:
|
||||
return "Pkt In";
|
||||
case Column::PacketsOut:
|
||||
return "Pkt Out";
|
||||
case Column::BytesIn:
|
||||
return "Bytes In";
|
||||
case Column::BytesOut:
|
||||
return "Bytes Out";
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
}
|
||||
|
||||
GModel::ColumnMetadata SocketModel::column_metadata(int column) const
|
||||
{
|
||||
switch (column) {
|
||||
case Column::PeerAddress:
|
||||
return { 80, TextAlignment::CenterLeft };
|
||||
case Column::PeerPort:
|
||||
return { 30, TextAlignment::CenterRight };
|
||||
case Column::LocalAddress:
|
||||
return { 80, TextAlignment::CenterLeft };
|
||||
case Column::LocalPort:
|
||||
return { 30, TextAlignment::CenterRight };
|
||||
case Column::State:
|
||||
return { 80, TextAlignment::CenterLeft };
|
||||
case Column::AckNumber:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::SeqNumber:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::PacketsIn:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::PacketsOut:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::BytesIn:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
case Column::BytesOut:
|
||||
return { 60, TextAlignment::CenterRight };
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
return {};
|
||||
}
|
||||
|
||||
GVariant SocketModel::data(const GModelIndex& index, Role role) const
|
||||
{
|
||||
auto& socket_object = m_sockets.at(index.row()).as_object();
|
||||
if (role == GModel::Role::Display) {
|
||||
switch (index.column()) {
|
||||
case Column::PeerAddress:
|
||||
return socket_object.get("peer_address").to_string();
|
||||
case Column::PeerPort:
|
||||
return socket_object.get("peer_port").to_u32();
|
||||
case Column::LocalAddress:
|
||||
return socket_object.get("local_address").to_string();
|
||||
case Column::LocalPort:
|
||||
return socket_object.get("local_port").to_u32();
|
||||
case Column::State:
|
||||
return socket_object.get("state").to_string();
|
||||
case Column::AckNumber:
|
||||
return socket_object.get("ack_number").to_u32();
|
||||
case Column::SeqNumber:
|
||||
return socket_object.get("sequence_number").to_u32();
|
||||
case Column::PacketsIn:
|
||||
return socket_object.get("packets_in").to_u32();
|
||||
case Column::PacketsOut:
|
||||
return socket_object.get("packets_out").to_u32();
|
||||
case Column::BytesIn:
|
||||
return socket_object.get("bytes_in").to_u32();
|
||||
case Column::BytesOut:
|
||||
return socket_object.get("bytes_out").to_u32();
|
||||
default:
|
||||
ASSERT_NOT_REACHED();
|
||||
}
|
||||
}
|
||||
return {};
|
||||
}
|
|
@ -1,38 +0,0 @@
|
|||
#pragma once
|
||||
|
||||
#include <AK/JsonArray.h>
|
||||
#include <LibGUI/GModel.h>
|
||||
|
||||
class SocketModel final : public GModel {
|
||||
public:
|
||||
enum Column {
|
||||
PeerAddress,
|
||||
PeerPort,
|
||||
LocalAddress,
|
||||
LocalPort,
|
||||
State,
|
||||
AckNumber,
|
||||
SeqNumber,
|
||||
PacketsIn,
|
||||
PacketsOut,
|
||||
BytesIn,
|
||||
BytesOut,
|
||||
__Count
|
||||
};
|
||||
|
||||
static NonnullRefPtr<SocketModel> create() { return adopt(*new SocketModel); }
|
||||
|
||||
virtual ~SocketModel() override {}
|
||||
|
||||
virtual int row_count(const GModelIndex& = GModelIndex()) const override;
|
||||
virtual int column_count(const GModelIndex& = GModelIndex()) const override { return Column::__Count; }
|
||||
virtual String column_name(int) const override;
|
||||
virtual ColumnMetadata column_metadata(int) const override;
|
||||
virtual GVariant data(const GModelIndex&, Role = Role::Display) const override;
|
||||
virtual void update() override;
|
||||
|
||||
private:
|
||||
SocketModel() {}
|
||||
|
||||
JsonArray m_sockets;
|
||||
};
|
Loading…
Reference in a new issue