Compare commits
5 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 115802cbe2 | |||
| 42fff97e17 | |||
| 0fe2e90d9a | |||
| 94aa3a9002 | |||
| 1455ce6e0f |
@@ -58,7 +58,7 @@ deploy/ Docker, systemd, install scripts, examples
|
|||||||
|
|
||||||
## Shared Library
|
## Shared Library
|
||||||
|
|
||||||
MCNS uses `mcdsl` (git.wntrmute.dev/kyle/mcdsl) for shared platform packages:
|
MCNS uses `mcdsl` (git.wntrmute.dev/mc/mcdsl) for shared platform packages:
|
||||||
auth, db, config, httpserver, grpcserver. These provide MCIAS authentication,
|
auth, db, config, httpserver, grpcserver. These provide MCIAS authentication,
|
||||||
SQLite database helpers, TOML config loading, and TLS-configured HTTP/gRPC
|
SQLite database helpers, TOML config loading, and TLS-configured HTTP/gRPC
|
||||||
server scaffolding.
|
server scaffolding.
|
||||||
|
|||||||
4
Makefile
4
Makefile
@@ -18,8 +18,8 @@ lint:
|
|||||||
golangci-lint run ./...
|
golangci-lint run ./...
|
||||||
|
|
||||||
proto:
|
proto:
|
||||||
protoc --go_out=. --go_opt=module=git.wntrmute.dev/kyle/mcns \
|
protoc --go_out=. --go_opt=module=git.wntrmute.dev/mc/mcns \
|
||||||
--go-grpc_out=. --go-grpc_opt=module=git.wntrmute.dev/kyle/mcns \
|
--go-grpc_out=. --go-grpc_opt=module=git.wntrmute.dev/mc/mcns \
|
||||||
proto/mcns/v1/*.proto
|
proto/mcns/v1/*.proto
|
||||||
|
|
||||||
proto-lint:
|
proto-lint:
|
||||||
|
|||||||
22
RUNBOOK.md
22
RUNBOOK.md
@@ -230,6 +230,28 @@ Symptoms: MCNS fails to start with "address already in use" on port 53.
|
|||||||
`[dns] listen_addr` in `mcns.toml` to a different address.
|
`[dns] listen_addr` in `mcns.toml` to a different address.
|
||||||
4. Restart MCNS and verify DNS is responding.
|
4. Restart MCNS and verify DNS is responding.
|
||||||
|
|
||||||
|
## Deployment with MCP
|
||||||
|
|
||||||
|
MCNS runs on rift as a single container managed by MCP. The service
|
||||||
|
definition lives at `~/.config/mcp/services/mcns.toml` on the operator's
|
||||||
|
machine. A reference copy is maintained at `deploy/mcns-rift.toml` in
|
||||||
|
this repository.
|
||||||
|
|
||||||
|
The container image is pulled from MCR. The container mounts `/srv/mcns`
|
||||||
|
and runs as `--user 0:0`. DNS listens on port 53 (UDP+TCP) on both
|
||||||
|
192.168.88.181 and 100.95.252.120, with the management API on 8443/9443.
|
||||||
|
|
||||||
|
Note: the operator's `~/.config/mcp/services/mcns.toml` may still
|
||||||
|
reference the old CoreDNS image and needs updating to the new MCNS image.
|
||||||
|
|
||||||
|
### Key Operations
|
||||||
|
|
||||||
|
1. Deploy or update: `mcp deploy mcns`
|
||||||
|
2. Restart: `mcp restart mcns`
|
||||||
|
3. Stop: `mcp stop mcns` (WARNING: stops DNS for all internal zones)
|
||||||
|
4. Check status: `mcp ps` or `mcp status mcns`
|
||||||
|
5. View logs: `ssh rift 'doas su - mcp -s /bin/sh -c "podman logs mcns"'`
|
||||||
|
|
||||||
## Escalation
|
## Escalation
|
||||||
|
|
||||||
Escalate when:
|
Escalate when:
|
||||||
|
|||||||
@@ -16,14 +16,14 @@ import (
|
|||||||
|
|
||||||
"github.com/spf13/cobra"
|
"github.com/spf13/cobra"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
mcdsldb "git.wntrmute.dev/kyle/mcdsl/db"
|
mcdsldb "git.wntrmute.dev/mc/mcdsl/db"
|
||||||
|
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/config"
|
"git.wntrmute.dev/mc/mcns/internal/config"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
mcnsdns "git.wntrmute.dev/kyle/mcns/internal/dns"
|
mcnsdns "git.wntrmute.dev/mc/mcns/internal/dns"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/grpcserver"
|
"git.wntrmute.dev/mc/mcns/internal/grpcserver"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/server"
|
"git.wntrmute.dev/mc/mcns/internal/server"
|
||||||
)
|
)
|
||||||
|
|
||||||
var version = "dev"
|
var version = "dev"
|
||||||
|
|||||||
17
deploy/mcns-rift.toml
Normal file
17
deploy/mcns-rift.toml
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
name = "mcns"
|
||||||
|
node = "rift"
|
||||||
|
active = true
|
||||||
|
|
||||||
|
[[components]]
|
||||||
|
name = "dns"
|
||||||
|
image = "mcr.svc.mcp.metacircular.net:8443/mcns:latest"
|
||||||
|
user = "0:0"
|
||||||
|
restart = "unless-stopped"
|
||||||
|
ports = [
|
||||||
|
"192.168.88.181:53:53/tcp",
|
||||||
|
"192.168.88.181:53:53/udp",
|
||||||
|
"100.95.252.120:53:53/tcp",
|
||||||
|
"100.95.252.120:53:53/udp",
|
||||||
|
]
|
||||||
|
volumes = ["/srv/mcns:/srv/mcns"]
|
||||||
|
cmd = ["server", "--config", "/srv/mcns/mcns.toml"]
|
||||||
@@ -110,7 +110,7 @@ const file_proto_mcns_v1_admin_proto_rawDesc = "" +
|
|||||||
"\x0eHealthResponse\x12\x16\n" +
|
"\x0eHealthResponse\x12\x16\n" +
|
||||||
"\x06status\x18\x01 \x01(\tR\x06status2I\n" +
|
"\x06status\x18\x01 \x01(\tR\x06status2I\n" +
|
||||||
"\fAdminService\x129\n" +
|
"\fAdminService\x129\n" +
|
||||||
"\x06Health\x12\x16.mcns.v1.HealthRequest\x1a\x17.mcns.v1.HealthResponseB/Z-git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
"\x06Health\x12\x16.mcns.v1.HealthRequest\x1a\x17.mcns.v1.HealthResponseB/Z-git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
file_proto_mcns_v1_admin_proto_rawDescOnce sync.Once
|
file_proto_mcns_v1_admin_proto_rawDescOnce sync.Once
|
||||||
|
|||||||
@@ -222,7 +222,7 @@ const file_proto_mcns_v1_auth_proto_rawDesc = "" +
|
|||||||
"\x0eLogoutResponse2\x80\x01\n" +
|
"\x0eLogoutResponse2\x80\x01\n" +
|
||||||
"\vAuthService\x126\n" +
|
"\vAuthService\x126\n" +
|
||||||
"\x05Login\x12\x15.mcns.v1.LoginRequest\x1a\x16.mcns.v1.LoginResponse\x129\n" +
|
"\x05Login\x12\x15.mcns.v1.LoginRequest\x1a\x16.mcns.v1.LoginResponse\x129\n" +
|
||||||
"\x06Logout\x12\x16.mcns.v1.LogoutRequest\x1a\x17.mcns.v1.LogoutResponseB/Z-git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
"\x06Logout\x12\x16.mcns.v1.LogoutRequest\x1a\x17.mcns.v1.LogoutResponseB/Z-git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
file_proto_mcns_v1_auth_proto_rawDescOnce sync.Once
|
file_proto_mcns_v1_auth_proto_rawDescOnce sync.Once
|
||||||
|
|||||||
@@ -551,7 +551,7 @@ const file_proto_mcns_v1_record_proto_rawDesc = "" +
|
|||||||
"\fCreateRecord\x12\x1c.mcns.v1.CreateRecordRequest\x1a\x0f.mcns.v1.Record\x127\n" +
|
"\fCreateRecord\x12\x1c.mcns.v1.CreateRecordRequest\x1a\x0f.mcns.v1.Record\x127\n" +
|
||||||
"\tGetRecord\x12\x19.mcns.v1.GetRecordRequest\x1a\x0f.mcns.v1.Record\x12=\n" +
|
"\tGetRecord\x12\x19.mcns.v1.GetRecordRequest\x1a\x0f.mcns.v1.Record\x12=\n" +
|
||||||
"\fUpdateRecord\x12\x1c.mcns.v1.UpdateRecordRequest\x1a\x0f.mcns.v1.Record\x12K\n" +
|
"\fUpdateRecord\x12\x1c.mcns.v1.UpdateRecordRequest\x1a\x0f.mcns.v1.Record\x12K\n" +
|
||||||
"\fDeleteRecord\x12\x1c.mcns.v1.DeleteRecordRequest\x1a\x1d.mcns.v1.DeleteRecordResponseB/Z-git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
"\fDeleteRecord\x12\x1c.mcns.v1.DeleteRecordRequest\x1a\x1d.mcns.v1.DeleteRecordResponseB/Z-git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
file_proto_mcns_v1_record_proto_rawDescOnce sync.Once
|
file_proto_mcns_v1_record_proto_rawDescOnce sync.Once
|
||||||
|
|||||||
@@ -595,7 +595,7 @@ const file_proto_mcns_v1_zone_proto_rawDesc = "" +
|
|||||||
"\n" +
|
"\n" +
|
||||||
"UpdateZone\x12\x1a.mcns.v1.UpdateZoneRequest\x1a\r.mcns.v1.Zone\x12E\n" +
|
"UpdateZone\x12\x1a.mcns.v1.UpdateZoneRequest\x1a\r.mcns.v1.Zone\x12E\n" +
|
||||||
"\n" +
|
"\n" +
|
||||||
"DeleteZone\x12\x1a.mcns.v1.DeleteZoneRequest\x1a\x1b.mcns.v1.DeleteZoneResponseB/Z-git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
"DeleteZone\x12\x1a.mcns.v1.DeleteZoneRequest\x1a\x1b.mcns.v1.DeleteZoneResponseB/Z-git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1b\x06proto3"
|
||||||
|
|
||||||
var (
|
var (
|
||||||
file_proto_mcns_v1_zone_proto_rawDescOnce sync.Once
|
file_proto_mcns_v1_zone_proto_rawDescOnce sync.Once
|
||||||
|
|||||||
4
go.mod
4
go.mod
@@ -1,9 +1,9 @@
|
|||||||
module git.wntrmute.dev/kyle/mcns
|
module git.wntrmute.dev/mc/mcns
|
||||||
|
|
||||||
go 1.25.7
|
go 1.25.7
|
||||||
|
|
||||||
require (
|
require (
|
||||||
git.wntrmute.dev/kyle/mcdsl v1.0.0
|
git.wntrmute.dev/mc/mcdsl v1.2.0
|
||||||
github.com/go-chi/chi/v5 v5.2.5
|
github.com/go-chi/chi/v5 v5.2.5
|
||||||
github.com/miekg/dns v1.1.66
|
github.com/miekg/dns v1.1.66
|
||||||
github.com/spf13/cobra v1.10.2
|
github.com/spf13/cobra v1.10.2
|
||||||
|
|||||||
4
go.sum
4
go.sum
@@ -1,5 +1,5 @@
|
|||||||
git.wntrmute.dev/kyle/mcdsl v1.0.0 h1:YB7dx4gdNYKKcVySpL6UkwHqdCJ9Nl1yS0+eHk0hNtk=
|
git.wntrmute.dev/mc/mcdsl v1.2.0 h1:41hep7/PNZJfN0SN/nM+rQpyF1GSZcvNNjyVG81DI7U=
|
||||||
git.wntrmute.dev/kyle/mcdsl v1.0.0/go.mod h1:wo0tGfUAxci3XnOe4/rFmR0RjUElKdYUazc+Np986sg=
|
git.wntrmute.dev/mc/mcdsl v1.2.0/go.mod h1:lXYrAt74ZUix6rx9oVN8d2zH1YJoyp4uxPVKQ+SSxuM=
|
||||||
github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs=
|
github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs=
|
||||||
github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
|
github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs=
|
||||||
github.com/cpuguy83/go-md2man/v2 v2.0.6/go.mod h1:oOW0eioCTA6cOiMLiUPZOpcVxMig6NIQQ7OS05n1F4g=
|
github.com/cpuguy83/go-md2man/v2 v2.0.6/go.mod h1:oOW0eioCTA6cOiMLiUPZOpcVxMig6NIQQ7OS05n1F4g=
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ package config
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
mcdslconfig "git.wntrmute.dev/kyle/mcdsl/config"
|
mcdslconfig "git.wntrmute.dev/mc/mcdsl/config"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Config is the top-level MCNS configuration.
|
// Config is the top-level MCNS configuration.
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ import (
|
|||||||
"database/sql"
|
"database/sql"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
|
||||||
mcdsldb "git.wntrmute.dev/kyle/mcdsl/db"
|
mcdsldb "git.wntrmute.dev/mc/mcdsl/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// DB wraps a SQLite database connection.
|
// DB wraps a SQLite database connection.
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package db
|
package db
|
||||||
|
|
||||||
import (
|
import (
|
||||||
mcdsldb "git.wntrmute.dev/kyle/mcdsl/db"
|
mcdsldb "git.wntrmute.dev/mc/mcdsl/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Migrations is the ordered list of MCNS schema migrations.
|
// Migrations is the ordered list of MCNS schema migrations.
|
||||||
|
|||||||
@@ -10,7 +10,7 @@ import (
|
|||||||
|
|
||||||
"github.com/miekg/dns"
|
"github.com/miekg/dns"
|
||||||
|
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Server is the MCNS DNS server. It listens on both UDP and TCP.
|
// Server is the MCNS DNS server. It listens on both UDP and TCP.
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import (
|
|||||||
|
|
||||||
"github.com/miekg/dns"
|
"github.com/miekg/dns"
|
||||||
|
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
"log/slog"
|
"log/slog"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|||||||
@@ -3,8 +3,8 @@ package grpcserver
|
|||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
|
||||||
pb "git.wntrmute.dev/kyle/mcns/gen/mcns/v1"
|
pb "git.wntrmute.dev/mc/mcns/gen/mcns/v1"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
type adminService struct {
|
type adminService struct {
|
||||||
|
|||||||
@@ -4,11 +4,11 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
"google.golang.org/grpc/codes"
|
"google.golang.org/grpc/codes"
|
||||||
"google.golang.org/grpc/status"
|
"google.golang.org/grpc/status"
|
||||||
|
|
||||||
pb "git.wntrmute.dev/kyle/mcns/gen/mcns/v1"
|
pb "git.wntrmute.dev/mc/mcns/gen/mcns/v1"
|
||||||
)
|
)
|
||||||
|
|
||||||
type authService struct {
|
type authService struct {
|
||||||
|
|||||||
@@ -16,10 +16,10 @@ import (
|
|||||||
"google.golang.org/grpc/metadata"
|
"google.golang.org/grpc/metadata"
|
||||||
"google.golang.org/grpc/status"
|
"google.golang.org/grpc/status"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
|
|
||||||
pb "git.wntrmute.dev/kyle/mcns/gen/mcns/v1"
|
pb "git.wntrmute.dev/mc/mcns/gen/mcns/v1"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// mockMCIAS starts a fake MCIAS HTTP server for token validation.
|
// mockMCIAS starts a fake MCIAS HTTP server for token validation.
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
package grpcserver
|
package grpcserver
|
||||||
|
|
||||||
import (
|
import (
|
||||||
mcdslgrpc "git.wntrmute.dev/kyle/mcdsl/grpcserver"
|
mcdslgrpc "git.wntrmute.dev/mc/mcdsl/grpcserver"
|
||||||
)
|
)
|
||||||
|
|
||||||
// methodMap builds the mcdsl grpcserver.MethodMap for MCNS.
|
// methodMap builds the mcdsl grpcserver.MethodMap for MCNS.
|
||||||
|
|||||||
@@ -10,8 +10,8 @@ import (
|
|||||||
"google.golang.org/grpc/status"
|
"google.golang.org/grpc/status"
|
||||||
"google.golang.org/protobuf/types/known/timestamppb"
|
"google.golang.org/protobuf/types/known/timestamppb"
|
||||||
|
|
||||||
pb "git.wntrmute.dev/kyle/mcns/gen/mcns/v1"
|
pb "git.wntrmute.dev/mc/mcns/gen/mcns/v1"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
type recordService struct {
|
type recordService struct {
|
||||||
|
|||||||
@@ -4,11 +4,11 @@ import (
|
|||||||
"log/slog"
|
"log/slog"
|
||||||
"net"
|
"net"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
mcdslgrpc "git.wntrmute.dev/kyle/mcdsl/grpcserver"
|
mcdslgrpc "git.wntrmute.dev/mc/mcdsl/grpcserver"
|
||||||
|
|
||||||
pb "git.wntrmute.dev/kyle/mcns/gen/mcns/v1"
|
pb "git.wntrmute.dev/mc/mcns/gen/mcns/v1"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Deps holds the dependencies injected into the gRPC server.
|
// Deps holds the dependencies injected into the gRPC server.
|
||||||
@@ -24,7 +24,7 @@ type Server struct {
|
|||||||
|
|
||||||
// New creates a configured gRPC server with MCNS services registered.
|
// New creates a configured gRPC server with MCNS services registered.
|
||||||
func New(certFile, keyFile string, deps Deps, logger *slog.Logger) (*Server, error) {
|
func New(certFile, keyFile string, deps Deps, logger *slog.Logger) (*Server, error) {
|
||||||
srv, err := mcdslgrpc.New(certFile, keyFile, deps.Authenticator, methodMap(), logger)
|
srv, err := mcdslgrpc.New(certFile, keyFile, deps.Authenticator, methodMap(), logger, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,8 +9,8 @@ import (
|
|||||||
"google.golang.org/grpc/status"
|
"google.golang.org/grpc/status"
|
||||||
"google.golang.org/protobuf/types/known/timestamppb"
|
"google.golang.org/protobuf/types/known/timestamppb"
|
||||||
|
|
||||||
pb "git.wntrmute.dev/kyle/mcns/gen/mcns/v1"
|
pb "git.wntrmute.dev/mc/mcns/gen/mcns/v1"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
type zoneService struct {
|
type zoneService struct {
|
||||||
|
|||||||
@@ -5,7 +5,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
)
|
)
|
||||||
|
|
||||||
type loginRequest struct {
|
type loginRequest struct {
|
||||||
|
|||||||
@@ -12,8 +12,8 @@ import (
|
|||||||
|
|
||||||
"github.com/go-chi/chi/v5"
|
"github.com/go-chi/chi/v5"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// openTestDB creates a temporary SQLite database with all migrations applied.
|
// openTestDB creates a temporary SQLite database with all migrations applied.
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import (
|
|||||||
"strings"
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
)
|
)
|
||||||
|
|
||||||
type contextKey string
|
type contextKey string
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ import (
|
|||||||
|
|
||||||
"github.com/go-chi/chi/v5"
|
"github.com/go-chi/chi/v5"
|
||||||
|
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
type createRecordRequest struct {
|
type createRecordRequest struct {
|
||||||
|
|||||||
@@ -7,10 +7,10 @@ import (
|
|||||||
|
|
||||||
"github.com/go-chi/chi/v5"
|
"github.com/go-chi/chi/v5"
|
||||||
|
|
||||||
mcdslauth "git.wntrmute.dev/kyle/mcdsl/auth"
|
mcdslauth "git.wntrmute.dev/mc/mcdsl/auth"
|
||||||
"git.wntrmute.dev/kyle/mcdsl/health"
|
"git.wntrmute.dev/mc/mcdsl/health"
|
||||||
|
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Deps holds dependencies injected into the REST handlers.
|
// Deps holds dependencies injected into the REST handlers.
|
||||||
|
|||||||
@@ -7,7 +7,7 @@ import (
|
|||||||
|
|
||||||
"github.com/go-chi/chi/v5"
|
"github.com/go-chi/chi/v5"
|
||||||
|
|
||||||
"git.wntrmute.dev/kyle/mcns/internal/db"
|
"git.wntrmute.dev/mc/mcns/internal/db"
|
||||||
)
|
)
|
||||||
|
|
||||||
type createZoneRequest struct {
|
type createZoneRequest struct {
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ syntax = "proto3";
|
|||||||
|
|
||||||
package mcns.v1;
|
package mcns.v1;
|
||||||
|
|
||||||
option go_package = "git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1";
|
option go_package = "git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1";
|
||||||
|
|
||||||
// AdminService exposes server health and administrative operations.
|
// AdminService exposes server health and administrative operations.
|
||||||
service AdminService {
|
service AdminService {
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ syntax = "proto3";
|
|||||||
|
|
||||||
package mcns.v1;
|
package mcns.v1;
|
||||||
|
|
||||||
option go_package = "git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1";
|
option go_package = "git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1";
|
||||||
|
|
||||||
// AuthService handles authentication by delegating to MCIAS.
|
// AuthService handles authentication by delegating to MCIAS.
|
||||||
service AuthService {
|
service AuthService {
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ syntax = "proto3";
|
|||||||
|
|
||||||
package mcns.v1;
|
package mcns.v1;
|
||||||
|
|
||||||
option go_package = "git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1";
|
option go_package = "git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1";
|
||||||
|
|
||||||
import "google/protobuf/timestamp.proto";
|
import "google/protobuf/timestamp.proto";
|
||||||
|
|
||||||
|
|||||||
@@ -2,7 +2,7 @@ syntax = "proto3";
|
|||||||
|
|
||||||
package mcns.v1;
|
package mcns.v1;
|
||||||
|
|
||||||
option go_package = "git.wntrmute.dev/kyle/mcns/gen/mcns/v1;mcnsv1";
|
option go_package = "git.wntrmute.dev/mc/mcns/gen/mcns/v1;mcnsv1";
|
||||||
|
|
||||||
import "google/protobuf/timestamp.proto";
|
import "google/protobuf/timestamp.proto";
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user