-
-
Notifications
You must be signed in to change notification settings - Fork 34
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
Cross Account - sourceArn #19
base: master
Are you sure you want to change the base?
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -38,6 +38,9 @@ func sendHelper( | |
configurationSetName *string, | ||
allowFromRegExp *regexp.Regexp, | ||
denyToRegExp *regexp.Regexp, | ||
sourceArn *string, | ||
fromArn *string, | ||
returnPathArn *string, | ||
apiErr error, | ||
) (email *ses.SendRawEmailInput, out []byte, err []byte, sendErr error) { | ||
outReader, outWriter, _ := os.Pipe() | ||
|
@@ -58,6 +61,9 @@ func sendHelper( | |
setName: configurationSetName, | ||
allowFromRegExp: allowFromRegExp, | ||
denyToRegExp: denyToRegExp, | ||
sourceArn: sourceArn, | ||
fromArn: fromArn, | ||
returnPathArn: returnPathArn, | ||
} | ||
testData.err = apiErr | ||
sendErr = c.Send(origin, from, to, data) | ||
|
@@ -75,7 +81,10 @@ func TestSend(t *testing.T) { | |
to := []string{"[email protected]"} | ||
data := []byte{'T', 'E', 'S', 'T'} | ||
setName := "" | ||
input, out, err, _ := sendHelper(&origin, from, to, data, &setName, nil, nil, nil) | ||
sourceArn := "" | ||
fromArn := "" | ||
returnPathArn := "" | ||
input, out, err, _ := sendHelper(&origin, from, to, data, &setName, nil, nil, &sourceArn, &fromArn, &returnPathArn, nil) | ||
if *input.Source != from { | ||
t.Errorf( | ||
"Unexpected source: %s. Expected: %s", | ||
|
@@ -115,7 +124,10 @@ func TestSendWithMultipleRecipients(t *testing.T) { | |
to := []string{"[email protected]", "[email protected]"} | ||
data := []byte{'T', 'E', 'S', 'T'} | ||
setName := "" | ||
input, out, err, _ := sendHelper(&origin, from, to, data, &setName, nil, nil, nil) | ||
sourceArn := "" | ||
fromArn := "" | ||
returnPathArn := "" | ||
input, out, err, _ := sendHelper(&origin, from, to, data, &setName, nil, nil, &sourceArn, &fromArn, &returnPathArn, nil) | ||
if len(input.Destinations) != 2 { | ||
t.Errorf( | ||
"Unexpected number of destinations: %d. Expected: %d", | ||
|
@@ -144,8 +156,11 @@ func TestSendWithDeniedSender(t *testing.T) { | |
to := []string{"[email protected]", "[email protected]"} | ||
data := []byte{'T', 'E', 'S', 'T'} | ||
setName := "" | ||
sourceArn := "" | ||
fromArn := "" | ||
returnPathArn := "" | ||
regexp, _ := regexp.Compile(`^admin@example\.org$`) | ||
input, out, err, sendErr := sendHelper(&origin, from, to, data, &setName, regexp, nil, nil) | ||
input, out, err, sendErr := sendHelper(&origin, from, to, data, &setName, regexp, nil, &sourceArn, &fromArn, &returnPathArn, nil) | ||
if input != nil { | ||
t.Errorf( | ||
"Unexpected number of destinations: %d. Expected: %d", | ||
|
@@ -170,8 +185,11 @@ func TestSendWithDeniedRecipient(t *testing.T) { | |
to := []string{"[email protected]", "[email protected]"} | ||
data := []byte{'T', 'E', 'S', 'T'} | ||
setName := "" | ||
sourceArn := "" | ||
fromArn := "" | ||
returnPathArn := "" | ||
regexp, _ := regexp.Compile(`^bob@example\.org$`) | ||
input, out, err, sendErr := sendHelper(&origin, from, to, data, &setName, nil, regexp, nil) | ||
input, out, err, sendErr := sendHelper(&origin, from, to, data, &setName, nil, regexp, &sourceArn, &fromArn, &returnPathArn, nil) | ||
if len(input.Destinations) != 1 { | ||
t.Errorf( | ||
"Unexpected number of destinations: %d. Expected: %d", | ||
|
@@ -203,8 +221,11 @@ func TestSendWithApiError(t *testing.T) { | |
to := []string{"[email protected]"} | ||
data := []byte{'T', 'E', 'S', 'T'} | ||
setName := "" | ||
sourceArn := "" | ||
fromArn := "" | ||
returnPathArn := "" | ||
apiErr := errors.New("API failure") | ||
input, out, err, sendErr := sendHelper(&origin, from, to, data, &setName, nil, nil, apiErr) | ||
input, out, err, sendErr := sendHelper(&origin, from, to, data, &setName, nil, nil, &sourceArn, &fromArn, &returnPathArn, apiErr) | ||
if *input.Source != from { | ||
t.Errorf( | ||
"Unexpected source: %s. Expected: %s", | ||
|
@@ -245,7 +266,10 @@ func TestNew(t *testing.T) { | |
setName := "" | ||
allowFromRegExp, _ := regexp.Compile(`^admin@example\.org$`) | ||
denyToRegExp, _ := regexp.Compile(`^bob@example\.org$`) | ||
client := New(&setName, allowFromRegExp, denyToRegExp) | ||
sourceArn := "" | ||
fromArn := "" | ||
returnPathArn := "" | ||
client := New(&setName, allowFromRegExp, denyToRegExp, &sourceArn, &fromArn, &returnPathArn) | ||
_, ok := interface{}(client).(relay.Client) | ||
if !ok { | ||
t.Error("Unexpected: client is not a relay.Client") | ||
|
@@ -259,4 +283,13 @@ func TestNew(t *testing.T) { | |
if client.denyToRegExp != denyToRegExp { | ||
t.Errorf("Unexpected denyToRegExp: %s", client.denyToRegExp) | ||
} | ||
if client.sourceArn != &sourceArn { | ||
t.Errorf("Unexpected sourceArn: %s", *client.sourceArn) | ||
} | ||
if client.fromArn != &fromArn { | ||
t.Errorf("Unexpected fromArn: %s", *client.fromArn) | ||
} | ||
if client.returnPathArn != &returnPathArn { | ||
t.Errorf("Unexpected returnPathArn: %s", *client.returnPathArn) | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -29,6 +29,9 @@ var ( | |
user = flag.String("u", "", "Authentication username") | ||
allowFrom = flag.String("l", "", "Allowed sender emails regular expression") | ||
denyTo = flag.String("d", "", "Denied recipient emails regular expression") | ||
sourceArn = flag.String("f", "", "The SourceARN (when using with cross accounts) ") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Would change the description of all three flags to the following (for consistency with
|
||
fromArn = flag.String("o", "", "The FromARN (when using with cross accounts)") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Would switch the flags for |
||
rPathArn = flag.String("p", "", "The ReturnPathARN (when using with cross accounts)") | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. For consistency, we should call this variable |
||
) | ||
|
||
var ipMap map[string]bool | ||
|
@@ -79,11 +82,27 @@ func configure() error { | |
return errors.New("Denied recipient emails: " + err.Error()) | ||
} | ||
} | ||
if *sourceArn != "" { | ||
if *fromArn == "" { | ||
fromArn = sourceArn | ||
} | ||
if *rPathArn == "" { | ||
rPathArn = sourceArn | ||
} | ||
} else { | ||
sourceArn = nil | ||
} | ||
if *fromArn == "" { | ||
fromArn = nil | ||
} | ||
if *rPathArn == "" { | ||
rPathArn = nil | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Could you elaborate on why you're setting the variables to |
||
switch *relayAPI { | ||
case "pinpoint": | ||
relayClient = pinpointrelay.New(setName, allowFromRegExp, denyToRegExp) | ||
case "ses": | ||
relayClient = sesrelay.New(setName, allowFromRegExp, denyToRegExp) | ||
relayClient = sesrelay.New(setName, allowFromRegExp, denyToRegExp, sourceArn, fromArn, rPathArn) | ||
default: | ||
return errors.New("Invalid relay API: " + *relayAPI) | ||
} | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think it might be better to create a struct called
arns
that consists of those three arns and add that as member to this struct. Makes handling the arguments for a lot of the function calls a bit simpler.