mirror of
https://github.com/neon-mmd/websurfx.git
synced 2024-11-22 14:08:23 -05:00
Merge branch 'rolling' into improve-results-caching
This commit is contained in:
commit
272fdefff5
3
.gitpod.Dockerfile
vendored
Normal file
3
.gitpod.Dockerfile
vendored
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
FROM gitpod/workspace-rust
|
||||||
|
|
||||||
|
RUN sudo install-packages redis-server nodejs npm
|
34
.gitpod.yml
34
.gitpod.yml
@ -1,23 +1,25 @@
|
|||||||
---
|
---
|
||||||
image: gitpod/workspace-base
|
image:
|
||||||
|
file: .gitpod.Dockerfile
|
||||||
|
|
||||||
# Commands that will run on workspace start
|
# Commands that will run on workspace start
|
||||||
tasks:
|
tasks:
|
||||||
- name: Setup, Install & Build
|
- name: Start Redis Server
|
||||||
before: apt install cargo redis-server nodejs npm -y && cargo test
|
command: redis-server --port 8082
|
||||||
init: cargo install cargo-watch
|
- name: Run The App
|
||||||
command: redis-server --port 8080 & cargo watch -q -w "." -x "run"
|
init: cargo build
|
||||||
# Ports to expose on workspace startup
|
command: PKG_ENV=dev ./target/release/websurfx
|
||||||
ports:
|
- name: Tests
|
||||||
- name: Website
|
command: cargo test
|
||||||
description: Website Preview
|
- name: Clippy Checks
|
||||||
port: 8080
|
command: cargo clippy
|
||||||
onOpen: open-preview
|
|
||||||
# vscode IDE setup
|
# vscode IDE setup
|
||||||
vscode:
|
vscode:
|
||||||
extensions:
|
extensions:
|
||||||
- vadimcn.vscode-lldb
|
- vadimcn.vscode-lldb
|
||||||
- cschleiden.vscode-github-actions
|
- cschleiden.vscode-github-actions
|
||||||
- rust-lang.rust
|
- rust-lang.rust-analyzer
|
||||||
- bungcip.better-toml
|
- bungcip.better-toml
|
||||||
- serayuzgur.crates
|
- serayuzgur.crates
|
||||||
- usernamehw.errorlens
|
- usernamehw.errorlens
|
||||||
@ -26,13 +28,17 @@ vscode:
|
|||||||
- stylelint.vscode-stylelint
|
- stylelint.vscode-stylelint
|
||||||
- dbaeumer.vscode-eslint
|
- dbaeumer.vscode-eslint
|
||||||
- evgeniypeshkov.syntax-highlighter
|
- evgeniypeshkov.syntax-highlighter
|
||||||
- redhat.vscode-yaml
|
|
||||||
- ms-azuretools.vscode-docker
|
- ms-azuretools.vscode-docker
|
||||||
- Catppuccin.catppuccin-vsc
|
- Catppuccin.catppuccin-vsc
|
||||||
- PKief.material-icon-theme
|
- PKief.material-icon-theme
|
||||||
- oderwat.indent-rainbow
|
- oderwat.indent-rainbow
|
||||||
- formulahendry.auto-rename-tag
|
- formulahendry.auto-rename-tag
|
||||||
|
- swellaby.vscode-rust-test-adapter
|
||||||
|
- belfz.search-crates-io
|
||||||
|
- hbenl.test-adapter-converter
|
||||||
|
- hbenl.vscode-test-explorer
|
||||||
- eamodio.gitlens
|
- eamodio.gitlens
|
||||||
|
|
||||||
github:
|
github:
|
||||||
prebuilds:
|
prebuilds:
|
||||||
master: true
|
master: true
|
||||||
@ -40,5 +46,5 @@ github:
|
|||||||
pullRequests: true
|
pullRequests: true
|
||||||
pullRequestsFromForks: true
|
pullRequestsFromForks: true
|
||||||
addCheck: true
|
addCheck: true
|
||||||
addComment: false
|
addComment: false
|
||||||
addBadge: true
|
addBadge: true
|
||||||
|
@ -23,6 +23,7 @@ Some of the configuration options provided in the file are stated below. These a
|
|||||||
|
|
||||||
- **logging:** An option to enable or disable logs.
|
- **logging:** An option to enable or disable logs.
|
||||||
- **debug:** An option to enable or disable debug mode.
|
- **debug:** An option to enable or disable debug mode.
|
||||||
|
- **threads:** The amount of threads that the app will use to run (the value should be greater than 0).
|
||||||
|
|
||||||
## Server
|
## Server
|
||||||
|
|
||||||
|
@ -79,6 +79,7 @@ After that edit the config.lua file located under `websurfx` directory. In the c
|
|||||||
-- ### General ###
|
-- ### General ###
|
||||||
logging = true -- an option to enable or disable logs.
|
logging = true -- an option to enable or disable logs.
|
||||||
debug = false -- an option to enable or disable debug mode.
|
debug = false -- an option to enable or disable debug mode.
|
||||||
|
threads = 10 -- the amount of threads that the app will use to run (the value should be greater than 0).
|
||||||
|
|
||||||
-- ### Server ###
|
-- ### Server ###
|
||||||
port = "8080" -- port on which server should be launched
|
port = "8080" -- port on which server should be launched
|
||||||
|
@ -24,8 +24,8 @@ async fn main() -> std::io::Result<()> {
|
|||||||
);
|
);
|
||||||
log::info!(
|
log::info!(
|
||||||
"Open http://{}:{}/ in your browser",
|
"Open http://{}:{}/ in your browser",
|
||||||
|
config.binding_ip,
|
||||||
config.port,
|
config.port,
|
||||||
config.binding_ip
|
|
||||||
);
|
);
|
||||||
|
|
||||||
let listener = TcpListener::bind((config.binding_ip.clone(), config.port))?;
|
let listener = TcpListener::bind((config.binding_ip.clone(), config.port))?;
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
use super::parser_models::Style;
|
use super::parser_models::Style;
|
||||||
use log::LevelFilter;
|
use log::LevelFilter;
|
||||||
use rlua::Lua;
|
use rlua::Lua;
|
||||||
use std::{collections::HashMap, format, fs, io::Write, path::Path, thread::available_parallelism};
|
use std::{collections::HashMap, format, fs, path::Path, thread::available_parallelism};
|
||||||
|
|
||||||
// ------- Constants --------
|
// ------- Constants --------
|
||||||
static COMMON_DIRECTORY_NAME: &str = "websurfx";
|
static COMMON_DIRECTORY_NAME: &str = "websurfx";
|
||||||
@ -79,26 +79,26 @@ impl Config {
|
|||||||
|
|
||||||
// Check whether logging has not been initialized before.
|
// Check whether logging has not been initialized before.
|
||||||
if logging_initialized {
|
if logging_initialized {
|
||||||
// Initializing logging middleware with level set to default or info.
|
if let Ok(pkg_env_var) = std::env::var("PKG_ENV"){
|
||||||
let mut log_level: LevelFilter = LevelFilter::Off;
|
if pkg_env_var.to_lowercase() == "dev" {
|
||||||
if logging && debug == false {
|
env_logger::Builder::new().filter(None, LevelFilter::Trace).init();
|
||||||
log_level = LevelFilter::Info;
|
}
|
||||||
} else if debug {
|
} else {
|
||||||
log_level = LevelFilter::Trace;
|
// Initializing logging middleware with level set to default or info.
|
||||||
};
|
let mut log_level: LevelFilter = LevelFilter::Error;
|
||||||
env_logger::Builder::new().filter(None, log_level).init();
|
if logging && debug == false {
|
||||||
|
log_level = LevelFilter::Info;
|
||||||
|
} else if debug {
|
||||||
|
log_level = LevelFilter::Debug;
|
||||||
|
};
|
||||||
|
env_logger::Builder::new().filter(None, log_level).init();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let threads: u8 = if parsed_threads == 0 {
|
let threads: u8 = if parsed_threads == 0 {
|
||||||
let total_num_of_threads:usize = available_parallelism()?.get() /2;
|
let total_num_of_threads: usize = available_parallelism()?.get() / 2;
|
||||||
if debug || logging {
|
log::error!("Config Error: The value of `threads` option should be a non zero positive integer");
|
||||||
log::error!("Config Error: The value of `threads` option should be a non zero positive integer");
|
log::error!("Falling back to using {} threads", total_num_of_threads);
|
||||||
log::info!("Falling back to using {} threads", total_num_of_threads)
|
|
||||||
} else {
|
|
||||||
std::io::stdout()
|
|
||||||
.lock()
|
|
||||||
.write_all(&format!("Config Error: The value of `threads` option should be a non zero positive integer\nFalling back to using {} threads\n", total_num_of_threads).into_bytes())?;
|
|
||||||
};
|
|
||||||
total_num_of_threads as u8
|
total_num_of_threads as u8
|
||||||
} else {
|
} else {
|
||||||
parsed_threads
|
parsed_threads
|
||||||
|
@ -144,6 +144,7 @@ pub async fn aggregate(
|
|||||||
initial = false
|
initial = false
|
||||||
}
|
}
|
||||||
Err(error_type) => {
|
Err(error_type) => {
|
||||||
|
log::error!("Engine Error: {:?}", error_type);
|
||||||
engine_errors_info.push(EngineErrorInfo::new(
|
engine_errors_info.push(EngineErrorInfo::new(
|
||||||
error_type.downcast_ref::<EngineError>().unwrap(),
|
error_type.downcast_ref::<EngineError>().unwrap(),
|
||||||
upstream_search_engines[counter].clone(),
|
upstream_search_engines[counter].clone(),
|
||||||
@ -172,6 +173,7 @@ pub async fn aggregate(
|
|||||||
counter += 1
|
counter += 1
|
||||||
}
|
}
|
||||||
Err(error_type) => {
|
Err(error_type) => {
|
||||||
|
log::error!("Engine Error: {:?}", error_type);
|
||||||
engine_errors_info.push(EngineErrorInfo::new(
|
engine_errors_info.push(EngineErrorInfo::new(
|
||||||
error_type.downcast_ref::<EngineError>().unwrap(),
|
error_type.downcast_ref::<EngineError>().unwrap(),
|
||||||
upstream_search_engines[counter].clone(),
|
upstream_search_engines[counter].clone(),
|
||||||
|
Loading…
Reference in New Issue
Block a user