# lws minimal secure streams sigv4

The application put a test file to AWS S3, using sigv4 auth.

It does it using Secure Streams... the streamtype is "s3PutObj", along with main
are in ss-s3-main.c

The handler for state changes and payloads for "s3PutObj" is in ss-s3-ss.c


## metadata
 "aws_region" and "aws_service" are configured through metadata. Also, at least
 "x-amz-content-sha256:" and ""x-amz-date:" headers need to be in metadata.


## credentials
credentials are read from ~/.aws/credentials, make sure you have valid keyid and
key.  One need to call lws_ss_sigv4_set_aws_key() to plug in aws credentials into
Secure Streams and the index need to be match of the "blob_index" in entry of "auth"
the policy.  In addition, you need to change the S3 bucket name to your own, as
bucket name is unique globally in S3.


## build

```
 $ cmake . && make
```

## usage


```
[2020/12/19 15:25:06:9763] U: LWS minimal secure streams sigv4
[2020/12/19 15:25:07:0768] U: ss_s3_state: LWSSSCS_CREATING, ord 0x0
[2020/12/19 15:25:07:0769] U: ss_s3_state: LWSSSCS_POLL, ord 0x0
[2020/12/19 15:25:07:0770] U: ss_s3_state: LWSSSCS_CONNECTING, ord 0x0
[2020/12/19 15:25:07:2317] U: SS / TX Payload
[2020/12/19 15:25:07:2317] U: SS / TX Payload Total = 1024, Pos = 0
[2020/12/19 15:25:07:3267] U: ss_s3_state: LWSSSCS_CONNECTED, ord 0x0
[2020/12/19 15:25:07:3267] U: ss_s3_state: LWSSSCS_QOS_ACK_REMOTE, ord 0x0
[2020/12/19 15:25:07:3267] U: ss_s3_state: LWSSSCS_DISCONNECTED, ord 0x0
[2020/12/19 15:25:07:3268] U: ss_s3_state: LWSSSCS_DESTROYING, ord 0x0
[2020/12/19 15:25:07:3269] U: Completed: OK

```