Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v1.0.0 Release preparation #71

Merged
merged 110 commits into from
Aug 21, 2021
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
110 commits
Select commit Hold shift click to select a range
0d9edde
updating go modules
Mzack9999 Nov 20, 2020
ae53e0c
adding email notification
Mzack9999 Nov 21, 2020
c87ce3c
adding smtp interaction support
Mzack9999 Nov 22, 2020
daf46a8
updating go modules
Mzack9999 Nov 26, 2020
54095ef
updating go modules
Mzack9999 Nov 26, 2020
ab8e348
pcap to proxy
Mzack9999 Dec 6, 2020
3b1dcd5
Merge pull request #16 from projectdiscovery/feature-smtp-support
Mzack9999 Dec 10, 2020
b8ee290
merge dev
Mzack9999 Dec 10, 2020
1f98071
updating yaml package
Mzack9999 Dec 10, 2020
5b09cc6
wip - go modules
Mzack9999 Dec 10, 2020
613c157
updating go modules
Mzack9999 Dec 11, 2020
2487d8e
Merge pull request #17 from projectdiscovery/feature-pcap-to-proxy
Mzack9999 Dec 11, 2020
210582a
Updating intercept instructions
Mzack9999 Dec 11, 2020
81af4e2
Merge pull request #18 from projectdiscovery/update-intercept-instruc…
Mzack9999 Dec 11, 2020
13d53e8
removing redundant go modules
Mzack9999 Feb 16, 2021
458c38f
using unique go modules
Mzack9999 Feb 16, 2021
7a7ff72
adding intercept binary release
Mzack9999 Feb 16, 2021
aa86cc8
updating gologger
Mzack9999 Feb 16, 2021
52c4683
updating notify/intercept double build test
Mzack9999 Feb 16, 2021
0ef50b0
adding gologger nocolor support
Mzack9999 Feb 17, 2021
ce88644
updating proxify to dev branch
Mzack9999 Feb 17, 2021
8e19090
updated proxify syntax
Mzack9999 Feb 17, 2021
db2e39b
adding bot
Mzack9999 Feb 17, 2021
6786e43
Merge pull request #24 from projectdiscovery/bugfix-gologger-version-…
Mzack9999 Feb 17, 2021
0d90259
adding cache size
Mzack9999 Mar 3, 2021
bb2d8b0
deps version bump
Mzack9999 Mar 3, 2021
af1f46a
Merge pull request #35 from projectdiscovery/bugfix-intercept-error
ehsandeep Mar 4, 2021
6befea7
adding goflags
Mzack9999 Mar 5, 2021
7829970
custom implementation => std library
Mzack9999 Mar 5, 2021
5a6bef4
updating dockerfile
Mzack9999 Mar 5, 2021
3b5569f
Deprecating golint
Mzack9999 May 25, 2021
5b428a0
Update README.md
pdelteil Jun 6, 2021
d259c7a
Update README.md
pdelteil Jun 6, 2021
9922404
fixing lint errors
Mzack9999 Jun 25, 2021
73148c1
updating deps
Mzack9999 Jun 25, 2021
fc54901
updating linter settings
Mzack9999 Jun 25, 2021
6a23403
misc
Mzack9999 Jun 25, 2021
72f9c36
Merge pull request #42 from projectdiscovery/bugfix-41
ehsandeep Jun 25, 2021
59696e3
Merge branch 'dev' into patch-2
ehsandeep Jun 25, 2021
a233822
Merge pull request #46 from pdelteil/patch-2
ehsandeep Jun 25, 2021
fafa7d3
Merge pull request #47 from pdelteil/patch-3
ehsandeep Jun 25, 2021
36913b8
Merge branch 'dev' into maintenance-misc
ehsandeep Jun 25, 2021
e087f10
temporary updating goflags
Mzack9999 Jun 25, 2021
a4813a2
Merge pull request #37 from projectdiscovery/maintenance-misc
Mzack9999 Jun 30, 2021
4a561ae
add -data flag to suport file reading
parrasajad Jul 1, 2021
46fd60c
Merge pull request #52 from projectdiscovery/feature/file_read_suppor…
Mzack9999 Jul 2, 2021
2ab0421
add stdin-all flag
parrasajad Jul 5, 2021
433fb03
fix lint issue
parrasajad Jul 6, 2021
0b6b3e1
add support to send Slack messages in a thread
parrasajad Jul 7, 2021
cdbdda0
put in empty check for slack-thread-ts value
parrasajad Jul 8, 2021
bdb28bd
add char-limit flag and split text by lines
parrasajad Jul 14, 2021
94a17a7
add separate provider config, code restructuring to prepare for custo…
parrasajad Jul 15, 2021
d05526f
log send error
parrasajad Jul 16, 2021
ae037d5
combine error and bytes count check
parrasajad Jul 17, 2021
8ea06d5
Merge pull request #59 from projectdiscovery/provider_config
ehsandeep Jul 20, 2021
b312b24
[Fix] CVE-2020-9283: Improper Signature Verification
smziaurrashid Jul 21, 2021
fbedd5f
resolve merge conflicts
parrasajad Jul 22, 2021
70d8315
resolve merge conflicts
parrasajad Jul 22, 2021
fd01f6f
Merge branch 'dev' into master
ehsandeep Jul 23, 2021
be5f774
Merge pull request #61 from smziaurrashid/master
ehsandeep Jul 23, 2021
ac84d8b
update goflags
parrasajad Jul 24, 2021
80f5241
update goflags, replace stdin-all flag with bulk
parrasajad Jul 24, 2021
45885f6
Merge pull request #55 from projectdiscovery/feature/stdin-all
ehsandeep Jul 24, 2021
cf3087f
add custom webhook URL support
parrasajad Jul 26, 2021
1646482
remove intercept and collaborator
parrasajad Jul 26, 2021
357a3ee
fix default provider config location
parrasajad Jul 26, 2021
618c0f7
remove intercept build instructions
parrasajad Jul 26, 2021
52891a5
change profile to id
parrasajad Jul 30, 2021
71a8622
add flag usage message
parrasajad Jul 30, 2021
6db4ea8
Merge pull request #66 from projectdiscovery/profile-to-id#65
ehsandeep Aug 1, 2021
6557502
add format message option
parrasajad Aug 4, 2021
0eb3987
update README
parrasajad Aug 4, 2021
345777a
Merge branch 'dev' into deprecate-intercept
parrasajad Aug 4, 2021
7af7ef9
update README.md
parrasajad Aug 4, 2021
4a1b07e
add slack threaded message logic to use ts value from first message
parrasajad Aug 5, 2021
b57aec6
slack: remove thread_ts from shoutrrr
parrasajad Aug 5, 2021
57449b0
resolve merge conflicts
parrasajad Aug 5, 2021
02492cf
add http proxy support
parrasajad Aug 5, 2021
56c0bdd
disable shoutrrr splitlines for discord
parrasajad Aug 6, 2021
d32b360
Merge pull request #63 from projectdiscovery/deprecate-intercept
ehsandeep Aug 6, 2021
7a6f60c
Merge branch 'dev' into custom-format#64
parrasajad Aug 7, 2021
b927280
resolve merge conflicts
parrasajad Aug 7, 2021
d5476ab
Merge branch 'dev' into http-proxy
parrasajad Aug 7, 2021
9f7857a
Merge branch 'dev' into custom_webhook
parrasajad Aug 7, 2021
87a9adc
Merge branch 'dev' into feature/slack-threading
parrasajad Aug 7, 2021
c7d3966
Merge pull request #68 from projectdiscovery/http-proxy
ehsandeep Aug 12, 2021
817397f
Merge branch 'dev' into custom-format#64
ehsandeep Aug 12, 2021
4c16002
Merge pull request #67 from projectdiscovery/custom-format#64
ehsandeep Aug 12, 2021
9ef122d
Merge branch 'dev' into feature/slack-threading
parrasajad Aug 13, 2021
2732af9
Merge branch 'dev' into custom_webhook
parrasajad Aug 13, 2021
ba22e28
change CustomBody to CustomFormat
parrasajad Aug 13, 2021
5971c18
Merge pull request #62 from projectdiscovery/custom_webhook
ehsandeep Aug 19, 2021
228e3d4
fix error handling, multi instance issue #70
parrasajad Aug 20, 2021
75164ca
print multierr errors one by one, few error message changes
parrasajad Aug 20, 2021
ad72eab
add verbose logs
parrasajad Aug 20, 2021
7843409
Merge pull request #72 from projectdiscovery/fix/error-handling
ehsandeep Aug 20, 2021
521bb32
GitHub workflow updates
ehsandeep Aug 20, 2021
7dd0f40
Merge pull request #73 from projectdiscovery/workflow-update
ehsandeep Aug 20, 2021
4e417cc
minor update
ehsandeep Aug 20, 2021
db8f19f
readme update
ehsandeep Aug 20, 2021
ad840d6
misc changes
ehsandeep Aug 20, 2021
1b0c3db
Added example for custom webhook support
ehsandeep Aug 20, 2021
4282f6f
Merge branch 'dev' into feature/slack-threading
parrasajad Aug 20, 2021
d3b9e29
change http client for proxy support
parrasajad Aug 20, 2021
c423164
Merge pull request #56 from projectdiscovery/feature/slack-threading
ehsandeep Aug 20, 2021
647a5d4
version update
ehsandeep Aug 20, 2021
39c75f4
Discarding internal shoutrrr logs
Mzack9999 Aug 20, 2021
3a097d5
Merge pull request #74 from projectdiscovery/bugfix-discarding-intern…
ehsandeep Aug 21, 2021
cb33368
example updates
ehsandeep Aug 21, 2021
436e11a
more examples
ehsandeep Aug 21, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 5 additions & 3 deletions cmd/notify/notify.go
Original file line number Diff line number Diff line change
Expand Up @@ -60,10 60,12 @@ func readConfig() {
set.StringVar(&options.DNSMessage, "message-dns", types.DefaultDNSMessage, "DNS Message")
set.StringVar(&options.SMTPMessage, "message-smtp", types.DefaultSMTPMessage, "SMTP Message")
set.StringVar(&options.CLIMessage, "message-cli", types.DefaultCLIMessage, "CLI Message")
set.StringVar(&options.Data, "data", "", "file path to read data from")
set.StringVar(&options.Data, "data", "", "File path to read data from")
set.BoolVar(&options.Bulk, "bulk", false, "Read the input and send it in bulk, character limit can be set using char-limit flag")
set.IntVar(&options.CharLimit, "char-limit", 4000, "Character limit for message")
set.StringVar(&options.ProviderConfig, "provider-config", "", "provider config path (default: $HOME/.config/notify/provider-config.yaml)")
set.StringSliceVar(&options.Providers, "provider", []string{}, "")
set.StringSliceVar(&options.Profiles, "profile", []string{}, "")
set.StringSliceVar(&options.Providers, "provider", []string{}, "provider to send the notification to (optional)")
set.StringSliceVar(&options.IDs, "id", []string{}, "id to send the notification to (optional)")

_ = set.Parse()

Expand Down
71 changes: 55 additions & 16 deletions internal/runner/runner.go
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 57,7 @@ func NewRunner(options *types.Options) (*Runner, error) {

file.Close()

prClient, err := providers.New(&providerOptions, options.Providers, options.Profiles)
prClient, err := providers.New(&providerOptions, options.Providers, options.IDs)
if err != nil {
return nil, err
}
Expand All @@ -67,35 67,59 @@ func NewRunner(options *types.Options) (*Runner, error) {

// Run polling and notification
func (r *Runner) Run() error {
// If stdin is present pass everything to webhooks and exit

// If stdin/file input is present pass everything to webhooks and exit
if hasStdin() || r.options.Data != "" {
var br *bufio.Scanner
var inFile *os.File
var err error

switch {
case hasStdin():
br = bufio.NewScanner(os.Stdin)
inFile = os.Stdin

case r.options.Data != "":
inFile, err := os.Open(r.options.Data)
inFile, err = os.Open(r.options.Data)
if err != nil {
gologger.Fatal().Msgf("%s\n", err)
}
}

if r.options.Bulk {
fi, err := inFile.Stat()
if err != nil {
gologger.Fatal().Msgf("%s\n", err)
}
br = bufio.NewScanner(inFile)

msgB := make([]byte, fi.Size())

n, err := inFile.Read(msgB)
if err != nil || n == 0 {
gologger.Fatal().Msgf("%s\n", err)
}

// char limit to search for a split
searchLimit := 250
if r.options.CharLimit < searchLimit {
searchLimit = r.options.CharLimit
}

items := SplitText(string(msgB), r.options.CharLimit, searchLimit)

for _, v := range items {
if err := r.sendMessage(v); err != nil {
gologger.Fatal().Msgf("%s\n", err)
}
}

os.Exit(0)
}

br := bufio.NewScanner(inFile)
for br.Scan() {
msg := br.Text()
if msg == "" {
continue
}
rr := strings.NewReplacer(
"{{data}}", msg,
)
msg = rr.Replace(r.options.CLIMessage)
gologger.Print().Msgf(msg)
//nolint:errcheck // silent fail
r.providers.Send(msg)
//nolint:errcheck
r.sendMessage(msg)

}
os.Exit(0)
}
Expand Down Expand Up @@ -178,6 202,21 @@ func (r *Runner) Run() error {
}
}

func (r *Runner) sendMessage(msg string) error {
rr := strings.NewReplacer(
"{{data}}", msg,
)
msg = rr.Replace(r.options.CLIMessage)
if len(msg) > 0 {
gologger.Print().Msgf(msg)
err := r.providers.Send(msg)
if err != nil {
return err
}
}
return nil
}

// Close the runner instance
func (r *Runner) Close() {
r.burpcollab.Empty()
Expand Down
59 changes: 59 additions & 0 deletions internal/runner/util.go
Original file line number Diff line number Diff line change
@@ -0,0 1,59 @@
package runner

import (
"math"
)

// SplitText tries to split a string by line while keeping the chunk size as close to maxChunkSize as possible (equal or less than maxChunkSize)
func SplitText(in string, maxChunkSize, searchLimit int) (chunks []string) {
runes := []rune(in)
totalSize := len(runes)
minChunkSize := 1
chunkOffset := 0

if maxChunkSize > searchLimit {
minChunkSize = maxChunkSize - searchLimit
}
maxPossibleChunks := int(math.Ceil(float64(totalSize) / float64(minChunkSize)))

for i := 0; i <= maxPossibleChunks; i {

chunkEnd := chunkOffset maxChunkSize
nextChunkStart := chunkEnd

// Check if it is the last chunk (chunkEnd is greater or equal to total size)
if chunkEnd >= totalSize {
chunkEnd = totalSize
nextChunkStart = totalSize
} else {

//Check for a line break
for j := 0; j < searchLimit; j {

sp := chunkEnd - j

if sp < 0 {
break
}
// Check if sp is the suitable split point
if runes[sp] == '\n' {

chunkEnd = sp
nextChunkStart = chunkEnd 1

break
}
}

}

chunks = append(chunks, string(runes[chunkOffset:chunkEnd]))

chunkOffset = nextChunkStart
if chunkOffset >= totalSize {
break
}
}

return chunks
}
6 changes: 3 additions & 3 deletions pkg/providers/discord/discord.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,17 14,17 @@ type Provider struct {
}

type Options struct {
Profile string `yaml:"profile,omitempty"`
ID string `yaml:"id,omitempty"`
DiscordWebHookURL string `yaml:"discord_webhook_url,omitempty"`
DiscordWebHookUsername string `yaml:"discord_username,omitempty"`
DiscordWebHookAvatarURL string `yaml:"discord_avatar,omitempty"`
}

func New(options []*Options, profiles []string) (*Provider, error) {
func New(options []*Options, ids []string) (*Provider, error) {
provider := &Provider{}

for _, o := range options {
if len(profiles) == 0 || utils.Contains(profiles, o.Profile) {
if len(ids) == 0 || utils.Contains(ids, o.ID) {
provider.Discord = append(provider.Discord, o)
}
}
Expand Down
14 changes: 7 additions & 7 deletions pkg/providers/providers.go
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 33,13 @@ type Client struct {
options *Options
}

func New(options *Options, providers, profiles []string) (*Client, error) {
func New(options *Options, providers, ids []string) (*Client, error) {

client := &Client{options: options}

if options.Slack != nil && (len(providers) == 0 || utils.Contains(providers, "slack")) {

provider, err := slack.New(options.Slack, profiles)
provider, err := slack.New(options.Slack, ids)
if err != nil {
return nil, errors.Wrap(err, "could not create slack provider client")
}
Expand All @@ -48,39 48,39 @@ func New(options *Options, providers, profiles []string) (*Client, error) {
}
if options.Discord != nil && (len(providers) == 0 || utils.Contains(providers, "discord")) {

provider, err := discord.New(options.Discord, profiles)
provider, err := discord.New(options.Discord, ids)
if err != nil {
return nil, errors.Wrap(err, "could not create discord provider client")
}
client.providers = append(client.providers, provider)
}
if options.Pushover != nil && (len(providers) == 0 || utils.Contains(providers, "pushover")) {

provider, err := pushover.New(options.Pushover, profiles)
provider, err := pushover.New(options.Pushover, ids)
if err != nil {
return nil, errors.Wrap(err, "could not create pushover provider client")
}
client.providers = append(client.providers, provider)
}
if options.SMTP != nil && (len(providers) == 0 || utils.Contains(providers, "smtp")) {

provider, err := smtp.New(options.SMTP, profiles)
provider, err := smtp.New(options.SMTP, ids)
if err != nil {
return nil, errors.Wrap(err, "could not create smtp provider client")
}
client.providers = append(client.providers, provider)
}
if options.Teams != nil && (len(providers) == 0 || utils.Contains(providers, "teams")) {

provider, err := teams.New(options.Teams, profiles)
provider, err := teams.New(options.Teams, ids)
if err != nil {
return nil, errors.Wrap(err, "could not create teams provider client")
}
client.providers = append(client.providers, provider)
}
if options.Telegram != nil && (len(providers) == 0 || utils.Contains(providers, "telegram")) {

provider, err := telegram.New(options.Telegram, profiles)
provider, err := telegram.New(options.Telegram, ids)
if err != nil {
return nil, errors.Wrap(err, "could not create telegram provider client")
}
Expand Down
6 changes: 3 additions & 3 deletions pkg/providers/pushover/pushover.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,17 13,17 @@ type Provider struct {
}

type Options struct {
Profile string `yaml:"profile,omitempty"`
ID string `yaml:"id,omitempty"`
PushoverApiToken string `yaml:"pushover_api_token,omitempty"`
UserKey string `yaml:"pushover_user_key,omitempty"`
PushoverDevices []string `yaml:"pushover_devices,omitempty"`
}

func New(options []*Options, profiles []string) (*Provider, error) {
func New(options []*Options, ids []string) (*Provider, error) {
provider := &Provider{}

for _, o := range options {
if len(profiles) == 0 || utils.Contains(profiles, o.Profile) {
if len(ids) == 0 || utils.Contains(ids, o.ID) {
provider.Pushover = append(provider.Pushover, o)
}
}
Expand Down
6 changes: 3 additions & 3 deletions pkg/providers/slack/slack.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 14,7 @@ type Provider struct {
}

type Options struct {
Profile string `yaml:"profile,omitempty"`
ID string `yaml:"id,omitempty"`
SlackWebHookURL string `yaml:"slack_webhook_url,omitempty"`
SlackUsername string `yaml:"slack_username,omitempty"`
SlackChannel string `yaml:"slack_channel,omitempty"`
Expand All @@ -23,11 23,11 @@ type Options struct {
SlackToken string `yaml:"slack_token,omitempty"`
}

func New(options []*Options, profiles []string) (*Provider, error) {
func New(options []*Options, ids []string) (*Provider, error) {
provider := &Provider{}

for _, o := range options {
if len(profiles) == 0 || utils.Contains(profiles, o.Profile) {
if len(ids) == 0 || utils.Contains(ids, o.ID) {
provider.Slack = append(provider.Slack, o)
}
}
Expand Down
6 changes: 3 additions & 3 deletions pkg/providers/smtp/smtp.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,19 13,19 @@ type Provider struct {
}

type Options struct {
Profile string `yaml:"profile,omitempty"`
ID string `yaml:"id,omitempty"`
Server string `yaml:"smtp_server,omitempty"`
Username string `yaml:"smtp_username,omitempty"`
Password string `yaml:"smtp_password,omitempty"`
FromAddress string `yaml:"from_address,omitempty"`
SMTPCC []string `yaml:"smtp_cc,omitempty"`
}

func New(options []*Options, profiles []string) (*Provider, error) {
func New(options []*Options, ids []string) (*Provider, error) {
provider := &Provider{}

for _, o := range options {
if len(profiles) == 0 || utils.Contains(profiles, o.Profile) {
if len(ids) == 0 || utils.Contains(ids, o.ID) {
provider.SMTP = append(provider.SMTP, o)
}
}
Expand Down
6 changes: 3 additions & 3 deletions pkg/providers/teams/teams.go
Original file line number Diff line number Diff line change
Expand Up @@ -13,15 13,15 @@ type Provider struct {
}

type Options struct {
Profile string `yaml:"profile,omitempty"`
ID string `yaml:"id,omitempty"`
TeamsWebHookURL string `yaml:"teams_webhook_url,omitempty"`
}

func New(options []*Options, profiles []string) (*Provider, error) {
func New(options []*Options, ids []string) (*Provider, error) {
provider := &Provider{}

for _, o := range options {
if len(profiles) == 0 || utils.Contains(profiles, o.Profile) {
if len(ids) == 0 || utils.Contains(ids, o.ID) {
provider.Teams = append(provider.Teams, o)
}
}
Expand Down
6 changes: 3 additions & 3 deletions pkg/providers/telegram/telegram.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 12,16 @@ type Provider struct {
}

type Options struct {
Profile string `yaml:"profile,omitempty"`
ID string `yaml:"id,omitempty"`
TelegramAPIKey string `yaml:"telegram_api_key,omitempty"`
TelegramChatID string `yaml:"telegram_chat_id,omitempty"`
}

func New(options []*Options, profiles []string) (*Provider, error) {
func New(options []*Options, ids []string) (*Provider, error) {
provider := &Provider{}

for _, o := range options {
if len(profiles) == 0 || utils.Contains(profiles, o.Profile) {
if len(ids) == 0 || utils.Contains(ids, o.ID) {
provider.Telegram = append(provider.Telegram, o)
}
}
Expand Down
8 changes: 5 additions & 3 deletions pkg/types/types.go
Original file line number Diff line number Diff line change
Expand Up @@ -12,13 12,15 @@ type Options struct {
Interval int `yaml:"interval,omitempty"`
ProviderConfig string `yaml:"provider_config,omitempty"`
Providers goflags.StringSlice `yaml:"providers,omitempty"`
Profiles goflags.StringSlice `yaml:"profiles,omitempty"`
IDs goflags.StringSlice `yaml:"ids,omitempty"`

HTTPMessage string `yaml:"http_message,omitempty"`
DNSMessage string `yaml:"dns_message,omitempty"`
CLIMessage string `yaml:"cli_message,omitempty"`
SMTPMessage string `yaml:"smtp_message,omitempty"`

Stdin bool
Data string `yaml:"data,omitempty"`
Stdin bool
Bulk bool `yaml:"bulk,omitempty"`
CharLimit int `yaml:"char_limit,omitempty"`
Data string `yaml:"data,omitempty"`
}