Video generation access and usage
Generating a video with Amazon Nova Reel is an asynchronous process that typically takes
        about 90 seconds for a 6 second video and approximately 14-17 minutes for a 2 minute video. After initiating the generation of a video, the video is
        written to an Amazon S3 bucket in your account. Because Amazon Bedrock writes a file to
        an Amazon S3 bucket on your behalf, the AWS role that you use needs permissions configured to
        allow the appropriate Amazon Bedrock and Amazon S3 actions and the
            s3:PutObject action. The minimum action permissions required to generate a
        video are:
- 
            bedrock:InvokeModel
- 
            s3:PutObject
However, we recommend the following additional actions so you can track the status of video generation jobs:
- 
            bedrock:GetAsyncInvoke
- 
            bedrock:ListAsyncInvokes
When video generation completes, the video and its constituent shots are stored in the Amazon S3 bucket you specified. Amazon Nova creates a folder for each invocation ID. This folder contains the manifest.json, output.mp4, and generation-status.json files that are created by the video generation request.
Topics
Starting a video generation job
To initiate the generation of a video, call start_async_invoke(). This
            creates a new invocation job. When the job completes, Amazon Nova automatically saves the
            generated video to an Amazon S3 bucket that you specify.
start_async_invoke() takes the following arguments:
- 
                modelId (Required) – The model ID to use. For Amazon Nova Reel, this is "amazon.nova-reel-v1:1" 
- 
                modelInput (Required) – Defines all of the video generation parameters specific to the Amazon Nova Reel model. For more information, see Video generation input parameters. 
- 
                outputDataConfig (Required) – Defines where the generated video should be saved. The value must have the following structure: { "s3OutputDataConfig": { "s3Uri":string (S3 URL starting with "s3://")} }
Video generation input parameters
Refer to the following parameter descriptions for information about how to generate videos using Amazon Nova Reel.
The video generation process will result in the following files being written to the Amazon S3 destination you specify:
- 
                manifest.json - A file written at the start of the job, containing the request ID. 
- 
                video-generation-status.json - This file is written whether the job succeeds of fails. When a job fails, it will contain detailed information explaining exactly which part of the job failed and what action to take to fix the error. 
- 
                output.mp4 - The complete multi-shot video. Written only if the job succeeds. 
- 
                shot_N.mp4 - Each individual shot is also provided as its own video. The file name follows the format "shot_0001.mp4", "shot_0002.mp4", and so on. These files are written only if the whole job succeeds. 
Checking progress of video generation jobs
There are two ways to check on the progress of a video generation job. If you have a
            reference to the invocation ARN that was returned when starting the invocation, you can
            use the get_async_invoke() method of the Amazon Bedrock
            Runtime.
response = bedrock_runtime.get_async_invoke( invocationArn="arn:AWS:bedrock:us-east-1:account-id:async-invoke/invocation-id" ) status = response["status"] print(f"Status: {status}")
The status of a job will be "Completed", "InProgress", or "Failed". For more details
            on using the get_async_invoke() method, see the 
            Async Invoke API documentation.
If you do not have a reference to the invocation ARN, or if you want to check the
            status for multiple jobs at once, you can use the list_async_invokes()
            method of the Amazon Bedrock Runtime.
invocations_details = bedrock_runtime.list_async_invokes( maxResults=10, # (Optional) statusEquals="InProgress", # (Optional) Can be "Completed", "InProgress", or "Failed". Omit this argument to list all jobs, regardless of status. # Note: There are other supported arguments not demonstrated here. ) print(json.dumps(invocations_details, indent=2, default=str))
For more details on using the list_async_invokes() method, see the
             Async Invoke API documentation.
Accessing the results of a video generation job
After a video generation job succeeds or fails, a JSON file is added to your Amazon S3 bucket. This file contains metadata about the shots that were created for the video. The file is named video-generation-status.json.
For a successful video generation request, the file contains the location of each individual shot that comprises the full video. For a failed request, the file contains the failure message and additional details about why the shot failed.
The schema of this JSON file is provided below.
{ "schemaVersion": string, "shots": [{ "status": enum, // where success is generation + upload "location": string, "failureType": enum, "failureMessage": string, }, ... ], "fullVideo": { "status": enum, // where success is generation + upload "location": string, "failureType": enum, "failureMessage": string, } }
- 
                schemaVersion - The version of the JSON schema. 
- 
                shots - Provides information about each shot in the video. - 
                        status - The completion state (SUCCESS or FAILURE) of the shot. 
- 
                        location - The file name and Amazon S3 location where the shot is stored. The location will be available only when all shots are successfully generated and the complete video is uploaded to its Amazon S3 location. 
- 
                        failureType - Provides the reason for failure. 
- 
                        failureMessage - Provides more information about the failure reason. 
 
- 
                        
- 
                fullVideo - Provides information about the full video. - 
                        status - The completion state (SUCCESS or FAILURE) of the full video. 
- 
                        location - The file name and Amazon S3 location where the full video is stored. 
- 
                        failureType - Provides the reason for failure. 
- 
                        failureMessage - Provides more information about the failure reason. 
 
- 
                        
Possible failure reasons and messages are
- 
                INTERNAL_SERVER_EXCEPTION - "Something went wrong on the server side." 
- 
                RAI_VIOLATION_OUTPUT_VIDEO_DEFLECTION - "The generated content has been blocked by our content filters." 
- 
                RATE_LIMIT_EXCEEDED - "Service capacity limit has been reached. Please try again later." 
- 
                ABORTED - "Request has been aborted."