for the Hawaii Space Flight Laboratory, by Spencer Young
COSMOS Web is a JavaScript application built using Node.js for the application programmable interface (API) and React.js for the front-facing web interface. It was conceptualized and built into fruition to supplement mission operations tasks by visualizing incoming telemetery data from satellites such as position and attitude. In addition, the project was partially an experiment to test the capabilities and limitations of building an interface on JavaScript; after assessing its advantages, it became an exploitation of the ease of use and the expansive supporting ecosystem that the platform offers. For example, since this application is web based, it is hardware agnostic and accessed anywhere; the only requirement is to have access to the internet and a web browser. Not only is it hardware agnostic, but updates to the software requires a mere push to the code base, and nothing is required of the end-user, whereas a desktop application would require a download to update it.
git clone https://github.com/spjy/cosmos-web-server.git
cd cosmos-web-server
npm install
Duplicate the .env.example
file and name it .env
. Enter the correct values for each variable.
MONGO_URL=mongodb://url # URL to MongoDB server
SATELLITE_IP=127.0.0.1 # IP to receive telemetry live/historical data
npm start
client/
├── public/
├── src/
│ ├── components/
│ │ ├── Attitude/
│ │ ├── Global/
│ │ ├── Orbit/
│ │ ├── Path/
│ │ ├── Attitude.js
│ │ ├── Home.js
│ │ ├── Orbit.js
│ │ ├── Path.js
│ └───└── Plot.js
├── App.js
└── index.js
server/
├── middlware/
├── models/
├── resources/
└── routes/
The client is composed of the React.js frontend.
/public
contains static assets./src
contains the React.js source.
Inside /src
the root contains the main application.
index.js
contains React.js instance.App.js
contains the React Router routes. Import the page layouts in here.
Inside /src/components
the root contains the page layouts. Each page contains a corresponding folder where you can find the components unique to that page.
Inside /src/components/Global
contains shared components between pages.
The server is composed of Node.js with Express.js middleware.
/middleware
/models
/resources
/routes
Inside /middleware
contains reusable routing methods.
Inside /models
contains the database schemas.
Inside /resources
contains the API routes.
Inside /routes
contains the non-API routes.
COSMOS Web uses various frameworks to make development easier.
The primary framework used on the frontend is React.js, a JavaScript library to build user interfaces.
- React.js is being used primarily to assist with building with the user interface; it features object oriented and component reusability ideologies.
- React Router is a router that enables React to be a single page application.
- Redux is being used to deal with inter-component state management. States in React.js are easy to work with within components, but if they are shared between components, it's a chore; thus Redux aims to solve that.
- Babylon.js is a web based three dimensional rendering engine powered by WebGL. Bablyon is used to visualize the satellite's position, attitude and orientation.
The primary framework being used for the server is Express.js, a web application framework used to build APIs.
- Express.js is a server framework for Node.js
- MongoDB is a NoSQL database to store incoming data for data replay.
- Mongoose is a object relational mapper for MongoDB built for Node.js. This is used to apply methods (such as querying and filtering) on MongoDB
- socket.io is used for web socket communication for real time data updates.