Skip to content

Commit

Permalink
Merge pull request #40 from nimh-dsst/some-deployment-fixes
Browse files Browse the repository at this point in the history
deployment fixes
  • Loading branch information
leej3 authored Aug 25, 2024
2 parents 91cc930 + 685face commit 9bd22da
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 76 deletions.
2 changes: 2 additions & 0 deletions pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ keywords = [
]
dynamic = ["version"]
dependencies = [
"pandas",
"pyarrow",
"pydantic",
"pydantic[email]",
"odmantic",
Expand Down
9 changes: 5 additions & 4 deletions web/dashboard/Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,13 @@ FROM tiangolo/uvicorn-gunicorn:python3.11

WORKDIR /app

RUN mkdir -p /opt/data
ENV LOCAL_DATA_PATH=/opt/data/dashboard_data.feather
COPY ./tempdata/dashboard_data.feather /opt/data/dashboard_data.feather

# Create the environment
RUN pip install holoviews panel pymongo odmantic pandas pyarrow pydantic[email]
RUN pip install panel pymongo odmantic pandas pydantic[email] pyarrow

RUN mkdir -p /opt/data
ENV LOCAL_DATA_PATH=/opt/data/matches.parquet
COPY ./tempdata/matches.parquet /opt/data/matches.parquet

RUN mkdir -p /opt/osm
COPY pyproject.toml /opt/osm
Expand Down
98 changes: 26 additions & 72 deletions web/dashboard/app.py
Original file line number Diff line number Diff line change
@@ -1,76 +1,42 @@
import os
from pathlib import Path

import pandas as pd
import panel as pn
import param
import pyarrow as pa
import pyarrow.dataset as ds
import ui
from main_dashboard import MainDashboard
from odmantic import SyncEngine
from pymongo import MongoClient
from pyarrow import compute as pc

from osm import schemas


def flatten_dict(d):
"""
Recursively flattens a nested dictionary without prepending parent keys.
:param d: Dictionary to flatten.
:return: Flattened dictionary.
"""
items = []
for k, v in d.items():
if isinstance(v, dict):
# If the value is a dictionary, flatten it without the parent key
items.extend(flatten_dict(v).items())
else:
items.append((k, v))
return dict(items)
from osm.schemas import schema_helpers as osh


def load_data():
local_path = os.environ.get("LOCAL_DATA_PATH")
if local_path is not None and Path(local_path).exists():
# return pd.read_feather(local_path)

return ds.dataset(local_path, format="parquet").to_table().to_pandas()
client = MongoClient(os.environ["MONGODB_URI"])
engine = SyncEngine(client=client, database="osm")
matches = (
engine.get_collection(schemas.Invocation)
.aggregate(
[
{
"$match": {
"osm_version": {"$eq": "0.0.1"},
# "work.pmid": {"$regex":r"^2"},
# "metrics.year": {"$gt": 2000},
# "metrics.is_data_pred": {"$eq": True},
},
},
{
"$project": {
# "osm_version": True,
"funder": True,
"data_tags": True,
"work.pmid": True,
"metrics.year": True,
"metrics.is_code_pred": True,
"metrics.is_data_pred": True,
"metrics.affiliation_country": True,
"metrics.journal": True,
"created_at": True,
},
},
]
)
.__iter__()
dset = ds.dataset(local_path, format="parquet")
else:
dset = ds.dataset(osh.matches_to_table(osh.get_data_from_mongo()))

tb = dset.to_table()
split_col = pc.split_pattern(
pc.if_else(
pc.is_null(tb["affiliation_country"]),
pa.scalar(""),
tb["affiliation_country"],
),
pattern=";",
)
tb = tb.set_column(
tb.column_names.index("affiliation_country"),
"affiliation_country",
pa.array(split_col, type=pa.list_(pa.string())),
)
df = pd.DataFrame(flatten_dict(match) for match in matches)
df.to_feather(local_path)
return df
raw_data = tb.to_pandas()
raw_data["metrics"] = "RTransparent"
raw_data = raw_data[raw_data.year >= 2000]
return raw_data


class OSMApp(param.Parameterized):
Expand Down Expand Up @@ -100,8 +66,8 @@ def get_template(self):
"""

template = pn.template.FastListTemplate(
site="NIH",
title="OpenSciMetrics",
site="OpenSciMetrics",
title="Measuring Open Science",
favicon="https://www.nih.gov/favicon.ico",
sidebar=[],
accent=ui.MAIN_COLOR,
Expand Down Expand Up @@ -163,18 +129,6 @@ def on_load():
pn.config.notifications = True
raw_data = load_data()

# Harcoded for now, will be added to the raw data later
raw_data["metrics"] = "RTransparent"

# Cleanup - might be handlded upstream in the future
raw_data.affiliation_country = raw_data.affiliation_country.apply(
lambda cntry: (
tuple(set(map(str.strip, cntry.split(";")))) if cntry is not None else cntry
)
)

raw_data = raw_data[raw_data.year >= 2000]

pn.state.cache["data"] = raw_data


Expand Down

0 comments on commit 9bd22da

Please sign in to comment.