A web-based API client built using React.js, Tailwind CSS, and Vite and allows developers to create and manage API request collections, send requests, and view responses. Includes support for query parameters, headers, and request bodies.
SoRest provides a simplified, browser-based interface for interacting with RESTful and SOAP APIs. It allows developers to organize requests into collections, configure various request details (method, URL, query params, headers, body), send the requests through a local proxy to bypass CORS issues during development, and inspect the responses (body, headers, status, time, size). All collection data is persisted locally using the browser's localStorage.
- Frontend:
- React.js (v18+)
- JavaScript (JSX)
- Tailwind CSS (v3+)
- Vite
- Lucide React
- @uiw/react-codemirror
- axios
 
- Backend Proxy (for CORS):
- Node.js
- Express.js
- axios- To make requests from the proxy to the target API
- cors- Node.js CORS middleware
 
Follow these instructions to get a copy of the project up and running on your local machine for development and testing purposes.
- Node.js (v18 or later recommended)
- npm (v8+ recommended)
- 
Clone the repository: git clone https://github.com/rvg07/sorest.git cd sorest
- 
Install ALL dependencies: (this part installs React.js, Vite, Tailwind ....) npm install 
- 
Configure Environment Variables: - Rename the example environment .env.examplefile in.env.
- Edit the .envfile with your local settings. Pay attention to:- 
PROXY_PORT: the port your backend proxy server will run on (defaults to3001inproxy-server.jsif not set). Make very sure this doesn't clash with other services.
- 
VITE_BACKEND_PROXY_URL: the full URL your frontend should use to contact your backend proxy server (e.g.,http://localhost:3001/proxy-request). This is very important!
 
- 
 .env.exampleshould look something like this:# Port for the Vite frontend development server PORT=5173 # Backend Proxy Configuration PROXY_PORT=3001 # URL the frontend uses to talk to the BACKEND proxy VITE_BACKEND_PROXY_URL=http://localhost:3001/proxy-request 
- Rename the example environment 
- 
Start Both Servers: open a terminal in the project root and run the combined development script (assuming you've set up concurrentlyinpackage.jsonas shown previously):npm run dev This command should: - Start the Backend Proxy Server (listening on the port defined by PROXY_PORTin your.envfile, likely3001).
- Start the Frontend Vite Development Server (usually on http://localhost:5173or the next available port).
 
- Start the Backend Proxy Server (listening on the port defined by 
- 
Access the Application: in dev mode usually url is: http://localhost:5173.
- 
Usage: - When click "Send", the React app will make a request to the URL specified in VITE_BACKEND_PROXY_URL(http://localhost:3001/proxy-request).
- Backend proxy server will handle the request, contact the actual target API specified in the URL input field, and return the response.
 
- When click "Send", the React app will make a request to the URL specified in