1// Code generated by smithy-go-codegen DO NOT EDIT. 2 3package frauddetector 4 5import ( 6 "context" 7 awsmiddleware "github.com/aws/aws-sdk-go-v2/aws/middleware" 8 "github.com/aws/aws-sdk-go-v2/aws/signer/v4" 9 "github.com/aws/aws-sdk-go-v2/service/frauddetector/types" 10 "github.com/aws/smithy-go/middleware" 11 smithyhttp "github.com/aws/smithy-go/transport/http" 12) 13 14// Updates a detector version. The detector version attributes that you can update 15// include models, external model endpoints, rules, rule execution mode, and 16// description. You can only update a DRAFT detector version. 17func (c *Client) UpdateDetectorVersion(ctx context.Context, params *UpdateDetectorVersionInput, optFns ...func(*Options)) (*UpdateDetectorVersionOutput, error) { 18 if params == nil { 19 params = &UpdateDetectorVersionInput{} 20 } 21 22 result, metadata, err := c.invokeOperation(ctx, "UpdateDetectorVersion", params, optFns, addOperationUpdateDetectorVersionMiddlewares) 23 if err != nil { 24 return nil, err 25 } 26 27 out := result.(*UpdateDetectorVersionOutput) 28 out.ResultMetadata = metadata 29 return out, nil 30} 31 32type UpdateDetectorVersionInput struct { 33 34 // The parent detector ID for the detector version you want to update. 35 // 36 // This member is required. 37 DetectorId *string 38 39 // The detector version ID. 40 // 41 // This member is required. 42 DetectorVersionId *string 43 44 // The Amazon SageMaker model endpoints to include in the detector version. 45 // 46 // This member is required. 47 ExternalModelEndpoints []string 48 49 // The rules to include in the detector version. 50 // 51 // This member is required. 52 Rules []types.Rule 53 54 // The detector version description. 55 Description *string 56 57 // The model versions to include in the detector version. 58 ModelVersions []types.ModelVersion 59 60 // The rule execution mode to add to the detector. If you specify FIRST_MATCHED, 61 // Amazon Fraud Detector evaluates rules sequentially, first to last, stopping at 62 // the first matched rule. Amazon Fraud dectector then provides the outcomes for 63 // that single rule. If you specifiy ALL_MATCHED, Amazon Fraud Detector evaluates 64 // all rules and returns the outcomes for all matched rules. You can define and 65 // edit the rule mode at the detector version level, when it is in draft status. 66 // The default behavior is FIRST_MATCHED. 67 RuleExecutionMode types.RuleExecutionMode 68} 69 70type UpdateDetectorVersionOutput struct { 71 // Metadata pertaining to the operation's result. 72 ResultMetadata middleware.Metadata 73} 74 75func addOperationUpdateDetectorVersionMiddlewares(stack *middleware.Stack, options Options) (err error) { 76 err = stack.Serialize.Add(&awsAwsjson11_serializeOpUpdateDetectorVersion{}, middleware.After) 77 if err != nil { 78 return err 79 } 80 err = stack.Deserialize.Add(&awsAwsjson11_deserializeOpUpdateDetectorVersion{}, middleware.After) 81 if err != nil { 82 return err 83 } 84 if err = addSetLoggerMiddleware(stack, options); err != nil { 85 return err 86 } 87 if err = awsmiddleware.AddClientRequestIDMiddleware(stack); err != nil { 88 return err 89 } 90 if err = smithyhttp.AddComputeContentLengthMiddleware(stack); err != nil { 91 return err 92 } 93 if err = addResolveEndpointMiddleware(stack, options); err != nil { 94 return err 95 } 96 if err = v4.AddComputePayloadSHA256Middleware(stack); err != nil { 97 return err 98 } 99 if err = addRetryMiddlewares(stack, options); err != nil { 100 return err 101 } 102 if err = addHTTPSignerV4Middleware(stack, options); err != nil { 103 return err 104 } 105 if err = awsmiddleware.AddRawResponseToMetadata(stack); err != nil { 106 return err 107 } 108 if err = awsmiddleware.AddRecordResponseTiming(stack); err != nil { 109 return err 110 } 111 if err = addClientUserAgent(stack); err != nil { 112 return err 113 } 114 if err = smithyhttp.AddErrorCloseResponseBodyMiddleware(stack); err != nil { 115 return err 116 } 117 if err = smithyhttp.AddCloseResponseBodyMiddleware(stack); err != nil { 118 return err 119 } 120 if err = addOpUpdateDetectorVersionValidationMiddleware(stack); err != nil { 121 return err 122 } 123 if err = stack.Initialize.Add(newServiceMetadataMiddleware_opUpdateDetectorVersion(options.Region), middleware.Before); err != nil { 124 return err 125 } 126 if err = addRequestIDRetrieverMiddleware(stack); err != nil { 127 return err 128 } 129 if err = addResponseErrorMiddleware(stack); err != nil { 130 return err 131 } 132 if err = addRequestResponseLogging(stack, options); err != nil { 133 return err 134 } 135 return nil 136} 137 138func newServiceMetadataMiddleware_opUpdateDetectorVersion(region string) *awsmiddleware.RegisterServiceMetadata { 139 return &awsmiddleware.RegisterServiceMetadata{ 140 Region: region, 141 ServiceID: ServiceID, 142 SigningName: "frauddetector", 143 OperationName: "UpdateDetectorVersion", 144 } 145} 146