Skip to content

Commit

Permalink
Bucket Notifications - doc
Browse files Browse the repository at this point in the history
Signed-off-by: Amit Prinz Setter <alphaprinz@gmail.com>
  • Loading branch information
alphaprinz committed Dec 19, 2024
1 parent 04fe4ed commit 6803a24
Show file tree
Hide file tree
Showing 3 changed files with 122 additions and 0 deletions.
12 changes: 12 additions & 0 deletions docs/NooBaaNonContainerized/ConfigFileCustomizations.md
Original file line number Diff line number Diff line change
Expand Up @@ -449,6 +449,18 @@ Warning: After setting this configuration, NooBaa will skip schema validations a
"LOG_TO_STDERR_ENABLED": false
3. systemctl restart noobaa
```
### 30. Notification log directory
* <u>Key</u> `NOTIFICATION_LOG_DIR`
* <u>Type</u> String
* <u>Default</u> empty
* <u>Description</u> Path to directory that will hold pending notifications to be sent,
* <u>Steps</u>
```
1. Open /path/to/config_dir/config.json file.
2. Set the config key -
Example:
"NOTIFICATION_LOG_DIR": "/etc/notif"
3. systemctl restart noobaa
## Config.json File Examples
The following is an example of a config.json file -
Expand Down
90 changes: 90 additions & 0 deletions docs/bucket-notifications.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
# Bucket Notifications

## Bucket Notification Configuration

Bucket's notifications can be configured with the s3api operation [put-bucket-notification-configuration](https://awscli.amazonaws.com/v2/documentation/api/latest/reference/s3api/put-bucket-notification-configuration.html).
Specify notifications under the "TopicConfigurations" field, which is an array of jsons, one for each notification.
A notification json has these fields:
- Id: Mandatory. A unique string identifying the notification configuration.
- Events: Optional. An array of [events](https://docs.aws.amazon.com/AmazonS3/latest/userguide/notification-how-to-event-types-and-destinations.html) for which the notification is relevant.
If not specified, the notification is relevant for all events.
- TopicArn: The connection file name. (To specify a Kafka target topic, see "Kafka Connection Fields" below).

Example for a bucket's notification configuration, in a file:
{
"TopicConfigurations": [
{
"Id": "created_from_s3op",
"TopicArn": "connect.json",
"Events": [
"s3:ObjectCreated:*"
]
}
]
}


## Connection File
A connection file contains some fields that specify the target notification server.
The connection file name is specified in TopicArn field of the [notification configuration](https://awscli.amazonaws.com/v2/documentation/api/latest/reference/s3api/put-bucket-notification-configuration.html)
In a containerized environment, the operator will mount the secrets as file in the core pod (see operator doc for more info).
In a non-containerized system, you must create the relevant file manually and place it in 'connect' config sub-directory.
Connect file contains a single json with the fields specified below.

### Common Connection Fields
- name: A string identifying the connection (mandatory).
- notification_protocol: One of: http, https, kafka (mandatory).

### Http(s) Connection Fields
- agent_request_object: Value is a JSON that is passed to to nodejs' http(s) agent (mandatory).
Any field supported by nodejs' http(s) agent can be used, specifically 'host' and 'port'.
A full list of options is [here](https://nodejs.org/docs/latest-v22.x/api/http.html#new-agentoptions).

- request_options_object: Value is a JSON that is passed to nodejs' http(s) request (optional).
Any field supported by nodejs' http(s) request option can be used, specifically:
- 'path': used to specify the url path
- 'auth': used for http simple auth. Value for 'auth' is of the syntax: <name>:<passowrd>.

A full list of options is [here](https://nodejs.org/docs/latest-v22.x/api/http.html#httprequesturl-options-callback).

### Kafka Connection Fields
- metadata.broker.list: A CSV list of Kafka brokers (mandatory).
- topic: A topic for the Kafka message (mandatory).

## Event Types
S3 spec lists several events and "sub events".

The list of supported events are:

- s3:ObjectCreated:*
- s3:ObjectCreated:Put
- s3:ObjectCreated:Post
- s3:ObjectCreated:Copy
- s3:ObjectCreated:CompleteMultipartUpload
- s3:ObjectRemoved:*
- s3:ObjectRemoved:Delete
- s3:ObjectRemoved:DeleteMarkerCreated
- s3:ObjectRestore:*
- s3:ObjectRestore:Post
- s3:ObjectRestore:Completed
- s3:ObjectRestore:Delete
- s3:ObjectTagging:*
- s3:ObjectTagging:Put
- s3:ObjectTagging:Delete
- s3:LifecycleExpiration:*
- s3:LifecycleExpiration:Delete
- s3:LifecycleExpiration:DeleteMarkerCreated

## Event Processing and Failure Handling
Once NooBaa finds an event with a relevant notification configuration, the notification
is written to a persistent file.
Location of persistent files is determined by-
- For containerized, the pvc specified in NooBaa Bucket Notification spec (see Operator docs for more info).
- For NC, the env variable NOTIFICATION_LOG_DIR (see NC docs for more info).

Files are processed by-
- For containerized, files are contantly being processed in the background of the core pod.
- For NC, files are processed by running manage_nsfs with 'notification' action.

If a notification fails to be sent to the external server, it will be re-written to a persistent file.
Once this new file is processed, NooBaa will try to re-send the failed notification.
20 changes: 20 additions & 0 deletions src/manage_nsfs/manage_nsfs_help_utils.js
Original file line number Diff line number Diff line change
Expand Up @@ -452,6 +452,19 @@ Usage:
`;

const NOTIFICATION_OPTIONS = `
Help:
'notification' is a noobaa-cli command that will process pending event notifications in the NOTIFICATION_LOG_DIR directory.
It will attempt to send each notification to its respective external server.
Note notifications that fail to be sent will be re-written in NOTIFICATION_LOG_DIR.
Usage:
noobaa-cli notification
`;


/**
* print_usage would print the help according to the arguments that were passed
Expand Down Expand Up @@ -481,6 +494,9 @@ function print_usage(type, action) {
case TYPES.UPGRADE:
print_help_upgrade(action);
break;
case TYPES.NOTIFICATION:
print_help_notification();
break;
default:
process.stdout.write(HELP + '\n');
process.stdout.write(USAGE.trimStart() + '\n');
Expand Down Expand Up @@ -600,6 +616,10 @@ function print_help_upgrade(action) {
}
}

function print_help_notification(action) {
process.stdout.write(NOTIFICATION_OPTIONS);
}


// EXPORTS
exports.print_usage = print_usage;

0 comments on commit 6803a24

Please sign in to comment.