mirror of
https://github.com/LemmyNet/lemmy.git
synced 2025-03-01 17:11:02 +00:00
replace occurences of v3
, fix routes
This commit is contained in:
parent
c2ccff0b12
commit
1dc544107a
9 changed files with 34 additions and 34 deletions
|
@ -82,13 +82,13 @@ LEMMY_CONFIG_LOCATION=./docker/federation/lemmy_epsilon.hjson \
|
|||
target/lemmy_server >$LOG_DIR/lemmy_epsilon.out 2>&1 &
|
||||
|
||||
echo "wait for all instances to start"
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-alpha:8541/api/v3/site')" != "200" ]]; do sleep 1; done
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-alpha:8541/api/v4/site')" != "200" ]]; do sleep 1; done
|
||||
echo "alpha started"
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-beta:8551/api/v3/site')" != "200" ]]; do sleep 1; done
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-beta:8551/api/v4/site')" != "200" ]]; do sleep 1; done
|
||||
echo "beta started"
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-gamma:8561/api/v3/site')" != "200" ]]; do sleep 1; done
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-gamma:8561/api/v4/site')" != "200" ]]; do sleep 1; done
|
||||
echo "gamma started"
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-delta:8571/api/v3/site')" != "200" ]]; do sleep 1; done
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-delta:8571/api/v4/site')" != "200" ]]; do sleep 1; done
|
||||
echo "delta started"
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-epsilon:8581/api/v3/site')" != "200" ]]; do sleep 1; done
|
||||
while [[ "$(curl -s -o /dev/null -w '%{http_code}' 'lemmy-epsilon:8581/api/v4/site')" != "200" ]]; do sleep 1; done
|
||||
echo "epsilon started. All started"
|
||||
|
|
|
@ -199,11 +199,11 @@ test("Images in remote image post are proxied if setting enabled", async () => {
|
|||
// remote image gets proxied after upload
|
||||
expect(
|
||||
post.thumbnail_url?.startsWith(
|
||||
"http://lemmy-gamma:8561/api/v3/image_proxy?url",
|
||||
"http://lemmy-gamma:8561/api/v4/image_proxy?url",
|
||||
),
|
||||
).toBeTruthy();
|
||||
expect(
|
||||
post.body?.startsWith("data:image/s3,"s3://crabby-images/23c24/23c240430c1920653d3e0c062cf228c179c47f47" alt="",
|
||||
post.body?.startsWith("data:image/s3,"s3://crabby-images/b00ee/b00ee33784dd8a04bc64bc53a6ae35ce6fb5d765" alt="",
|
||||
).toBeTruthy();
|
||||
|
||||
// Make sure that it ends with jpg, to be sure its an image
|
||||
|
@ -222,12 +222,12 @@ test("Images in remote image post are proxied if setting enabled", async () => {
|
|||
|
||||
expect(
|
||||
epsilonPost.thumbnail_url?.startsWith(
|
||||
"http://lemmy-epsilon:8581/api/v3/image_proxy?url",
|
||||
"http://lemmy-epsilon:8581/api/v4/image_proxy?url",
|
||||
),
|
||||
).toBeTruthy();
|
||||
expect(
|
||||
epsilonPost.body?.startsWith(
|
||||
"data:image/s3,"s3://crabby-images/4ad6b/4ad6b42213e3936281116f6bbb5fc4ab697364a4" alt="",
|
||||
).toBeTruthy();
|
||||
|
||||
|
@ -249,7 +249,7 @@ test("Thumbnail of remote image link is proxied if setting enabled", async () =>
|
|||
// remote image gets proxied after upload
|
||||
expect(
|
||||
post.thumbnail_url?.startsWith(
|
||||
"http://lemmy-gamma:8561/api/v3/image_proxy?url",
|
||||
"http://lemmy-gamma:8561/api/v4/image_proxy?url",
|
||||
),
|
||||
).toBeTruthy();
|
||||
|
||||
|
@ -267,7 +267,7 @@ test("Thumbnail of remote image link is proxied if setting enabled", async () =>
|
|||
|
||||
expect(
|
||||
epsilonPost.thumbnail_url?.startsWith(
|
||||
"http://lemmy-epsilon:8581/api/v3/image_proxy?url",
|
||||
"http://lemmy-epsilon:8581/api/v4/image_proxy?url",
|
||||
),
|
||||
).toBeTruthy();
|
||||
|
||||
|
|
|
@ -11,7 +11,7 @@ Here is an example using [reqwest](https://crates.io/crates/reqwest):
|
|||
};
|
||||
let client = Client::new();
|
||||
let response = client
|
||||
.get("https://lemmy.ml/api/v3/post/list")
|
||||
.get("https://lemmy.ml/api/v4/post/list")
|
||||
.query(¶ms)
|
||||
.send()
|
||||
.await?;
|
||||
|
|
|
@ -435,7 +435,7 @@ pub struct EditSite {
|
|||
/// The response for a site.
|
||||
pub struct SiteResponse {
|
||||
pub site_view: SiteView,
|
||||
/// deprecated, use field `tagline` or /api/v3/tagline/list
|
||||
/// deprecated, use field `tagline` or /api/4/tagline/list
|
||||
pub taglines: Vec<()>,
|
||||
}
|
||||
|
||||
|
|
|
@ -1120,7 +1120,7 @@ async fn proxy_image_link_internal(
|
|||
}
|
||||
}
|
||||
|
||||
/// Rewrite a link to go through `/api/v3/image_proxy` endpoint. This is only for remote urls and
|
||||
/// Rewrite a link to go through `/api/v4/image_proxy` endpoint. This is only for remote urls and
|
||||
/// if image_proxy setting is enabled.
|
||||
pub async fn proxy_image_link(link: Url, context: &LemmyContext) -> LemmyResult<DbUrl> {
|
||||
proxy_image_link_internal(
|
||||
|
@ -1172,7 +1172,7 @@ fn build_proxied_image_url(
|
|||
protocol_and_hostname: &str,
|
||||
) -> Result<Url, url::ParseError> {
|
||||
Url::parse(&format!(
|
||||
"{}/api/v3/image_proxy?url={}",
|
||||
"{}/api/v4/image_proxy?url={}",
|
||||
protocol_and_hostname,
|
||||
encode(link.as_str())
|
||||
))
|
||||
|
@ -1251,7 +1251,7 @@ mod tests {
|
|||
)
|
||||
.await?;
|
||||
assert_eq!(
|
||||
"https://lemmy-alpha/api/v3/image_proxy?url=http%3A%2F%2Flemmy-beta%2Fimage.png",
|
||||
"https://lemmy-alpha/api/v4/image_proxy?url=http%3A%2F%2Flemmy-beta%2Fimage.png",
|
||||
proxied.as_str()
|
||||
);
|
||||
|
||||
|
|
|
@ -111,7 +111,7 @@ pub enum PictrsImageMode {
|
|||
#[default]
|
||||
StoreLinkPreviews,
|
||||
/// If enabled, all images from remote domains are rewritten to pass through
|
||||
/// `/api/v3/image_proxy`, including embedded images in markdown. Images are stored temporarily
|
||||
/// `/api/v4/image_proxy`, including embedded images in markdown. Images are stored temporarily
|
||||
/// in pict-rs for caching. This improves privacy as users don't expose their IP to untrusted
|
||||
/// servers, and decreases load on other servers. However it increases bandwidth use for the
|
||||
/// local server.
|
||||
|
|
|
@ -4,7 +4,7 @@ use markdown_it::{plugins::cmark::inline::image::Image, NodeValue};
|
|||
use url::Url;
|
||||
use urlencoding::encode;
|
||||
|
||||
/// Rewrites all links to remote domains in markdown, so they go through `/api/v3/image_proxy`.
|
||||
/// Rewrites all links to remote domains in markdown, so they go through `/api/v4/image_proxy`.
|
||||
pub fn markdown_rewrite_image_links(mut src: String) -> (String, Vec<Url>) {
|
||||
let links_offsets = find_urls::<Image>(&src);
|
||||
|
||||
|
@ -18,7 +18,7 @@ pub fn markdown_rewrite_image_links(mut src: String) -> (String, Vec<Url>) {
|
|||
// If link points to remote domain, replace with proxied link
|
||||
if parsed.domain() != Some(&SETTINGS.hostname) {
|
||||
let mut proxied = format!(
|
||||
"{}/api/v3/image_proxy?url={}",
|
||||
"{}/api/v4/image_proxy?url={}",
|
||||
SETTINGS.get_protocol_and_hostname(),
|
||||
encode(url),
|
||||
);
|
||||
|
@ -115,7 +115,7 @@ mod tests {
|
|||
(
|
||||
"remote image proxied",
|
||||
"data:image/s3,"s3://crabby-images/6163f/6163f09ac470dd7d34061aa26f24eaafc263a44b" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/590cb/590cb924068c3b10f056fd9c540c86b70e7063fa" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/facef/facefc99efd068b0bb9a29af41e749513bef7206" alt="link"",
|
||||
),
|
||||
(
|
||||
"local image unproxied",
|
||||
|
@ -125,7 +125,7 @@ mod tests {
|
|||
(
|
||||
"multiple image links",
|
||||
"data:image/s3,"s3://crabby-images/be5ff/be5ffe7b028a7e99a25995db7c077e2b043eca8f" alt="link" data:image/s3,"s3://crabby-images/527ae/527aef343fe9d05f636cc743628d2af5610a1d54" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/c9098/c90981d4226ef727ff28335365a93666b6f00811" alt="link" data:image/s3,"s3://crabby-images/76db1/76db1931d5297bb8a56f5feaabf887fadba0e8e2" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/9b2dc/9b2dc58c61465e525b180e56b085c041bd6f9a21" alt="link" data:image/s3,"s3://crabby-images/e3ebf/e3ebfe6bdd859b3e20b3b2a382a46d3c5665fd50" alt="link"",
|
||||
),
|
||||
(
|
||||
"empty link handled",
|
||||
|
@ -135,7 +135,7 @@ mod tests {
|
|||
(
|
||||
"empty label handled",
|
||||
"data:image/s3,"s3://crabby-images/6163f/6163f09ac470dd7d34061aa26f24eaafc263a44b" alt=""",
|
||||
"data:image/s3,"s3://crabby-images/590cb/590cb924068c3b10f056fd9c540c86b70e7063fa" alt="""
|
||||
"data:image/s3,"s3://crabby-images/facef/facefc99efd068b0bb9a29af41e749513bef7206" alt="""
|
||||
),
|
||||
(
|
||||
"invalid image link removed",
|
||||
|
@ -145,12 +145,12 @@ mod tests {
|
|||
(
|
||||
"label with nested markdown handled",
|
||||
"data:image/s3,"s3://crabby-images/6163f/6163f09ac470dd7d34061aa26f24eaafc263a44b" alt="a *b* c"",
|
||||
"data:image/s3,"s3://crabby-images/590cb/590cb924068c3b10f056fd9c540c86b70e7063fa" alt="a *b* c""
|
||||
"data:image/s3,"s3://crabby-images/facef/facefc99efd068b0bb9a29af41e749513bef7206" alt="a *b* c""
|
||||
),
|
||||
(
|
||||
"custom emoji support",
|
||||
r#"data:image/s3,"s3://crabby-images/3705d/3705d80ae44a6097239009319d215df6fc8bcd83" alt="party-blob""#,
|
||||
r#"data:image/s3,"s3://crabby-images/a73f5/a73f50fb3c3e04c27ee7e05347eda601db8e4f4a" alt="party-blob""#
|
||||
r#"data:image/s3,"s3://crabby-images/7fa0c/7fa0c15bda4c240948ac428916328611059c43df" alt="party-blob""#
|
||||
)
|
||||
];
|
||||
|
||||
|
|
|
@ -141,7 +141,7 @@ mod tests {
|
|||
(
|
||||
"remote image proxied",
|
||||
"data:image/s3,"s3://crabby-images/6163f/6163f09ac470dd7d34061aa26f24eaafc263a44b" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/590cb/590cb924068c3b10f056fd9c540c86b70e7063fa" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/facef/facefc99efd068b0bb9a29af41e749513bef7206" alt="link"",
|
||||
),
|
||||
(
|
||||
"local image unproxied",
|
||||
|
@ -151,7 +151,7 @@ mod tests {
|
|||
(
|
||||
"multiple image links",
|
||||
"data:image/s3,"s3://crabby-images/be5ff/be5ffe7b028a7e99a25995db7c077e2b043eca8f" alt="link" data:image/s3,"s3://crabby-images/527ae/527aef343fe9d05f636cc743628d2af5610a1d54" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/c9098/c90981d4226ef727ff28335365a93666b6f00811" alt="link" data:image/s3,"s3://crabby-images/76db1/76db1931d5297bb8a56f5feaabf887fadba0e8e2" alt="link"",
|
||||
"data:image/s3,"s3://crabby-images/9b2dc/9b2dc58c61465e525b180e56b085c041bd6f9a21" alt="link" data:image/s3,"s3://crabby-images/e3ebf/e3ebfe6bdd859b3e20b3b2a382a46d3c5665fd50" alt="link"",
|
||||
),
|
||||
(
|
||||
"empty link handled",
|
||||
|
@ -161,7 +161,7 @@ mod tests {
|
|||
(
|
||||
"empty label handled",
|
||||
"data:image/s3,"s3://crabby-images/6163f/6163f09ac470dd7d34061aa26f24eaafc263a44b" alt=""",
|
||||
"data:image/s3,"s3://crabby-images/590cb/590cb924068c3b10f056fd9c540c86b70e7063fa" alt="""
|
||||
"data:image/s3,"s3://crabby-images/facef/facefc99efd068b0bb9a29af41e749513bef7206" alt="""
|
||||
),
|
||||
(
|
||||
"invalid image link removed",
|
||||
|
@ -171,12 +171,12 @@ mod tests {
|
|||
(
|
||||
"label with nested markdown handled",
|
||||
"data:image/s3,"s3://crabby-images/6163f/6163f09ac470dd7d34061aa26f24eaafc263a44b" alt="a *b* c"",
|
||||
"data:image/s3,"s3://crabby-images/590cb/590cb924068c3b10f056fd9c540c86b70e7063fa" alt="a *b* c""
|
||||
"data:image/s3,"s3://crabby-images/facef/facefc99efd068b0bb9a29af41e749513bef7206" alt="a *b* c""
|
||||
),
|
||||
(
|
||||
"custom emoji support",
|
||||
r#"data:image/s3,"s3://crabby-images/3705d/3705d80ae44a6097239009319d215df6fc8bcd83" alt="party-blob""#,
|
||||
r#"data:image/s3,"s3://crabby-images/a73f5/a73f50fb3c3e04c27ee7e05347eda601db8e4f4a" alt="party-blob""#
|
||||
r#"data:image/s3,"s3://crabby-images/7fa0c/7fa0c15bda4c240948ac428916328611059c43df" alt="party-blob""#
|
||||
)
|
||||
];
|
||||
|
||||
|
|
|
@ -162,7 +162,7 @@ use lemmy_utils::rate_limit::RateLimitCell;
|
|||
|
||||
pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
||||
cfg.service(
|
||||
web::scope("/api/v3")
|
||||
web::scope("/api/v4")
|
||||
.wrap(rate_limit.message())
|
||||
.route("/image_proxy", web::get().to(image_proxy))
|
||||
// Site
|
||||
|
@ -283,11 +283,11 @@ pub fn config(cfg: &mut web::ServiceConfig, rate_limit: &RateLimitCell) {
|
|||
web::scope("/account/auth")
|
||||
.guard(guard::Post())
|
||||
.wrap(rate_limit.register())
|
||||
.route("register", web::post().to(register))
|
||||
.route("login", web::post().to(login))
|
||||
.route("/register", web::post().to(register))
|
||||
.route("/login", web::post().to(login))
|
||||
.route("/logout", web::post().to(logout))
|
||||
.route("password_reset", web::post().to(reset_password))
|
||||
.route("get_captcha", web::get().to(get_captcha))
|
||||
.route("/password_reset", web::post().to(reset_password))
|
||||
.route("/get_captcha", web::get().to(get_captcha))
|
||||
.route(
|
||||
"/password_change",
|
||||
web::post().to(change_password_after_reset),
|
||||
|
|
Loading…
Reference in a new issue