1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172
|
// Code generated by smithy-go-codegen DO NOT EDIT.
package transfer
import (
"context"
"fmt"
awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware"
"github.com/aws/aws-sdk-go-v2/aws/signer/v4"
"github.com/aws/smithy-go/middleware"
smithyhttp "github.com/aws/smithy-go/transport/http"
)
// Begins a file transfer between local Amazon Web Services storage and a remote
// AS2 or SFTP server.
// - For an AS2 connector, you specify the ConnectorId and one or more
// SendFilePaths to identify the files you want to transfer.
// - For an SFTP connector, the file transfer can be either outbound or inbound.
// In both cases, you specify the ConnectorId . Depending on the direction of the
// transfer, you also specify the following items:
// - If you are transferring file from a partner's SFTP server to Amazon Web
// Services storage, you specify one or more RetreiveFilePaths to identify the
// files you want to transfer, and a LocalDirectoryPath to specify the
// destination folder.
// - If you are transferring file to a partner's SFTP server from Amazon Web
// Services storage, you specify one or more SendFilePaths to identify the files
// you want to transfer, and a RemoteDirectoryPath to specify the destination
// folder.
func (c *Client) StartFileTransfer(ctx context.Context, params *StartFileTransferInput, optFns ...func(*Options)) (*StartFileTransferOutput, error) {
if params == nil {
params = &StartFileTransferInput{}
}
result, metadata, err := c.invokeOperation(ctx, "StartFileTransfer", params, optFns, c.addOperationStartFileTransferMiddlewares)
if err != nil {
return nil, err
}
out := result.(*StartFileTransferOutput)
out.ResultMetadata = metadata
return out, nil
}
type StartFileTransferInput struct {
// The unique identifier for the connector.
//
// This member is required.
ConnectorId *string
// For an inbound transfer, the LocaDirectoryPath specifies the destination for
// one or more files that are transferred from the partner's SFTP server.
LocalDirectoryPath *string
// For an outbound transfer, the RemoteDirectoryPath specifies the destination for
// one or more files that are transferred to the partner's SFTP server. If you
// don't specify a RemoteDirectoryPath , the destination for transferred files is
// the SFTP user's home directory.
RemoteDirectoryPath *string
// One or more source paths for the partner's SFTP server. Each string represents
// a source file path for one inbound file transfer.
RetrieveFilePaths []string
// One or more source paths for the Amazon S3 storage. Each string represents a
// source file path for one outbound file transfer. For example,
// DOC-EXAMPLE-BUCKET/myfile.txt . Replace DOC-EXAMPLE-BUCKET with one of your
// actual buckets.
SendFilePaths []string
noSmithyDocumentSerde
}
type StartFileTransferOutput struct {
// Returns the unique identifier for the file transfer.
//
// This member is required.
TransferId *string
// Metadata pertaining to the operation's result.
ResultMetadata middleware.Metadata
noSmithyDocumentSerde
}
func (c *Client) addOperationStartFileTransferMiddlewares(stack *middleware.Stack, options Options) (err error) {
if err := stack.Serialize.Add(&setOperationInputMiddleware{}, middleware.After); err != nil {
return err
}
err = stack.Serialize.Add(&awsAwsjson11_serializeOpStartFileTransfer{}, middleware.After)
if err != nil {
return err
}
err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpStartFileTransfer{}, middleware.After)
if err != nil {
return err
}
if err := addProtocolFinalizerMiddlewares(stack, options, "StartFileTransfer"); err != nil {
return fmt.Errorf("add protocol finalizers: %v", err)
}
if err = addlegacyEndpointContextSetter(stack, options); err != nil {
return err
}
if err = addSetLoggerMiddleware(stack, options); err != nil {
return err
}
if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil {
return err
}
if err = addResolveEndpointMiddleware(stack, options); err != nil {
return err
}
if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil {
return err
}
if err = addRetryMiddlewares(stack, options); err != nil {
return err
}
if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil {
return err
}
if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil {
return err
}
if err = addClientUserAgent(stack, options); err != nil {
return err
}
if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil {
return err
}
if err = addSetLegacyContextSigningOptionsMiddleware(stack); err != nil {
return err
}
if err = addOpStartFileTransferValidationMiddleware(stack); err != nil {
return err
}
if err = stack.Initialize.Add(newServiceMetadataMiddleware_opStartFileTransfer(options.Region), middleware.Before); err != nil {
return err
}
if err = awsmiddleware.AddRecursionDetection(stack); err != nil {
return err
}
if err = addRequestIDRetrieverMiddleware(stack); err != nil {
return err
}
if err = addResponseErrorMiddleware(stack); err != nil {
return err
}
if err = addRequestResponseLogging(stack, options); err != nil {
return err
}
if err = addDisableHTTPSMiddleware(stack, options); err != nil {
return err
}
return nil
}
func newServiceMetadataMiddleware_opStartFileTransfer(region string) *awsmiddleware.RegisterServiceMetadata {
return &awsmiddleware.RegisterServiceMetadata{
Region: region,
ServiceID: ServiceID,
OperationName: "StartFileTransfer",
}
}
|