mirror of
https://github.com/TecharoHQ/anubis.git
synced 2026-04-09 18:18:49 +00:00
Compare commits
3 Commits
Xe/dont-co
...
Xe/fix-doc
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
1f9dda9d42 | ||
|
|
316905bf1d | ||
|
|
1a12171d74 |
4
.github/workflows/asset-verification.yml
vendored
4
.github/workflows/asset-verification.yml
vendored
@@ -22,11 +22,11 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y build-essential
|
sudo apt-get install -y build-essential
|
||||||
|
|
||||||
- uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
|
- uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0
|
||||||
with:
|
with:
|
||||||
node-version: latest
|
node-version: latest
|
||||||
|
|
||||||
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5.5.0
|
- uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
|
|
||||||
|
|||||||
6
.github/workflows/docker-pr.yml
vendored
6
.github/workflows/docker-pr.yml
vendored
@@ -26,11 +26,11 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y build-essential
|
sudo apt-get install -y build-essential
|
||||||
|
|
||||||
- uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
|
- uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0
|
||||||
with:
|
with:
|
||||||
node-version: latest
|
node-version: latest
|
||||||
|
|
||||||
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5.5.0
|
- uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
|
|
||||||
@@ -38,7 +38,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Docker meta
|
- name: Docker meta
|
||||||
id: meta
|
id: meta
|
||||||
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0
|
uses: docker/metadata-action@318604b99e75e41977312d83839a89be02ca4893 # v5.9.0
|
||||||
with:
|
with:
|
||||||
images: ghcr.io/${{ github.repository }}
|
images: ghcr.io/${{ github.repository }}
|
||||||
|
|
||||||
|
|||||||
6
.github/workflows/docker.yml
vendored
6
.github/workflows/docker.yml
vendored
@@ -36,11 +36,11 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
echo "IMAGE=ghcr.io/${GITHUB_REPOSITORY,,}" >> $GITHUB_ENV
|
echo "IMAGE=ghcr.io/${GITHUB_REPOSITORY,,}" >> $GITHUB_ENV
|
||||||
|
|
||||||
- uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
|
- uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0
|
||||||
with:
|
with:
|
||||||
node-version: latest
|
node-version: latest
|
||||||
|
|
||||||
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5.5.0
|
- uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
|
|
||||||
@@ -55,7 +55,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Docker meta
|
- name: Docker meta
|
||||||
id: meta
|
id: meta
|
||||||
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0
|
uses: docker/metadata-action@318604b99e75e41977312d83839a89be02ca4893 # v5.9.0
|
||||||
with:
|
with:
|
||||||
images: ${{ env.IMAGE }}
|
images: ${{ env.IMAGE }}
|
||||||
|
|
||||||
|
|||||||
2
.github/workflows/docs-deploy.yml
vendored
2
.github/workflows/docs-deploy.yml
vendored
@@ -33,7 +33,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Docker meta
|
- name: Docker meta
|
||||||
id: meta
|
id: meta
|
||||||
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0
|
uses: docker/metadata-action@318604b99e75e41977312d83839a89be02ca4893 # v5.9.0
|
||||||
with:
|
with:
|
||||||
images: ghcr.io/techarohq/anubis/docs
|
images: ghcr.io/techarohq/anubis/docs
|
||||||
tags: |
|
tags: |
|
||||||
|
|||||||
2
.github/workflows/docs-test.yml
vendored
2
.github/workflows/docs-test.yml
vendored
@@ -22,7 +22,7 @@ jobs:
|
|||||||
|
|
||||||
- name: Docker meta
|
- name: Docker meta
|
||||||
id: meta
|
id: meta
|
||||||
uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0
|
uses: docker/metadata-action@318604b99e75e41977312d83839a89be02ca4893 # v5.9.0
|
||||||
with:
|
with:
|
||||||
images: ghcr.io/techarohq/anubis/docs
|
images: ghcr.io/techarohq/anubis/docs
|
||||||
tags: |
|
tags: |
|
||||||
|
|||||||
4
.github/workflows/go.yml
vendored
4
.github/workflows/go.yml
vendored
@@ -24,11 +24,11 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y build-essential
|
sudo apt-get install -y build-essential
|
||||||
|
|
||||||
- uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
|
- uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0
|
||||||
with:
|
with:
|
||||||
node-version: latest
|
node-version: latest
|
||||||
|
|
||||||
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5.5.0
|
- uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
|
|
||||||
|
|||||||
4
.github/workflows/package-builds-stable.yml
vendored
4
.github/workflows/package-builds-stable.yml
vendored
@@ -25,11 +25,11 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y build-essential
|
sudo apt-get install -y build-essential
|
||||||
|
|
||||||
- uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
|
- uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0
|
||||||
with:
|
with:
|
||||||
node-version: latest
|
node-version: latest
|
||||||
|
|
||||||
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5.5.0
|
- uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
|
|
||||||
|
|||||||
@@ -26,11 +26,11 @@ jobs:
|
|||||||
sudo apt-get update
|
sudo apt-get update
|
||||||
sudo apt-get install -y build-essential
|
sudo apt-get install -y build-essential
|
||||||
|
|
||||||
- uses: actions/setup-node@49933ea5288caeca8642d1e84afbd3f7d6820020 # v4.4.0
|
- uses: actions/setup-node@2028fbc5c25fe9cf00d9f06a71cc4710d4507903 # v6.0.0
|
||||||
with:
|
with:
|
||||||
node-version: latest
|
node-version: latest
|
||||||
|
|
||||||
- uses: actions/setup-go@d35c59abb061a4a6fb18e82ac0862c26744d6ab5 # v5.5.0
|
- uses: actions/setup-go@44694675825211faa026b3c33043df3e48a5fa00 # v6.0.0
|
||||||
with:
|
with:
|
||||||
go-version: stable
|
go-version: stable
|
||||||
|
|
||||||
|
|||||||
@@ -51,3 +51,10 @@
|
|||||||
all:
|
all:
|
||||||
- path.startsWith("/v2/")
|
- path.startsWith("/v2/")
|
||||||
- userAgent.contains("containerd/")
|
- userAgent.contains("containerd/")
|
||||||
|
|
||||||
|
- name: allow-renovate
|
||||||
|
action: ALLOW
|
||||||
|
expression:
|
||||||
|
all:
|
||||||
|
- path.startsWith("/v2/")
|
||||||
|
- userAgent.contains("Renovate/")
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
FROM docker.io/library/node AS build
|
FROM docker.io/library/node:lts AS build
|
||||||
|
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|||||||
@@ -16,6 +16,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|||||||
- Allow more OCI registry clients [based on feedback](https://github.com/TecharoHQ/anubis/pull/1253#issuecomment-3506744184).
|
- Allow more OCI registry clients [based on feedback](https://github.com/TecharoHQ/anubis/pull/1253#issuecomment-3506744184).
|
||||||
- Expose services directory in the embedded `(data)` filesystem.
|
- Expose services directory in the embedded `(data)` filesystem.
|
||||||
- Add Ukrainian locale ([#1044](https://github.com/TecharoHQ/anubis/pull/1044))
|
- Add Ukrainian locale ([#1044](https://github.com/TecharoHQ/anubis/pull/1044))
|
||||||
|
- Allow Renovate as an OCI registry client
|
||||||
|
|
||||||
## v1.23.1: Lyse Hext - Echo 1
|
## v1.23.1: Lyse Hext - Echo 1
|
||||||
|
|
||||||
|
|||||||
142
lib/http_test.go
142
lib/http_test.go
@@ -173,148 +173,6 @@ func TestRenderIndexRedirect(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestClearCookieHostParameterHonorsDynamicDomain(t *testing.T) {
|
|
||||||
// Test that Host parameter is only used when CookieDynamicDomain is enabled
|
|
||||||
testCases := []struct {
|
|
||||||
name string
|
|
||||||
options Options
|
|
||||||
host string
|
|
||||||
expectedDomain string
|
|
||||||
shouldHaveDomainField bool
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
name: "dynamic domain disabled",
|
|
||||||
options: Options{CookieDynamicDomain: false},
|
|
||||||
host: "subdomain.example.com",
|
|
||||||
expectedDomain: "",
|
|
||||||
shouldHaveDomainField: false,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "dynamic domain enabled with valid host",
|
|
||||||
options: Options{CookieDynamicDomain: true},
|
|
||||||
host: "subdomain.example.com",
|
|
||||||
expectedDomain: "example.com",
|
|
||||||
shouldHaveDomainField: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "dynamic domain enabled with invalid host",
|
|
||||||
options: Options{CookieDynamicDomain: true},
|
|
||||||
host: "invalid-host",
|
|
||||||
expectedDomain: "",
|
|
||||||
shouldHaveDomainField: false,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, tc := range testCases {
|
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
|
||||||
srv := spawnAnubis(t, tc.options)
|
|
||||||
rw := httptest.NewRecorder()
|
|
||||||
|
|
||||||
// Test ClearCookie with Host parameter
|
|
||||||
srv.ClearCookie(rw, CookieOpts{Path: "/", Host: tc.host})
|
|
||||||
|
|
||||||
resp := rw.Result()
|
|
||||||
cookies := resp.Cookies()
|
|
||||||
|
|
||||||
if len(cookies) != 1 {
|
|
||||||
t.Errorf("wanted 1 cookie, got %d cookies", len(cookies))
|
|
||||||
}
|
|
||||||
|
|
||||||
ckie := cookies[0]
|
|
||||||
|
|
||||||
if ckie.Name != anubis.CookieName {
|
|
||||||
t.Errorf("wanted cookie named %q, got cookie named %q", anubis.CookieName, ckie.Name)
|
|
||||||
}
|
|
||||||
|
|
||||||
if ckie.MaxAge != -1 {
|
|
||||||
t.Errorf("wanted cookie max age of -1, got: %d", ckie.MaxAge)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verify domain handling based on CookieDynamicDomain setting
|
|
||||||
if tc.shouldHaveDomainField {
|
|
||||||
if ckie.Domain != tc.expectedDomain {
|
|
||||||
t.Errorf("wanted cookie domain %q, got cookie domain %q", tc.expectedDomain, ckie.Domain)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ckie.Domain != tc.expectedDomain {
|
|
||||||
t.Errorf("wanted cookie domain %q, got cookie domain %q", tc.expectedDomain, ckie.Domain)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSetCookieHostParameterHonorsDynamicDomain(t *testing.T) {
|
|
||||||
// Test that SetCookie Host parameter is only used when CookieDynamicDomain is enabled
|
|
||||||
testCases := []struct {
|
|
||||||
name string
|
|
||||||
options Options
|
|
||||||
host string
|
|
||||||
expectedDomain string
|
|
||||||
shouldHaveDomainField bool
|
|
||||||
}{
|
|
||||||
{
|
|
||||||
name: "dynamic domain disabled",
|
|
||||||
options: Options{CookieDynamicDomain: false},
|
|
||||||
host: "subdomain.example.com",
|
|
||||||
expectedDomain: "",
|
|
||||||
shouldHaveDomainField: false,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "dynamic domain enabled with valid host",
|
|
||||||
options: Options{CookieDynamicDomain: true},
|
|
||||||
host: "subdomain.example.com",
|
|
||||||
expectedDomain: "example.com",
|
|
||||||
shouldHaveDomainField: true,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "dynamic domain enabled with invalid host",
|
|
||||||
options: Options{CookieDynamicDomain: true},
|
|
||||||
host: "invalid-host",
|
|
||||||
expectedDomain: "",
|
|
||||||
shouldHaveDomainField: false,
|
|
||||||
},
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, tc := range testCases {
|
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
|
||||||
srv := spawnAnubis(t, tc.options)
|
|
||||||
rw := httptest.NewRecorder()
|
|
||||||
|
|
||||||
// Test SetCookie with Host parameter
|
|
||||||
srv.SetCookie(rw, CookieOpts{Path: "/", Host: tc.host, Value: "test-value"})
|
|
||||||
|
|
||||||
resp := rw.Result()
|
|
||||||
cookies := resp.Cookies()
|
|
||||||
|
|
||||||
if len(cookies) != 1 {
|
|
||||||
t.Errorf("wanted 1 cookie, got %d cookies", len(cookies))
|
|
||||||
}
|
|
||||||
|
|
||||||
ckie := cookies[0]
|
|
||||||
|
|
||||||
if ckie.Name != anubis.CookieName {
|
|
||||||
t.Errorf("wanted cookie named %q, got cookie named %q", anubis.CookieName, ckie.Name)
|
|
||||||
}
|
|
||||||
|
|
||||||
if ckie.Value != "test-value" {
|
|
||||||
t.Errorf("wanted cookie value %q, got cookie value %q", "test-value", ckie.Value)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Verify domain handling based on CookieDynamicDomain setting
|
|
||||||
if tc.shouldHaveDomainField {
|
|
||||||
if ckie.Domain != tc.expectedDomain {
|
|
||||||
t.Errorf("wanted cookie domain %q, got cookie domain %q", tc.expectedDomain, ckie.Domain)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if ckie.Domain != tc.expectedDomain {
|
|
||||||
t.Errorf("wanted cookie domain %q, got cookie domain %q", tc.expectedDomain, ckie.Domain)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestRenderIndexUnauthorized(t *testing.T) {
|
func TestRenderIndexUnauthorized(t *testing.T) {
|
||||||
s := &Server{
|
s := &Server{
|
||||||
opts: Options{
|
opts: Options{
|
||||||
|
|||||||
Reference in New Issue
Block a user