npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

dana-core

v1.0.0-alpha.2

Published

Tools for processing and accessing different information types

Downloads

148

Readme

dana-core

Tools for processing and accessing different information types

Executables can be downloaded from https://github.com/commonknowledge/dana-core/releases

Developer quickstart

Nothing unorthodox here. Clone, run yarn to install dependencies and yarn start to run everything.

If you use vscode, you can optionally clone and run this repository in a development container. The GUI is accessible over vnc on port 5901 (password: vscode).

This project comes with a launch.json configuration for debugging the electron process. If using vscode, you can start this by running the default configuration (usually this can be done by hitting F5.

Developer how-tos:

Code structure

We have three high-level areas.

  • src/app – Backend code, running in a nodejs or 'electron main' environment lives here.
  • src/frontend – Frontend code, running in a browser or 'electron renderer' environment lives here.
  • src/common – Environment-agnostic code lives here.

In general, try to keep both frontend and backend code separate from anything electron specifc – if you must use electron APIs, wrap them in an API that could be used (or disabled) in non-electron environments.

The backend is subdivided into domain areas (asset, media, etc). Try to keep the interfaces between these relatively minimal and document them well. In particular, avoid making state changes in one domain that implicitly affect another (for example via database cascades).

Interfaces

The general patttern for communication between domains and between the app and its frontend is to have an interface file in src/common/*.interfaces.ts.

These should generally have a schema declaration associated with them (we use zod for schema validation) so that client-server environments can do data validation easily. Zod provides

IPC

We abstract communication between the frontend and backend into the FrontendIpc interface, which can support both electron's asynchronous message-passing paradigm and http.

This supports dispatching 'pubsub' events from the backend to the frontend and RPC-style calls. The RpcInterface and EventInterface types are used to identify specifc RPC calls and events in a typesafe way.

These are documented in src/common/ipc.interfaces.ts. See also examples in the other src/common/*.interface.ts files.

Generating migrations

Archives store their metadata in sqlite documents. We use MikroORM as an ORM to simplify this, which bundles Umzug for managing schema migrations. It's fairly straightforward, but please pay attention to its concept of a 'unit of work' if that is new to you.

Migrations can be auto-generated from entities (assuming the entity files follow the file naming convention of *entity.ts). To do this, run yarn make-migrations.

The state of the current database schema is tracked in a JSON file in the migrations directory. If you need to revert to a previous version of the schema for generating new migrations, you can take advantage of the fact that this is version controlled to do that.

Please do make sure that you squash any new migrations in your branch before opening a PR in order to keep them managable.

Release workflow

To cut a new release:

  • When the version is ready to test, increment the version number in package.json
  • Draft a new release. Set the “Tag version” to the value of version in package.json, and prefix it with v. “Release title” should be the same as the tag version.
  • For example, if package.json version is 1.0, your draft’s “Tag version” and “Release title” would be v1.0.
  • Push some commits. Every CI build will update the artifacts attached to this draft.
  • Once you are done, publish the release. GitHub will tag the latest commit for you.

Q&As

Jest tests are not finding migrations / entities

Clearing the cache should fix this

yarn jest --clearCache