mirror of
https://github.com/mCaptcha/mCaptcha.git
synced 2026-02-11 18:15:39 +00:00
Deploying to gh-pages from @ 8d09aa2452b42d68083625966965e9e78b62c5ee 🚀
This commit is contained in:
@@ -441,6 +441,9 @@
|
||||
<a href="#441" id="441">441</a>
|
||||
<a href="#442" id="442">442</a>
|
||||
<a href="#443" id="443">443</a>
|
||||
<a href="#444" id="444">444</a>
|
||||
<a href="#445" id="445">445</a>
|
||||
<a href="#446" id="446">446</a>
|
||||
</pre></div><pre class="rust"><code><span class="comment">// Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
// SPDX-FileCopyrightText: 2023 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
//
|
||||
@@ -756,8 +759,11 @@
|
||||
|
||||
<span class="doccomment">/// Get the entry at a location in the list of analytics entires under a certain time limit
|
||||
/// and sorted in ascending order
|
||||
</span><span class="kw">async fn </span>stats_get_entry_at_location_for_time_limit_asc(<span class="kw-2">&</span><span class="self">self</span>, duration: u32, location: u32) -> DBResult<<span class="prelude-ty">Option</span><usize>>;
|
||||
|
||||
</span><span class="kw">async fn </span>stats_get_entry_at_location_for_time_limit_asc(
|
||||
<span class="kw-2">&</span><span class="self">self</span>,
|
||||
duration: u32,
|
||||
location: u32,
|
||||
) -> DBResult<<span class="prelude-ty">Option</span><usize>>;
|
||||
}
|
||||
|
||||
<span class="attr">#[derive(Debug, Clone, Default, Deserialize, Serialize, PartialEq)]
|
||||
|
||||
@@ -434,6 +434,31 @@
|
||||
<a href="#434" id="434">434</a>
|
||||
<a href="#435" id="435">435</a>
|
||||
<a href="#436" id="436">436</a>
|
||||
<a href="#437" id="437">437</a>
|
||||
<a href="#438" id="438">438</a>
|
||||
<a href="#439" id="439">439</a>
|
||||
<a href="#440" id="440">440</a>
|
||||
<a href="#441" id="441">441</a>
|
||||
<a href="#442" id="442">442</a>
|
||||
<a href="#443" id="443">443</a>
|
||||
<a href="#444" id="444">444</a>
|
||||
<a href="#445" id="445">445</a>
|
||||
<a href="#446" id="446">446</a>
|
||||
<a href="#447" id="447">447</a>
|
||||
<a href="#448" id="448">448</a>
|
||||
<a href="#449" id="449">449</a>
|
||||
<a href="#450" id="450">450</a>
|
||||
<a href="#451" id="451">451</a>
|
||||
<a href="#452" id="452">452</a>
|
||||
<a href="#453" id="453">453</a>
|
||||
<a href="#454" id="454">454</a>
|
||||
<a href="#455" id="455">455</a>
|
||||
<a href="#456" id="456">456</a>
|
||||
<a href="#457" id="457">457</a>
|
||||
<a href="#458" id="458">458</a>
|
||||
<a href="#459" id="459">459</a>
|
||||
<a href="#460" id="460">460</a>
|
||||
<a href="#461" id="461">461</a>
|
||||
</pre></div><pre class="rust"><code><span class="comment">// Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
// SPDX-FileCopyrightText: 2023 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
//
|
||||
@@ -445,26 +470,26 @@
|
||||
|
||||
<span class="doccomment">/// easy traffic pattern
|
||||
</span><span class="kw">pub const </span>TRAFFIC_PATTERN: TrafficPattern = TrafficPattern {
|
||||
avg_traffic: <span class="number">500</span>,
|
||||
peak_sustainable_traffic: <span class="number">5_000</span>,
|
||||
broke_my_site_traffic: <span class="prelude-val">Some</span>(<span class="number">10_000</span>),
|
||||
};
|
||||
avg_traffic: <span class="number">500</span>,
|
||||
peak_sustainable_traffic: <span class="number">5_000</span>,
|
||||
broke_my_site_traffic: <span class="prelude-val">Some</span>(<span class="number">10_000</span>),
|
||||
};
|
||||
|
||||
<span class="doccomment">/// levels for complex captcha config
|
||||
</span><span class="kw">pub const </span>LEVELS: [Level; <span class="number">3</span>] = [
|
||||
Level {
|
||||
difficulty_factor: <span class="number">1</span>,
|
||||
visitor_threshold: <span class="number">1</span>,
|
||||
},
|
||||
Level {
|
||||
difficulty_factor: <span class="number">2</span>,
|
||||
visitor_threshold: <span class="number">2</span>,
|
||||
},
|
||||
Level {
|
||||
difficulty_factor: <span class="number">3</span>,
|
||||
visitor_threshold: <span class="number">3</span>,
|
||||
},
|
||||
];
|
||||
</span><span class="kw">pub const </span>LEVELS: [Level; <span class="number">3</span>] = [
|
||||
Level {
|
||||
difficulty_factor: <span class="number">1</span>,
|
||||
visitor_threshold: <span class="number">1</span>,
|
||||
},
|
||||
Level {
|
||||
difficulty_factor: <span class="number">2</span>,
|
||||
visitor_threshold: <span class="number">2</span>,
|
||||
},
|
||||
Level {
|
||||
difficulty_factor: <span class="number">3</span>,
|
||||
visitor_threshold: <span class="number">3</span>,
|
||||
},
|
||||
];
|
||||
|
||||
<span class="doccomment">/// test all database functions
|
||||
</span><span class="kw">pub async fn </span>database_works<<span class="lifetime">'a</span>, T: MCDatabase>(
|
||||
@@ -745,12 +770,26 @@
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
};
|
||||
|
||||
|
||||
<span class="macro">assert_eq!</span>(db.stats_get_num_logs_under_time(analytics.time).<span class="kw">await</span>.unwrap(), <span class="number">0</span>);
|
||||
<span class="macro">assert_eq!</span>(
|
||||
db.stats_get_num_logs_under_time(analytics.time)
|
||||
.<span class="kw">await
|
||||
</span>.unwrap(),
|
||||
<span class="number">0
|
||||
</span>);
|
||||
|
||||
db.analysis_save(c.key, <span class="kw-2">&</span>analytics).<span class="kw">await</span>.unwrap();
|
||||
<span class="macro">assert_eq!</span>(db.stats_get_num_logs_under_time(analytics.time).<span class="kw">await</span>.unwrap(), <span class="number">1</span>);
|
||||
<span class="macro">assert_eq!</span>(db.stats_get_num_logs_under_time(analytics.time - <span class="number">1</span>).<span class="kw">await</span>.unwrap(), <span class="number">0</span>);
|
||||
<span class="macro">assert_eq!</span>(
|
||||
db.stats_get_num_logs_under_time(analytics.time)
|
||||
.<span class="kw">await
|
||||
</span>.unwrap(),
|
||||
<span class="number">1
|
||||
</span>);
|
||||
<span class="macro">assert_eq!</span>(
|
||||
db.stats_get_num_logs_under_time(analytics.time - <span class="number">1</span>)
|
||||
.<span class="kw">await
|
||||
</span>.unwrap(),
|
||||
<span class="number">0
|
||||
</span>);
|
||||
<span class="kw">let </span>limit = <span class="number">50</span>;
|
||||
<span class="kw">let </span><span class="kw-2">mut </span>offset = <span class="number">0</span>;
|
||||
<span class="kw">let </span>a = db.analytics_fetch(c.key, limit, offset).<span class="kw">await</span>.unwrap();
|
||||
@@ -770,37 +809,48 @@
|
||||
<span class="macro">assert_eq!</span>(db.analytics_fetch(c.key, <span class="number">1000</span>, <span class="number">0</span>).<span class="kw">await</span>.unwrap().len(), <span class="number">0</span>);
|
||||
<span class="macro">assert!</span>(!db.analytics_captcha_is_published(c.key).<span class="kw">await</span>.unwrap());
|
||||
|
||||
<span class="kw">let </span>rest_analytics= [
|
||||
<span class="kw">let </span>rest_analytics = [
|
||||
CreatePerformanceAnalytics {
|
||||
time: <span class="number">2</span>,
|
||||
difficulty_factor: <span class="number">2</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
time: <span class="number">2</span>,
|
||||
difficulty_factor: <span class="number">2</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
CreatePerformanceAnalytics {
|
||||
time: <span class="number">3</span>,
|
||||
difficulty_factor: <span class="number">3</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
|
||||
time: <span class="number">3</span>,
|
||||
difficulty_factor: <span class="number">3</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
CreatePerformanceAnalytics {
|
||||
time: <span class="number">4</span>,
|
||||
difficulty_factor: <span class="number">4</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
|
||||
time: <span class="number">4</span>,
|
||||
difficulty_factor: <span class="number">4</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
CreatePerformanceAnalytics {
|
||||
time: <span class="number">5</span>,
|
||||
difficulty_factor: <span class="number">5</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
time: <span class="number">5</span>,
|
||||
difficulty_factor: <span class="number">5</span>,
|
||||
worker_type: <span class="string">"wasm"</span>.into(),
|
||||
},
|
||||
];
|
||||
<span class="kw">for </span>a <span class="kw">in </span>rest_analytics.iter() {
|
||||
db.analysis_save(c.key, <span class="kw-2">&</span>a).<span class="kw">await</span>.unwrap();
|
||||
}
|
||||
<span class="macro">assert!</span>(db.stats_get_entry_at_location_for_time_limit_asc(<span class="number">1</span>, <span class="number">2</span>).<span class="kw">await</span>.unwrap().is_none());
|
||||
<span class="macro">assert_eq!</span>(db.stats_get_entry_at_location_for_time_limit_asc(<span class="number">2</span>, <span class="number">1</span>).<span class="kw">await</span>.unwrap(), <span class="prelude-val">Some</span>(<span class="number">2</span>));
|
||||
<span class="macro">assert_eq!</span>(db.stats_get_entry_at_location_for_time_limit_asc(<span class="number">3</span>, <span class="number">2</span>).<span class="kw">await</span>.unwrap(), <span class="prelude-val">Some</span>(<span class="number">3</span>));
|
||||
|
||||
<span class="macro">assert!</span>(db
|
||||
.stats_get_entry_at_location_for_time_limit_asc(<span class="number">1</span>, <span class="number">2</span>)
|
||||
.<span class="kw">await
|
||||
</span>.unwrap()
|
||||
.is_none());
|
||||
<span class="macro">assert_eq!</span>(
|
||||
db.stats_get_entry_at_location_for_time_limit_asc(<span class="number">2</span>, <span class="number">1</span>)
|
||||
.<span class="kw">await
|
||||
</span>.unwrap(),
|
||||
<span class="prelude-val">Some</span>(<span class="number">2</span>)
|
||||
);
|
||||
<span class="macro">assert_eq!</span>(
|
||||
db.stats_get_entry_at_location_for_time_limit_asc(<span class="number">3</span>, <span class="number">2</span>)
|
||||
.<span class="kw">await
|
||||
</span>.unwrap(),
|
||||
<span class="prelude-val">Some</span>(<span class="number">3</span>)
|
||||
);
|
||||
|
||||
db.analytics_delete_all_records_for_campaign(c.key)
|
||||
.<span class="kw">await
|
||||
|
||||
@@ -1343,9 +1343,6 @@
|
||||
<a href="#1343" id="1343">1343</a>
|
||||
<a href="#1344" id="1344">1344</a>
|
||||
<a href="#1345" id="1345">1345</a>
|
||||
<a href="#1346" id="1346">1346</a>
|
||||
<a href="#1347" id="1347">1347</a>
|
||||
<a href="#1348" id="1348">1348</a>
|
||||
</pre></div><pre class="rust"><code><span class="comment">// Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
// SPDX-FileCopyrightText: 2023 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
//
|
||||
@@ -2568,37 +2565,36 @@
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
<span class="doccomment">/// Get number of analytics entries that are under a certain duration
|
||||
</span><span class="kw">async fn </span>stats_get_num_logs_under_time(<span class="kw-2">&</span><span class="self">self</span>, duration: u32) -> DBResult<usize> {
|
||||
|
||||
<span class="kw">struct </span>Count {
|
||||
count: <span class="prelude-ty">Option</span><i64>,
|
||||
}
|
||||
<span class="kw">struct </span>Count {
|
||||
count: <span class="prelude-ty">Option</span><i64>,
|
||||
}
|
||||
|
||||
<span class="comment">//"SELECT COUNT(*) FROM (SELECT difficulty_factor FROM mcaptcha_pow_analytics WHERE time <= ?) as count",
|
||||
</span><span class="kw">let </span>count = <span class="macro">sqlx::query_as!</span>(
|
||||
Count,
|
||||
</span><span class="kw">let </span>count = <span class="macro">sqlx::query_as!</span>(
|
||||
Count,
|
||||
<span class="string">"SELECT
|
||||
COUNT(difficulty_factor) AS count
|
||||
FROM
|
||||
mcaptcha_pow_analytics
|
||||
WHERE time <= ?;"</span>,
|
||||
duration <span class="kw">as </span>i32,
|
||||
)
|
||||
.fetch_one(<span class="kw-2">&</span><span class="self">self</span>.pool)
|
||||
.<span class="kw">await
|
||||
</span>.map_err(|e| map_row_not_found_err(e, DBError::CaptchaNotFound))<span class="question-mark">?</span>;
|
||||
duration <span class="kw">as </span>i32,
|
||||
)
|
||||
.fetch_one(<span class="kw-2">&</span><span class="self">self</span>.pool)
|
||||
.<span class="kw">await
|
||||
</span>.map_err(|e| map_row_not_found_err(e, DBError::CaptchaNotFound))<span class="question-mark">?</span>;
|
||||
|
||||
<span class="prelude-val">Ok</span>(count.count.unwrap_or_else(|| <span class="number">0</span>) <span class="kw">as </span>usize)
|
||||
}
|
||||
|
||||
<span class="doccomment">/// Get the entry at a location in the list of analytics entires under a certain time limited
|
||||
/// and sorted in ascending order
|
||||
</span><span class="kw">async fn </span>stats_get_entry_at_location_for_time_limit_asc(<span class="kw-2">&</span><span class="self">self</span>, duration: u32, location: u32) -> DBResult<<span class="prelude-ty">Option</span><usize>> {
|
||||
|
||||
|
||||
</span><span class="kw">async fn </span>stats_get_entry_at_location_for_time_limit_asc(
|
||||
<span class="kw-2">&</span><span class="self">self</span>,
|
||||
duration: u32,
|
||||
location: u32,
|
||||
) -> DBResult<<span class="prelude-ty">Option</span><usize>> {
|
||||
<span class="kw">struct </span>Difficulty {
|
||||
difficulty_factor: <span class="prelude-ty">Option</span><i32>,
|
||||
}
|
||||
@@ -2620,10 +2616,8 @@
|
||||
</span>{
|
||||
<span class="prelude-val">Ok</span>(res) => <span class="prelude-val">Ok</span>(<span class="prelude-val">Some</span>(res.difficulty_factor.unwrap() <span class="kw">as </span>usize)),
|
||||
<span class="prelude-val">Err</span>(sqlx::Error::RowNotFound) => <span class="prelude-val">Ok</span>(<span class="prelude-val">None</span>),
|
||||
<span class="prelude-val">Err</span>(e) => <span class="prelude-val">Err</span>(map_row_not_found_err(e, DBError::CaptchaNotFound))
|
||||
|
||||
<span class="prelude-val">Err</span>(e) => <span class="prelude-val">Err</span>(map_row_not_found_err(e, DBError::CaptchaNotFound)),
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1346,9 +1346,6 @@
|
||||
<a href="#1346" id="1346">1346</a>
|
||||
<a href="#1347" id="1347">1347</a>
|
||||
<a href="#1348" id="1348">1348</a>
|
||||
<a href="#1349" id="1349">1349</a>
|
||||
<a href="#1350" id="1350">1350</a>
|
||||
<a href="#1351" id="1351">1351</a>
|
||||
</pre></div><pre class="rust"><code><span class="comment">// Copyright (C) 2022 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
// SPDX-FileCopyrightText: 2023 Aravinth Manivannan <realaravinth@batsense.net>
|
||||
//
|
||||
@@ -2581,28 +2578,29 @@
|
||||
|
||||
<span class="doccomment">/// Get number of analytics entries that are under a certain duration
|
||||
</span><span class="kw">async fn </span>stats_get_num_logs_under_time(<span class="kw-2">&</span><span class="self">self</span>, duration: u32) -> DBResult<usize> {
|
||||
<span class="kw">struct </span>Count {
|
||||
count: <span class="prelude-ty">Option</span><i64>,
|
||||
}
|
||||
|
||||
<span class="kw">struct </span>Count {
|
||||
count: <span class="prelude-ty">Option</span><i64>,
|
||||
}
|
||||
|
||||
<span class="kw">let </span>count = <span class="macro">sqlx::query_as!</span>(
|
||||
<span class="kw">let </span>count = <span class="macro">sqlx::query_as!</span>(
|
||||
Count,
|
||||
<span class="string">"SELECT COUNT(difficulty_factor) FROM mcaptcha_pow_analytics WHERE time <= $1;"</span>,
|
||||
duration <span class="kw">as </span>i32,
|
||||
)
|
||||
.fetch_one(<span class="kw-2">&</span><span class="self">self</span>.pool)
|
||||
.<span class="kw">await
|
||||
</span>.map_err(|e| map_row_not_found_err(e, DBError::CaptchaNotFound))<span class="question-mark">?</span>;
|
||||
.fetch_one(<span class="kw-2">&</span><span class="self">self</span>.pool)
|
||||
.<span class="kw">await
|
||||
</span>.map_err(|e| map_row_not_found_err(e, DBError::CaptchaNotFound))<span class="question-mark">?</span>;
|
||||
|
||||
<span class="prelude-val">Ok</span>(count.count.unwrap_or_else(|| <span class="number">0</span>) <span class="kw">as </span>usize)
|
||||
}
|
||||
|
||||
<span class="doccomment">/// Get the entry at a location in the list of analytics entires under a certain time limit
|
||||
/// and sorted in ascending order
|
||||
</span><span class="kw">async fn </span>stats_get_entry_at_location_for_time_limit_asc(<span class="kw-2">&</span><span class="self">self</span>, duration: u32, location: u32) -> DBResult<<span class="prelude-ty">Option</span><usize>> {
|
||||
|
||||
|
||||
</span><span class="kw">async fn </span>stats_get_entry_at_location_for_time_limit_asc(
|
||||
<span class="kw-2">&</span><span class="self">self</span>,
|
||||
duration: u32,
|
||||
location: u32,
|
||||
) -> DBResult<<span class="prelude-ty">Option</span><usize>> {
|
||||
<span class="kw">struct </span>Difficulty {
|
||||
difficulty_factor: <span class="prelude-ty">Option</span><i32>,
|
||||
}
|
||||
@@ -2624,13 +2622,9 @@
|
||||
</span>{
|
||||
<span class="prelude-val">Ok</span>(res) => <span class="prelude-val">Ok</span>(<span class="prelude-val">Some</span>(res.difficulty_factor.unwrap() <span class="kw">as </span>usize)),
|
||||
<span class="prelude-val">Err</span>(sqlx::Error::RowNotFound) => <span class="prelude-val">Ok</span>(<span class="prelude-val">None</span>),
|
||||
<span class="prelude-val">Err</span>(e) => <span class="prelude-val">Err</span>(map_row_not_found_err(e, DBError::CaptchaNotFound))
|
||||
|
||||
<span class="prelude-val">Err</span>(e) => <span class="prelude-val">Err</span>(map_row_not_found_err(e, DBError::CaptchaNotFound)),
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
<span class="attr">#[derive(Clone)]
|
||||
|
||||
Reference in New Issue
Block a user