Vultr DNS Manager
A modern, user-friendly interface for managing DNS records on Vultr's platform. Built with Next.js, TypeScript, and Tailwind CSS.
✨ Features
- 🔐 Secure API key management
- 🌐 Domain listing and management
- 📝 DNS record creation, editing, and deletion
- 🔄 Real-time updates
- 🌙 Dark/light theme support
- 📱 Responsive design for all devices
🖥️ Screenshots
Screenshots will be added here
🚀 Getting Started
Prerequisites
- Node.js 16.x or later
- npm or yarn
Installation
-
Clone the repository:
git clone https://github.com/yourusername/vultr-dns-manager.git cd vultr-dns-manager
-
Install dependencies:
npm install # or yarn install
-
Start the development server:
npm run dev # or yarn dev
-
Open http://localhost:3000 in your browser.
Docker Deployment
# Build the Docker image
docker build -t vultr-dns-manager .
# Run the container
docker run -p 3000:3000 vultr-dns-manager
🔧 Usage
- Enter your Vultr API key on the welcome screen
- Select a domain from the sidebar
- Manage DNS records in the main panel
- View API logs for troubleshooting
🏗️ Architecture
The application is built with a modern React stack:
- Next.js: For server-side rendering and API routes
- TypeScript: For type safety and better developer experience
- Tailwind CSS: For styling
- shadcn/ui: For UI components
- React Hook Form: For form handling
- Zod: For validation
📦 Project Structure
vultr-dns-manager/
├── app/ # Next.js app directory
│ ├── api/ # API routes
│ ├── layout.tsx # Root layout
│ └── page.tsx # Home page
├── components/ # React components
│ ├── ui/ # UI components
│ └── ... # Feature components
├── lib/ # Utility functions
├── public/ # Static assets
├── styles/ # Global styles
└── ... # Config files
🛠️ Development
Commands
npm run dev
: Start development servernpm run build
: Build for productionnpm run start
: Start production servernpm run lint
: Run ESLint
🤝 Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature
) - Commit your changes (
git commit -m 'Add some amazing feature'
) - Push to the branch (
git push origin feature/amazing-feature
) - Open a Pull Request
📄 License
This project is licensed under the MIT License - see the LICENSE file for details.
🙏 Acknowledgements
Description
Languages
TypeScript
98.4%
CSS
0.8%
Dockerfile
0.7%
JavaScript
0.1%