mirror of
https://github.com/juanfont/headscale.git
synced 2025-08-17 19:27:30 +00:00
Compare commits
5 Commits
remove-nod
...
topic/pret
Author | SHA1 | Date | |
---|---|---|---|
![]() |
a1b18b36dd | ||
![]() |
68503581a0 | ||
![]() |
e2afd30b1c | ||
![]() |
c906aaf927 | ||
![]() |
580f96ce83 |
27
.github/workflows/docs-test.yml
vendored
Normal file
27
.github/workflows/docs-test.yml
vendored
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
name: Test documentation build
|
||||||
|
|
||||||
|
on: [pull_request]
|
||||||
|
|
||||||
|
concurrency:
|
||||||
|
group: ${{ github.workflow }}-$${{ github.head_ref || github.run_id }}
|
||||||
|
cancel-in-progress: true
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
test:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Checkout repository
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
- name: Install python
|
||||||
|
uses: actions/setup-python@v4
|
||||||
|
with:
|
||||||
|
python-version: 3.x
|
||||||
|
- name: Setup cache
|
||||||
|
uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
key: ${{ github.ref }}
|
||||||
|
path: .cache
|
||||||
|
- name: Setup dependencies
|
||||||
|
run: pip install -r docs/requirements.txt
|
||||||
|
- name: Build docs
|
||||||
|
run: mkdocs build --strict
|
@@ -137,12 +137,6 @@ disable_check_updates: false
|
|||||||
# Time before an inactive ephemeral node is deleted?
|
# Time before an inactive ephemeral node is deleted?
|
||||||
ephemeral_node_inactivity_timeout: 30m
|
ephemeral_node_inactivity_timeout: 30m
|
||||||
|
|
||||||
# Period to check for node updates within the tailnet. A value too low will severely affect
|
|
||||||
# CPU consumption of Headscale. A value too high (over 60s) will cause problems
|
|
||||||
# for the nodes, as they won't get updates or keep alive messages frequently enough.
|
|
||||||
# In case of doubts, do not touch the default 10s.
|
|
||||||
node_update_check_interval: 10s
|
|
||||||
|
|
||||||
database:
|
database:
|
||||||
type: sqlite
|
type: sqlite
|
||||||
|
|
||||||
|
@@ -1,5 +1,4 @@
|
|||||||
cairosvg~=2.7.1
|
cairosvg~=2.7.1
|
||||||
mkdocs-material~=9.4.14
|
mkdocs-material~=9.5.18
|
||||||
mkdocs-minify-plugin~=0.7.1
|
mkdocs-minify-plugin~=0.7.1
|
||||||
pillow~=10.1.0
|
pillow~=10.1.0
|
||||||
|
|
||||||
|
@@ -6,9 +6,10 @@
|
|||||||
maintained by the Headscale authors and are written by community members.
|
maintained by the Headscale authors and are written by community members.
|
||||||
|
|
||||||
| Name | Repository Link | Description | Status |
|
| Name | Repository Link | Description | Status |
|
||||||
| --------------- | ------------------------------------------------------- | ------------------------------------------------------------------------- | ------ |
|
| --------------- | ------------------------------------------------------- | --------------------------------------------------------------------------- | ------ |
|
||||||
| headscale-webui | [Github](https://github.com/ifargle/headscale-webui) | A simple Headscale web UI for small-scale deployments. | Alpha |
|
| headscale-webui | [Github](https://github.com/ifargle/headscale-webui) | A simple Headscale web UI for small-scale deployments. | Alpha |
|
||||||
| headscale-ui | [Github](https://github.com/gurucomputing/headscale-ui) | A web frontend for the headscale Tailscale-compatible coordination server | Alpha |
|
| headscale-ui | [Github](https://github.com/gurucomputing/headscale-ui) | A web frontend for the headscale Tailscale-compatible coordination server | Alpha |
|
||||||
| HeadscaleUi | [GitHub](https://github.com/simcu/headscale-ui) | A static headscale admin ui, no backend enviroment required | Alpha |
|
| HeadscaleUi | [GitHub](https://github.com/simcu/headscale-ui) | A static headscale admin ui, no backend enviroment required | Alpha |
|
||||||
|
| headscale-admin | [Github](https://github.com/GoodiesHQ/headscale-admin) | Headscale-Admin is meant to be a simple, modern web interface for Headscale | Beta |
|
||||||
|
|
||||||
You can ask for support on our dedicated [Discord channel](https://discord.com/channels/896711691637780480/1105842846386356294).
|
You can ask for support on our dedicated [Discord channel](https://discord.com/channels/896711691637780480/1105842846386356294).
|
||||||
|
@@ -206,6 +206,11 @@ func SetTags(
|
|||||||
tags []string,
|
tags []string,
|
||||||
) error {
|
) error {
|
||||||
if len(tags) == 0 {
|
if len(tags) == 0 {
|
||||||
|
// if no tags are provided, we remove all forced tags
|
||||||
|
if err := tx.Model(&types.Node{}).Where("id = ?", nodeID).Update("forced_tags", types.StringList{}).Error; err != nil {
|
||||||
|
return fmt.Errorf("failed to remove tags for node in the database: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -386,6 +386,13 @@ func (s *Suite) TestSetTags(c *check.C) {
|
|||||||
check.DeepEquals,
|
check.DeepEquals,
|
||||||
types.StringList([]string{"tag:bar", "tag:test", "tag:unknown"}),
|
types.StringList([]string{"tag:bar", "tag:test", "tag:unknown"}),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// test removing tags
|
||||||
|
err = db.SetTags(node.ID, []string{})
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
node, err = db.getNode("test", "testnode")
|
||||||
|
c.Assert(err, check.IsNil)
|
||||||
|
c.Assert(node.ForcedTags, check.DeepEquals, types.StringList([]string{}))
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestHeadscale_generateGivenName(t *testing.T) {
|
func TestHeadscale_generateGivenName(t *testing.T) {
|
||||||
|
@@ -46,7 +46,6 @@ type Config struct {
|
|||||||
GRPCAddr string
|
GRPCAddr string
|
||||||
GRPCAllowInsecure bool
|
GRPCAllowInsecure bool
|
||||||
EphemeralNodeInactivityTimeout time.Duration
|
EphemeralNodeInactivityTimeout time.Duration
|
||||||
NodeUpdateCheckInterval time.Duration
|
|
||||||
PrefixV4 *netip.Prefix
|
PrefixV4 *netip.Prefix
|
||||||
PrefixV6 *netip.Prefix
|
PrefixV6 *netip.Prefix
|
||||||
IPAllocation IPAllocationStrategy
|
IPAllocation IPAllocationStrategy
|
||||||
@@ -233,8 +232,6 @@ func LoadConfig(path string, isFile bool) error {
|
|||||||
|
|
||||||
viper.SetDefault("ephemeral_node_inactivity_timeout", "120s")
|
viper.SetDefault("ephemeral_node_inactivity_timeout", "120s")
|
||||||
|
|
||||||
viper.SetDefault("node_update_check_interval", "10s")
|
|
||||||
|
|
||||||
viper.SetDefault("tuning.batch_change_delay", "800ms")
|
viper.SetDefault("tuning.batch_change_delay", "800ms")
|
||||||
viper.SetDefault("tuning.node_mapsession_buffered_chan_size", 30)
|
viper.SetDefault("tuning.node_mapsession_buffered_chan_size", 30)
|
||||||
|
|
||||||
@@ -290,15 +287,6 @@ func LoadConfig(path string, isFile bool) error {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
maxNodeUpdateCheckInterval, _ := time.ParseDuration("60s")
|
|
||||||
if viper.GetDuration("node_update_check_interval") > maxNodeUpdateCheckInterval {
|
|
||||||
errorText += fmt.Sprintf(
|
|
||||||
"Fatal config error: node_update_check_interval (%s) is set too high, must be less than %s",
|
|
||||||
viper.GetString("node_update_check_interval"),
|
|
||||||
maxNodeUpdateCheckInterval,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
if errorText != "" {
|
if errorText != "" {
|
||||||
// nolint
|
// nolint
|
||||||
return errors.New(strings.TrimSuffix(errorText, "\n"))
|
return errors.New(strings.TrimSuffix(errorText, "\n"))
|
||||||
@@ -714,10 +702,6 @@ func GetHeadscaleConfig() (*Config, error) {
|
|||||||
"ephemeral_node_inactivity_timeout",
|
"ephemeral_node_inactivity_timeout",
|
||||||
),
|
),
|
||||||
|
|
||||||
NodeUpdateCheckInterval: viper.GetDuration(
|
|
||||||
"node_update_check_interval",
|
|
||||||
),
|
|
||||||
|
|
||||||
Database: GetDatabaseConfig(),
|
Database: GetDatabaseConfig(),
|
||||||
|
|
||||||
TLS: GetTLSConfig(),
|
TLS: GetTLSConfig(),
|
||||||
|
@@ -73,7 +73,6 @@ database:
|
|||||||
type: sqlite3
|
type: sqlite3
|
||||||
sqlite.path: /tmp/integration_test_db.sqlite3
|
sqlite.path: /tmp/integration_test_db.sqlite3
|
||||||
ephemeral_node_inactivity_timeout: 30m
|
ephemeral_node_inactivity_timeout: 30m
|
||||||
node_update_check_interval: 10s
|
|
||||||
prefixes:
|
prefixes:
|
||||||
v6: fd7a:115c:a1e0::/48
|
v6: fd7a:115c:a1e0::/48
|
||||||
v4: 100.64.0.0/10
|
v4: 100.64.0.0/10
|
||||||
@@ -116,7 +115,6 @@ func DefaultConfigEnv() map[string]string {
|
|||||||
"HEADSCALE_DATABASE_TYPE": "sqlite",
|
"HEADSCALE_DATABASE_TYPE": "sqlite",
|
||||||
"HEADSCALE_DATABASE_SQLITE_PATH": "/tmp/integration_test_db.sqlite3",
|
"HEADSCALE_DATABASE_SQLITE_PATH": "/tmp/integration_test_db.sqlite3",
|
||||||
"HEADSCALE_EPHEMERAL_NODE_INACTIVITY_TIMEOUT": "30m",
|
"HEADSCALE_EPHEMERAL_NODE_INACTIVITY_TIMEOUT": "30m",
|
||||||
"HEADSCALE_NODE_UPDATE_CHECK_INTERVAL": "10s",
|
|
||||||
"HEADSCALE_PREFIXES_V4": "100.64.0.0/10",
|
"HEADSCALE_PREFIXES_V4": "100.64.0.0/10",
|
||||||
"HEADSCALE_PREFIXES_V6": "fd7a:115c:a1e0::/48",
|
"HEADSCALE_PREFIXES_V6": "fd7a:115c:a1e0::/48",
|
||||||
"HEADSCALE_DNS_CONFIG_BASE_DOMAIN": "headscale.net",
|
"HEADSCALE_DNS_CONFIG_BASE_DOMAIN": "headscale.net",
|
||||||
|
Reference in New Issue
Block a user