Skip to content

suyashvsingh/rce70-next

Repository files navigation


Logo

Remote Code Executor

About The Project

Product Name Screen Shot

Users can run code on the web without having to install any IDE or text editor. And it's free! The user can also download the code. The app currently supports five languages: C++, C, Python, Java and Javascript. The app is hosted on Vercel. The app is also serverless and uses AWS Lambda to run the code.

Tools Used

Next Tailwind AWS Vercel

Packages Used

  1. Axios
  2. Monaco Editor
  3. React Hot Toast
  4. React Icons
  5. React Select
  6. React Spinners
  7. js-file-download

Live Demo

https://rce70.vercel.app: Frontend hosted on Vercel and uses AWS Lambda serverless service

Main Features

  1. Multiple language support

    javascript python c++ c java

  2. There are three text editors: one for the code, one for the input and one for the output

  3. The code can be run using the Run button or Alt + Enter key

  4. The user can reset the code using the Reset button

  5. The user can download the code using the Download button

Thought behind the project

  1. Researchers could use a Remote Code Executor app to test the security of different applications or systems without having to run potentially dangerous code on their machines.

  2. Developers could use a Remote Code Executor app to quickly test code snippets or entire applications in a controlled environment without having to set up a local development environment.

  3. A Remote Code Executor app could be helpful for teaching coding concepts and techniques, particularly for online courses or tutorials. Students could experiment with different code examples and receive immediate feedback without having to install anything locally.

Working

  1. The user writes the code in the code editor

  2. The user gives the input in the input editor

  3. The user clicks on the Run button or presses Alt</ kbd> + Enter key

  4. The code is sent to the server.

  5. The server creates a random file name and saves the code and input it into the file with the respective extensions.

  6. The server runs the code using the respective compiler or interpreter, with a timeout of 10 seconds.

  7. The server sends the status, data and execution time to the client.

  8. The client displays the output (or error, if any) and Execution time in the output editor.

Getting Started

Installation through Source Code

  1. Clone the repository

    git clone https://github.com/suyashvsingh/rce70-next.git
  2. Install NPM packages

    npm install
  3. Add the following to the .env.local file

    AWS_API_GATEWAY_URL={}
  4. Start the application

    npm run dev
  5. Application will run on PORT 3000

  6. Write the code and give any input (if required)

  7. Run the code using Run button or Alt + Enter key

Team 😃

Made with love by:

  1. Sanket Diwate (2020IMT-031)
  2. Ketan Prakash (2020IMT-044)
  3. Aditya Pote (2020IMT-069)
  4. Suyash Vikram Singh (2020IMT-104)