mirror of
https://github.com/neon-mmd/websurfx.git
synced 2024-11-21 13:38:21 -05:00
commit
34047fcf27
34
CONTRIBUTING.md
Normal file
34
CONTRIBUTING.md
Normal file
@ -0,0 +1,34 @@
|
||||
# Things to Consider Before Contributing
|
||||
|
||||
## Knowledge Required
|
||||
|
||||
- Rust basics
|
||||
- Actix-web crate basics
|
||||
- Tokio crate and async/await
|
||||
- Reqwest crate basics
|
||||
- Serde and serde~json~ crate basics
|
||||
- fake~useragent~ crate basics
|
||||
- pyo3/hlua/rlua crates basics
|
||||
|
||||
## Guidelines
|
||||
|
||||
- Please be patient.
|
||||
|
||||
- Treat everyone with respect -- \"give respect and take respect.\"
|
||||
|
||||
- Document your code properly with Rust coding conventions in mind.
|
||||
|
||||
- Provide a brief description of the changes you made in the pull
|
||||
request.
|
||||
|
||||
- Provide an appropriate header for the pull request.
|
||||
|
||||
**NOTE:** The rolling branch is where all contributions should go.
|
||||
In other words, it is the working branch for this project.
|
||||
|
||||
We appreciate any contributions and suggestions to help improve the
|
||||
Websurfx project. Please keep in mind the above requirements and
|
||||
guidelines before submitting a pull request and also if you have any
|
||||
doubts/concerns/questions about the project, its source code or anything
|
||||
related to the project than feel free to ask by opening an
|
||||
\[issue\](<https://github.com/neon-mmd/websurfx/issues>).
|
@ -1,22 +0,0 @@
|
||||
* Things to Consider Before Contributing
|
||||
|
||||
** Knowledge Required
|
||||
- Rust basics
|
||||
- Actix-web crate basics
|
||||
- Tokio crate and async/await
|
||||
- Reqwest crate basics
|
||||
- Serde and serde_json crate basics
|
||||
- fake_useragent crate basics
|
||||
- pyo3/hlua/rlua crates basics
|
||||
|
||||
** Guidelines
|
||||
|
||||
- Please be patient.
|
||||
- Treat everyone with respect -- "give respect and take respect."
|
||||
- Document your code properly with Rust coding conventions in mind.
|
||||
- Provide a brief description of the changes you made in the pull request.
|
||||
- Provide an appropriate header for the pull request.
|
||||
|
||||
*NOTE:* The rolling branch is where all contributions should go. In other words, it is the working branch for this project.
|
||||
|
||||
We appreciate any contributions and suggestions to help improve the Websurfx project. Please keep in mind the above requirements and guidelines before submitting a pull request and also if you have any doubts/concerns/questions about the project, its source code or anything related to the project than feel free to ask by opening an [issue](https://github.com/neon-mmd/websurfx/issues).
|
273
README.md
Normal file
273
README.md
Normal file
@ -0,0 +1,273 @@
|
||||
<h1 align="center">Websurfx</h1>
|
||||
<p align="center">
|
||||
<i>
|
||||
A modern-looking, lightning-fast, privacy-respecting, secure
|
||||
<a href="https://en.wikipedia.org/wiki/Metasearch_engine"
|
||||
>meta search engine</a
|
||||
>
|
||||
(pronounced as websurface or web-surface /wɛbˈsɜːrfəs/.) written in Rust. It
|
||||
provides a fast and secure search experience while respecting user
|
||||
privacy.</i
|
||||
>
|
||||
<br />
|
||||
<br />
|
||||
<img align="center" width="500px" src="./images/intro.png" />
|
||||
<br />
|
||||
<br />
|
||||
<b align="center"><a href="README.org">Readme</a></b> |
|
||||
<b><a href="https://discord.gg/k4GH2TnZ">Discord</a></b> |
|
||||
<b><a href="https://github.com/neon-mmd/websurfx">GitHub</a></b> |
|
||||
<b><a href="https://github.com/neon-mmd/websurfx/wiki">Documentation</a></b>
|
||||
<br /><br />
|
||||
<a href="./LICENSE">
|
||||
<img
|
||||
alt="GitHub"
|
||||
src="https://img.shields.io/github/license/neon-mmd/websurfx?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
<a href="https://github.com/neon-mmd/websurfx/stargazers">
|
||||
<img
|
||||
alt="GitHub Repo stars"
|
||||
src="https://img.shields.io/github/stars/neon-mmd/websurfx?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
<a href="https://github.com/neon-mmd/websurfx/forks">
|
||||
<img
|
||||
alt="GitHub forks"
|
||||
src="https://img.shields.io/github/forks/neon-mmd/websurfx?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
<a href="#">
|
||||
<img
|
||||
alt="GitHub code size in bytes"
|
||||
src="https://img.shields.io/github/languages/code-size/neon-mmd/websurfx?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
<a href="https://github.com/neon-mmd/websurfx/issues">
|
||||
<img
|
||||
alt="GitHub issues"
|
||||
src="https://img.shields.io/github/issues/neon-mmd/websurfx?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
<a href="https://github.com/neon-mmd/websurfx/pulls">
|
||||
<img
|
||||
alt="GitHub pull requests"
|
||||
src="https://img.shields.io/github/issues-pr/neon-mmd/websurfx?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
<a href="https://github.com/neon-mmd/websurfx/actions">
|
||||
<img
|
||||
alt="GitHub Workflow Status"
|
||||
src="https://img.shields.io/github/actions/workflow/status/neon-mmd/websurfx/rust.yml?style=flat-square"
|
||||
/>
|
||||
</a>
|
||||
</p>
|
||||
|
||||
<details>
|
||||
<summary><b>Table of Contents</b></summary>
|
||||
<p>
|
||||
|
||||
- **Getting Started**
|
||||
- [🌈 Features](#features-)
|
||||
- [🔭 Preview](#preview-)
|
||||
- [🛠️ Installation and Testing](#installation-and-testing-)
|
||||
- [🔧 Configuration](#configuration-)
|
||||
- **Feature Overview**
|
||||
- [🎨 Theming](#theming-)
|
||||
- [🌍 Multi-Language Support](#multi-language-support-)
|
||||
- **Community**
|
||||
- [📊 System Requirements](#system-requirements-)
|
||||
- [🗨️ FAQ (Frequently Asked Questions)](#faq-frequently-asked-questions-)
|
||||
- [📣 More Contributers Wanted](#more-contributers-wanted-)
|
||||
- [💖 Supporting Websurfx](#supporting-websurfx-)
|
||||
- [📘 Documentation](#documentation-)
|
||||
- [🛣️ Roadmap](#roadmap-)
|
||||
- [🙋 Contributing](#contributing-)
|
||||
- [📜 License](#license-)
|
||||
- [🤝 Credits](#credits-)
|
||||
|
||||
</p>
|
||||
</details>
|
||||
|
||||
# Features 🌈
|
||||
|
||||
- ⛔ Proper NSFW blocking
|
||||
- 🎨 High level customizability with 9 colorchemes provided by default with a simple theme, also supporting creation of your custom themes and colorschemes very quickly and easily
|
||||
- 🔍 Advanced image search
|
||||
- 🔐 Fast, private and secure
|
||||
- 🆓 100% free and open source
|
||||
- 🌈 and lots more...
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Preview 🔭
|
||||
|
||||
## Main Page
|
||||
|
||||
<img align="center" src="./images/main_page.png" />
|
||||
|
||||
## Search Page
|
||||
|
||||
<img align="center" src="./images/search_page.png" />
|
||||
|
||||
## 404 Error Page
|
||||
|
||||
<img align="center" src="./images/404_error_page.png" />
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Installation and Testing 🛠️
|
||||
|
||||
> For full setup instructions, see: [**Installation**]()
|
||||
|
||||
To get started with Websurfx, clone the repository, edit the config file which is located in the `websurfx`{.verbatim} directory and install redis server by following the instructions located [here](https://redis.io/docs/getting-started/) and then run the websurfx server and redis server using the following commands:
|
||||
|
||||
``` shell
|
||||
git clone https://github.com/neon-mmd/websurfx.git
|
||||
cd websurfx
|
||||
cargo build
|
||||
redis-server -p 8082 &
|
||||
./target/debug/websurfx
|
||||
```
|
||||
|
||||
If you want to use the rolling/edge branch, run the following commands instead:
|
||||
|
||||
``` shell
|
||||
git clone https://github.com/neon-mmd/websurfx.git
|
||||
cd websurfx
|
||||
git checkout rolling
|
||||
cargo build
|
||||
redis-server -p 8082 &
|
||||
./target/debug/websurfx
|
||||
```
|
||||
|
||||
Once you have started the server, open your preferred web browser and navigate to <http://127.0.0.1:8080> to start using Websurfx.
|
||||
|
||||
> **Warning**
|
||||
> Please be aware that the project is still in the testing phase and is not ready for production use.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Configuration 🔧
|
||||
|
||||
> For full configuration instructions, see: [**Configuration**]()
|
||||
|
||||
Websurfx is configured through the config.lua file, located at `websurfx/config.lua`.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Theming 🎨
|
||||
|
||||
> For full theming and customization instructions, see: [**Theming**]()
|
||||
|
||||
Websurfx comes with several themes and colorschemes by default which you can apply and edit through the config file. Support for custom themes and colorschemes using css and develop your own unique-looking website.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Multi-Language Support 🌍
|
||||
|
||||
> **Note**
|
||||
> Currently, we do not support other languages but in future we would start accepting contributions regarding language support because we believe that language should not be a barrier for entry.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# System Requirements 📊
|
||||
|
||||
At present, we only support x86_64 architecture systems but will love to have contributions to extend to other architectures as well.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# FAQ (Frequently Asked Questions) 🗨️
|
||||
|
||||
## Why Websurfx?
|
||||
|
||||
The main goal of the Websurfx project is to provide a fast, secure, and privacy-focused [meta search engine](https://en.wikipedia.org/wiki/Metasearch_engine). While there are many meta search engines available, they do not always guarantee the security of their search engine, which is essential for ensuring privacy. For example, memory vulnerabilities can leak private or sensitive information, which is never good. Websurfx is written in Rust, which guarantees memory safety and eliminates such problems. Many meta search engines also lack key features such as advanced image search, which is required by many graphic designers, content creators, and others. Websurfx aims to provide these features and others, such as proper NSFW blocking, to improve the user experience.
|
||||
|
||||
## Why AGPLv3?
|
||||
|
||||
Websurfx is released under the **AGPLv3** license to ensure that the source code remains open and transparent. This helps to prevent the inclusion of spyware, telemetry, or other malicious code in the project. **AGPLv3** is a strong copyleft license that ensures the source code of the software remains open and available to everyone, including any modifications or improvements made to the code.
|
||||
|
||||
## Why Rust?
|
||||
|
||||
Rust was chosen as the programming language for Websurfx due to its memory safety features, which can help prevent vulnerabilities and make the codebase more secure. Rust is also faster than C++, which helps to make Websurfx fast and responsive. In addition, Rust\'s ownership and borrowing system allows for safe concurrency and thread safety in the codebase.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# More Contributers Wanted 📣
|
||||
|
||||
We are looking for more willing contributors to help grow this project.For more information on how you can contribute, check out the [project board](https://github.com/neon-mmd/websurfx/projects?query=is%3Aopen) and the [CONTRIBUTING.org](CONTRIBUTING.org) file for guidelines and rules for making contributions.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Supporting Websurfx 💖
|
||||
|
||||
> For full details and other ways you can help out, see: [**Contributing**]()
|
||||
|
||||
If you're using Dashy and would like to help support its development, then that would be awesome! Contributions of any type, any size, are always very much appreciated, and we will appropriately credit you for your effort.
|
||||
|
||||
Several areas that we need a bit of help with at the moment are:
|
||||
- **Better and more colorchemes** - Help fix colorchemes and add other famous colorchemes.
|
||||
- **Improve evasion code for bot detection** - Help improve code related to evade ip blocking and emulate human behaviours located in everyone engine file.
|
||||
- **Logo** - Help create a logo for the project and website.
|
||||
- **Docker Support** - Help write a docker compose file for the project.
|
||||
- Submit a PR to add a new feature, fix a bug, update the docs, add a theme, widget or something else.
|
||||
- Star Websurfx on GitHub.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Documentation 📘
|
||||
|
||||
> **Note**
|
||||
> We are willing to have any contribution regarding [documentation](https://github.com/neon-mmd/websurfx/wiki) as this helps everyone using this project.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Roadmap 🛣️
|
||||
|
||||
> Coming soon!! 🙂.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Contributing 🙋
|
||||
|
||||
Contributions are welcome from anyone. It doesn\'t matter who you are; you can still contribute to the project in your way.
|
||||
|
||||
## Not a developer but still want to contribute?
|
||||
|
||||
Check out this [video](https://youtu.be/FccdqCucVSI) by Mr. Nick on how to contribute.
|
||||
|
||||
## Developer
|
||||
|
||||
If you are a developer, have a look at the [CONTRIBUTING.org](CONTRIBUTING.org) document for more information.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# License 📜
|
||||
|
||||
Websurfx is available under the [AGPLv3](LICENSE) license.
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
# Credits 🤝
|
||||
|
||||
We would like to thank the following people for their contributions and support:
|
||||
|
||||
<p>
|
||||
<br />
|
||||
<a href="https://github.com/neon-mmd/websurfx/graphs/contributors">
|
||||
<img src="https://contrib.rocks/image?repo=neon-mmd/websurfx" />
|
||||
</a>
|
||||
<br />
|
||||
</p>
|
||||
|
||||
**[⬆️ Back to Top](#websurfx)**
|
||||
|
||||
---
|
||||
|
||||
<p align="center">
|
||||
<a href="https://github.com/neon-mmd/websurfx">
|
||||
<img src="https://github.githubassets.com/images/icons/emoji/octocat.png" />
|
||||
</a>
|
||||
<br /><br />
|
||||
<i>Thank you for Visiting</i>
|
||||
</p>
|
137
README.org
137
README.org
@ -1,137 +0,0 @@
|
||||
#+html: <h1 align="center">Websurfx</h1>
|
||||
#+html: <p align="center">
|
||||
#+html: <i> A lightning-fast, privacy-respecting, secure <a href="https://en.wikipedia.org/wiki/Metasearch_engine">meta search engine</a> (pronounced as websurface or web-surface /wɛbˈsɜːrfəs/.) written in Rust. It provides a fast and secure search experience while respecting user privacy.</i>
|
||||
#+html: <br/>
|
||||
#+html: <br/>
|
||||
#+html: <b align="center"><a href="README.org">Readme</a></b> | <b><a href="https://discord.gg/k4GH2TnZ">Discord</a></b> | <b><a href="https://github.com/neon-mmd/websurfx">GitHub</a></b>
|
||||
#+html: <br/><br/>
|
||||
#+html: <!---add status badges here---->
|
||||
#+html: </p>
|
||||
|
||||
* Table of Contents
|
||||
|
||||
- [[#features][Features]]
|
||||
- [[#preview][Preview]]
|
||||
- [[#main-page][Main Page]]
|
||||
- [[#search-page][Search Page]]
|
||||
- [[#404-error-page][404 Error Page]]
|
||||
- [[#installation-and-testing][Installation and Testing]]
|
||||
- [[#more-contributers-wanted][More Contributers Wanted]]
|
||||
- [[#faq-frequently-asked-questions][FAQ - (Frequently Asked Questions)]]
|
||||
- [[#why-websurfx][Why Websurfx?]]
|
||||
- [[#why-agplv3][Why AGPLv3?]]
|
||||
- [[#why-rust][Why Rust?]]
|
||||
- [[#contributing][Contributing]]
|
||||
- [[#not-a-developer-but-still-want-to-contribute][Not a developer but still want to contribute]]
|
||||
- [[#developer][Developer]]
|
||||
- [[#license][License]]
|
||||
- [[#credits][Credits]]
|
||||
|
||||
* Features
|
||||
|
||||
- Proper NSFW blocking
|
||||
- High level customizability with 9 colorchemes provided by default with a simple theme, also supporting creation of your custom themes and colorschemes very quickly and easily
|
||||
- Advanced image search
|
||||
- Fast, private and secure
|
||||
- 100% free and open source
|
||||
- and lots more...
|
||||
|
||||
* Preview
|
||||
|
||||
** Main Page
|
||||
|
||||
#+html: <img align="center" src="./images/main_page.png" />
|
||||
|
||||
** Search Page
|
||||
|
||||
#+html: <img align="center" src="./images/search_page.png" />
|
||||
|
||||
** 404 Error Page
|
||||
|
||||
#+html: <img align="center" src="./images/404_error_page.png" />
|
||||
|
||||
* Installation and Testing
|
||||
|
||||
To get started with Websurfx, clone the repository, edit the config file which is located in the =websurfx= directory and install redis server by following the instructions located [[https://redis.io/docs/getting-started/][here]] and then run the websurfx server and redis server using the following commands:
|
||||
|
||||
#+begin_src shell
|
||||
git clone https://github.com/neon-mmd/websurfx.git
|
||||
cd websurfx
|
||||
cargo build
|
||||
redis-server -p 8082 &
|
||||
./target/debug/websurfx
|
||||
#+end_src
|
||||
|
||||
If you want to use the rolling/edge branch, run the following commands instead:
|
||||
|
||||
#+begin_src shell
|
||||
git clone https://github.com/neon-mmd/websurfx.git
|
||||
cd websurfx
|
||||
git checkout rolling
|
||||
cargo build
|
||||
redis-server -p 8082 &
|
||||
./target/debug/websurfx
|
||||
#+end_src
|
||||
|
||||
Once you have started the server, open your preferred web browser and navigate to http://127.0.0.1:8080 to start using Websurfx.
|
||||
|
||||
*Important Note:* Please be aware that the project is still in the testing phase and is not ready for production use.
|
||||
|
||||
* Configuration
|
||||
|
||||
Websurfx is configured through the config.lua file, located at =websurfx/config.lua=.
|
||||
|
||||
* Theming
|
||||
|
||||
Websurfx comes with several themes and colorschemes by default which you can apply and edit through the config file. Support for custom themes and colorschemes using css and develop your own unique-looking website.
|
||||
|
||||
* More Contributers Wanted
|
||||
|
||||
We are looking for more willing contributors to help grow this project. For more information on how you can contribute, check out the [[https://github.com/neon-mmd/websurfx/projects?query=is%3Aopen][project board]] and the [[file:CONTRIBUTING.org][CONTRIBUTING.org]] file for guidelines and rules for making contributions.
|
||||
|
||||
* FAQ (Frequently Asked Questions)
|
||||
|
||||
** Why Websurfx?
|
||||
|
||||
The main goal of the Websurfx project is to provide a fast, secure, and privacy-focused [[https://en.wikipedia.org/wiki/Metasearch_engine][meta search engine]]. While there are many meta search engines available, they do not always guarantee the security of their search engine, which is essential for ensuring privacy. For example, memory vulnerabilities can leak private or sensitive information, which is never good. Websurfx is written in Rust, which guarantees memory safety and eliminates such problems. Many meta search engines also lack key features such as advanced image search, which is required by many graphic designers, content creators, and others. Websurfx aims to provide these features and others, such as proper NSFW blocking, to improve the user experience.
|
||||
|
||||
** Why AGPLv3?
|
||||
|
||||
Websurfx is released under the *AGPLv3* license to ensure that the source code remains open and transparent. This helps to prevent the inclusion of spyware, telemetry, or other malicious code in the project. *AGPLv3* is a strong copyleft license that ensures the source code of the software remains open and available to everyone, including any modifications or improvements made to the code.
|
||||
|
||||
** Why Rust?
|
||||
|
||||
Rust was chosen as the programming language for Websurfx due to its memory safety features, which can help prevent vulnerabilities and make the codebase more secure. Rust is also faster than C++, which helps to make Websurfx fast and responsive. In addition, Rust's ownership and borrowing system allows for safe concurrency and thread safety in the codebase.
|
||||
|
||||
* Contributing
|
||||
|
||||
Contributions are welcome from anyone. It doesn't matter who you are; you can still contribute to the project in your way.
|
||||
|
||||
** Not a developer but still want to contribute?
|
||||
|
||||
Check out this [[https://youtu.be/FccdqCucVSI][video]] by Mr. Nick on how to contribute.
|
||||
|
||||
** Developer
|
||||
|
||||
If you are a developer, have a look at the [[file:CONTRIBUTING.org][CONTRIBUTING.org]] document for more information.
|
||||
|
||||
* License
|
||||
|
||||
Websurfx is available under the [[file:LICENSE][AGPLv3]] license.
|
||||
|
||||
* Credits
|
||||
|
||||
We would like to thank the following people for their contributions and support:
|
||||
|
||||
#+html: <a href="https://github.com/neon-mmd/websurfx/graphs/contributors">
|
||||
#+html: <img src="https://contrib.rocks/image?repo=neon-mmd/websurfx" />
|
||||
#+html: </a>
|
||||
|
||||
#+html: <br/>
|
||||
#+html: <p align="center">
|
||||
#+html: <a href="https://github.com/neon-mmd/websurfx">
|
||||
#+html: <img src="https://github.githubassets.com/images/icons/emoji/octocat.png" />
|
||||
#+html: </a>
|
||||
#+html: <br><br>
|
||||
#+html: <i>Thank you for Visiting</i>
|
||||
#+html: </p>
|
15
goals.org
15
goals.org
@ -1,15 +0,0 @@
|
||||
* Goals for future development
|
||||
|
||||
- Replace Handlebars with the faster templating engine /Tera/.
|
||||
|
||||
- Add more upstream search engines.
|
||||
|
||||
- Implement dorking support (like Google).
|
||||
|
||||
- Add advanced search functionality and a dropdown menu for it.
|
||||
|
||||
- Add more categories to the search engine's search page, such as images, files, news, and maps.
|
||||
|
||||
- Add advanced image functionality for content creators, video editors, etc.
|
||||
|
||||
- Add GPT integration, taking inspiration from the Langchain module of Python or incorporating it using pyo3, and give users the choice to add an API key. Giving users the choice is important, as some people may be against AI, and this will ensure that those users who don't want to use GPT can disable it by not adding an API key.
|
BIN
images/intro.png
Normal file
BIN
images/intro.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 11 KiB |
Loading…
Reference in New Issue
Block a user