# @aws-sdk/client-mediastore-data-browser

[![NPM version](https://img.shields.io/npm/v/@aws-sdk/client-mediastore-data-browser/preview.svg)](https://www.npmjs.com/package/@aws-sdk/client-mediastore-data-browser)
[![NPM downloads](https://img.shields.io/npm/dm/@aws-sdk/client-mediastore-data-browser.svg)](https://www.npmjs.com/package/@aws-sdk/client-mediastore-data-browser)

## Description

<p>An AWS Elemental MediaStore asset is an object, similar to an object in the Amazon S3 service. Objects are the fundamental entities that are stored in AWS Elemental MediaStore.</p>

## Installing

To install the this package using NPM, simply type the following into a terminal window:

```
npm install @aws-sdk/client-mediastore-data-browser
```

## Getting Started

### Import

The AWS SDK is modulized by clients and commands in CommonJS modules. To send a request, you only need to import the client(`MediaStoreDataClient`) and the commands you need, for example `PutObjectCommand`:

```javascript
//JavaScript
const {
  MediaStoreDataClient
} = require("@aws-sdk/client-mediastore-data-browser/MediaStoreDataClient");
const {
  PutObjectCommand
} = require("@aws-sdk/client-mediastore-data-browser/commands/PutObjectCommand");
```

```javascript
//TypeScript
import { MediaStoreDataClient } from "@aws-sdk/client-mediastore-data-browser/MediaStoreDataClient";
import { PutObjectCommand } from "@aws-sdk/client-mediastore-data-browser/commands/PutObjectCommand";
```

### Usage

To send a request, you:

- Initiate client with configuration (e.g. credentials, region). For more information you can refer to the [API reference][].
- Initiate command with input parameters.
- Call `send` operation on client with command object as input.
- If you are using a custom http handler, you may call `destroy()` to close open connections.

```javascript
const mediaStoreData = new MediaStoreDataClient({region: 'region'});
//clients can be shared by different commands
const params = {
  Body: /**a blob value*/
  /**You can supply readable stream to streaming input. e.g. (await fetch(input)).body */,
  Path: /**a string value*/,
};
const putObjectCommand = new PutObjectCommand(params);
mediaStoreData.send(putObjectCommand).then(data => {
    // do something
}).catch(error => {
    // error handling
})
```

In addition to using promises, there are 2 other ways to send a request:

```javascript
// async/await
try {
  const data = await mediaStoreData.send(putObjectCommand);
  // do something
} catch (error) {
  // error handling
}
```

```javascript
// callback
mediaStoreData.send(putObjectCommand, (err, data) => {
  //do something
});
```

The SDK can also send requests using the simplified callback style from version 2 of the SDK.

```javascript
import * as AWS from "@aws-sdk/@aws-sdk/client-mediastore-data-browser/MediaStoreData";
const mediaStoreData = new AWS.MediaStoreData({ region: "region" });
mediaStoreData.putObject(params, (err, data) => {
  //do something
});
```

For operations containing stream response like `GetObject()`, you can get response stream by accessing to streaming member. e.g. data.Body.getReader().read().then(/_ do something and continue reading _/).(`data` is the resolved response object)

### Troubleshooting

When the service returns an exception, the error will include the exception information, as well as response metadata (e.g. request id).

```javascript
try {
  const data = await mediaStoreData.send(putObjectCommand);
  // do something
} catch (error) {
  const metadata = error.$metadata;
  console.log(
    `requestId: ${metadata.requestId}
cfId: ${metadata.cfId}
extendedRequestId: ${metadata.extendedRequestId}`
  );
  /*
The keys within exceptions are also parsed. You can access them by specifying exception names:
    if(error.name === 'SomeServiceException') {
        const value = error.specialKeyInException;
    }
*/
}
```

## Getting Help

Please use these community resources for getting help. We use the GitHub issues for tracking bugs and feature requests and have limited bandwidth to address them.

- Ask a question on [StackOverflow](https://stackoverflow.com/questions/tagged/aws-sdk-js) and tag it with `aws-sdk-js`
- Come join the AWS JavaScript community on [gitter](https://gitter.im/aws/aws-sdk-js-v3)
- If it turns out that you may have found a bug, please [open an issue](https://github.com/aws/aws-sdk-js-v3/issues)

## Contributing

This client code is generated automatically. Any modifications will be overwritten the next time the `@aws-sdk/@aws-sdk/client-mediastore-data-browser' package is updated. To contribute to SDK you can checkout our [code generator package][].

## License

This SDK is distributed under the
[Apache License, Version 2.0](http://www.apache.org/licenses/LICENSE-2.0),
see LICENSE for more information.

[code generator package]: https://github.com/aws/aws-sdk-js-v3/tree/master/packages/service-types-generator
[api reference]: https://docs.aws.amazon.com/AWSJavaScriptSDK/latest/
