mirror of
https://github.com/0ceanSlim/grain.git
synced 2024-11-23 09:07:12 +00:00
Compare commits
2 Commits
f1511a9b8b
...
4fef7088bb
Author | SHA1 | Date | |
---|---|---|---|
4fef7088bb | |||
c51199737b |
@ -59,6 +59,31 @@ func CheckBlacklist(pubkey, eventContent string) (bool, string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check mutelist blacklist
|
||||||
|
if len(blacklistConfig.MuteListAuthors) > 0 {
|
||||||
|
cfg := GetConfig()
|
||||||
|
if cfg == nil {
|
||||||
|
log.Println("Server configuration is not loaded")
|
||||||
|
return true, "Internal server error: server configuration is missing"
|
||||||
|
}
|
||||||
|
|
||||||
|
localRelayURL := fmt.Sprintf("ws://localhost%s", cfg.Server.Port)
|
||||||
|
mutelistedPubkeys, err := FetchPubkeysFromLocalMuteList(localRelayURL, blacklistConfig.MuteListAuthors)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Error fetching pubkeys from mutelist: %v", err)
|
||||||
|
return true, "Error fetching pubkeys from mutelist"
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, mutelistedPubkey := range mutelistedPubkeys {
|
||||||
|
if pubkey == mutelistedPubkey {
|
||||||
|
log.Printf("Pubkey %s is in the mutelist", pubkey)
|
||||||
|
return true, "not allowed: pubkey is in mutelist"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log.Println("No mutelist event IDs specified in the blacklist configuration")
|
||||||
|
}
|
||||||
|
|
||||||
return false, ""
|
return false, ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,27 +2,51 @@ package config
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
nostr "grain/server/types"
|
||||||
"grain/server/utils"
|
"grain/server/utils"
|
||||||
|
"log"
|
||||||
"strconv"
|
"strconv"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Check if a pubkey or npub is whitelisted
|
// CheckWhitelist checks if an event meets the whitelist criteria.
|
||||||
func IsPubKeyWhitelisted(pubKey string) bool {
|
func CheckWhitelist(evt nostr.Event) (bool, string) {
|
||||||
cfg := GetWhitelistConfig()
|
whitelistCfg := GetWhitelistConfig()
|
||||||
if !cfg.PubkeyWhitelist.Enabled {
|
if whitelistCfg == nil {
|
||||||
return true
|
return false, "Internal server error: whitelist configuration is missing"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check if the event's kind is whitelisted
|
||||||
|
if whitelistCfg.KindWhitelist.Enabled && !IsKindWhitelisted(evt.Kind) {
|
||||||
|
return false, "not allowed: event kind is not whitelisted"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the event's pubkey is whitelisted
|
||||||
|
if whitelistCfg.PubkeyWhitelist.Enabled && !IsPubKeyWhitelisted(evt.PubKey) {
|
||||||
|
return false, "not allowed: pubkey or npub is not whitelisted"
|
||||||
|
}
|
||||||
|
|
||||||
|
return true, ""
|
||||||
|
}
|
||||||
|
|
||||||
|
// IsPubKeyWhitelisted checks if a pubkey or npub is whitelisted, considering pubkeys from domains.
|
||||||
|
func IsPubKeyWhitelisted(pubKey string) bool {
|
||||||
|
cfg := GetWhitelistConfig()
|
||||||
|
if cfg == nil || !cfg.PubkeyWhitelist.Enabled {
|
||||||
|
return true // Whitelisting is not enforced if the configuration is missing or disabled
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check statically defined pubkeys
|
||||||
for _, whitelistedKey := range cfg.PubkeyWhitelist.Pubkeys {
|
for _, whitelistedKey := range cfg.PubkeyWhitelist.Pubkeys {
|
||||||
if pubKey == whitelistedKey {
|
if pubKey == whitelistedKey {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check statically defined npubs after decoding them to pubkeys
|
||||||
for _, npub := range cfg.PubkeyWhitelist.Npubs {
|
for _, npub := range cfg.PubkeyWhitelist.Npubs {
|
||||||
decodedPubKey, err := utils.DecodeNpub(npub)
|
decodedPubKey, err := utils.DecodeNpub(npub)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Error decoding npub:", err)
|
log.Printf("Error decoding npub: %v", err)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
if pubKey == decodedPubKey {
|
if pubKey == decodedPubKey {
|
||||||
@ -30,6 +54,22 @@ func IsPubKeyWhitelisted(pubKey string) bool {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Fetch and check pubkeys from domains if domain whitelisting is enabled
|
||||||
|
if cfg.DomainWhitelist.Enabled {
|
||||||
|
domains := cfg.DomainWhitelist.Domains
|
||||||
|
pubkeys, err := utils.FetchPubkeysFromDomains(domains)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("Error fetching pubkeys from domains: %v", err)
|
||||||
|
return false // Consider returning true or handling based on your application's needs
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, domainPubKey := range pubkeys {
|
||||||
|
if pubKey == domainPubKey {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,77 +106,16 @@ func validateEventTimestamp(evt nostr.Event) bool {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func handleBlacklistAndWhitelist(ws *websocket.Conn, evt nostr.Event) bool {
|
func handleBlacklistAndWhitelist(ws *websocket.Conn, evt nostr.Event) bool {
|
||||||
// Get the current whitelist configuration
|
// Use the updated CheckBlacklist function
|
||||||
whitelistCfg := config.GetWhitelistConfig()
|
|
||||||
if whitelistCfg == nil {
|
|
||||||
fmt.Println("Whitelist configuration is not loaded.")
|
|
||||||
response.SendNotice(ws, "", "Internal server error: whitelist configuration is missing")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
// If domain whitelisting is enabled, dynamically fetch pubkeys from domains
|
|
||||||
if whitelistCfg.DomainWhitelist.Enabled {
|
|
||||||
domains := whitelistCfg.DomainWhitelist.Domains
|
|
||||||
pubkeys, err := utils.FetchPubkeysFromDomains(domains)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("Error fetching pubkeys from domains:", err)
|
|
||||||
response.SendNotice(ws, "", "Error fetching pubkeys from domains")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
// Update the whitelisted pubkeys dynamically
|
|
||||||
whitelistCfg.PubkeyWhitelist.Pubkeys = append(whitelistCfg.PubkeyWhitelist.Pubkeys, pubkeys...)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if the event's pubkey or content is blacklisted
|
|
||||||
if blacklisted, msg := config.CheckBlacklist(evt.PubKey, evt.Content); blacklisted {
|
if blacklisted, msg := config.CheckBlacklist(evt.PubKey, evt.Content); blacklisted {
|
||||||
response.SendOK(ws, evt.ID, false, msg)
|
response.SendOK(ws, evt.ID, false, msg)
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check mutelist blacklist
|
// Check the whitelist using CheckWhitelist function
|
||||||
cfg := config.GetConfig()
|
isWhitelisted, msg := config.CheckWhitelist(evt)
|
||||||
if cfg == nil {
|
if !isWhitelisted {
|
||||||
fmt.Println("Server configuration is not loaded")
|
response.SendOK(ws, evt.ID, false, msg)
|
||||||
response.SendNotice(ws, "", "Internal server error: server configuration is missing")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
blacklistCfg := config.GetBlacklistConfig()
|
|
||||||
if blacklistCfg == nil {
|
|
||||||
fmt.Println("Blacklist configuration is not loaded")
|
|
||||||
response.SendNotice(ws, "", "Internal server error: blacklist configuration is missing")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
// Only proceed if there are mutelist event IDs specified
|
|
||||||
if len(blacklistCfg.MuteListAuthors) > 0 {
|
|
||||||
localRelayURL := fmt.Sprintf("ws://localhost%s", cfg.Server.Port)
|
|
||||||
mutelistedPubkeys, err := config.FetchPubkeysFromLocalMuteList(localRelayURL, blacklistCfg.MuteListAuthors)
|
|
||||||
if err != nil {
|
|
||||||
fmt.Println("Error fetching pubkeys from mutelist:", err)
|
|
||||||
response.SendNotice(ws, "", "Error fetching pubkeys from mutelist")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
for _, mutelistedPubkey := range mutelistedPubkeys {
|
|
||||||
if evt.PubKey == mutelistedPubkey {
|
|
||||||
response.SendOK(ws, evt.ID, false, "not allowed: pubkey is in mutelist")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
fmt.Println("No mutelist event IDs specified in the blacklist configuration")
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if the event's kind is whitelisted
|
|
||||||
if whitelistCfg.KindWhitelist.Enabled && !config.IsKindWhitelisted(evt.Kind) {
|
|
||||||
response.SendOK(ws, evt.ID, false, "not allowed: event kind is not whitelisted")
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if the event's pubkey is whitelisted
|
|
||||||
if whitelistCfg.PubkeyWhitelist.Enabled && !config.IsPubKeyWhitelisted(evt.PubKey) {
|
|
||||||
response.SendOK(ws, evt.ID, false, "not allowed: pubkey or npub is not whitelisted")
|
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user