Compare commits
	
		
			21 Commits
		
	
	
		
			kat/create
			...
			810212dc12
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 810212dc12 | |||
| c3210df517 | |||
| 9f5c354433 | |||
| 23d9fef2b1 | |||
| df3087de7d | |||
| 5dd8318dab | |||
| 56c8bcce20 | |||
| 1c4961db5b | |||
| 5e0d01ea5b | |||
| e8938621fc | |||
| 8c8dcdd8e1 | |||
| 5085c9af90 | |||
| 85bc743c8e | |||
| b8efa644e3 | |||
| c18628a4ca | |||
| 535e24c9c2 | |||
| 04308b1003 | |||
| 43c626141e | |||
| c49266e4c1 | |||
| 6677b9232f | |||
| 76e792be88 | 
| @@ -30,6 +30,8 @@ export type Scalars = { | |||||||
|   Float: { input: number; output: number }; |   Float: { input: number; output: number }; | ||||||
|   /** Date with time (isoformat) */ |   /** Date with time (isoformat) */ | ||||||
|   DateTime: { input: any; output: any }; |   DateTime: { input: any; output: any }; | ||||||
|  |   /** The `JSON` scalar type represents JSON values as specified by [ECMA-404](https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf). */ | ||||||
|  |   JSON: { input: any; output: any }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type AggregateInputGql = { | export type AggregateInputGql = { | ||||||
| @@ -102,6 +104,10 @@ export type CreateUploadStreamReturn = { | |||||||
|   videoId: Scalars["Int"]["output"]; |   videoId: Scalars["Int"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type CreatedAfter = | ||||||
|  |   | { createdAt: Scalars["DateTime"]["input"]; videoId?: never } | ||||||
|  |   | { createdAt?: never; videoId: Scalars["Int"]["input"] }; | ||||||
|  |  | ||||||
| export type CueObjectFeaturesGql = { | export type CueObjectFeaturesGql = { | ||||||
|   __typename?: "CueObjectFeaturesGQL"; |   __typename?: "CueObjectFeaturesGQL"; | ||||||
|   cueBallSpeed?: Maybe<Scalars["Float"]["output"]>; |   cueBallSpeed?: Maybe<Scalars["Float"]["output"]>; | ||||||
| @@ -1029,9 +1035,15 @@ export type FilterInput = | |||||||
|       videoId: Array<Scalars["Int"]["input"]>; |       videoId: Array<Scalars["Int"]["input"]>; | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  | export type GetShotsPagination = { | ||||||
|  |   createdAfter: CreatedAfter; | ||||||
|  |   startFrameAfter: Scalars["Int"]["input"]; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type GetUploadLinkReturn = { | export type GetUploadLinkReturn = { | ||||||
|   __typename?: "GetUploadLinkReturn"; |   __typename?: "GetUploadLinkReturn"; | ||||||
|   headers: Array<Maybe<Header>>; |   headers: Array<Maybe<Header>>; | ||||||
|  |   uploadCompletionCursor?: Maybe<Scalars["Int"]["output"]>; | ||||||
|   uploadUrl: Scalars["String"]["output"]; |   uploadUrl: Scalars["String"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1077,6 +1089,7 @@ export type MakePercentageIntervalGql = { | |||||||
|  |  | ||||||
| export type Mutation = { | export type Mutation = { | ||||||
|   __typename?: "Mutation"; |   __typename?: "Mutation"; | ||||||
|  |   addAnnotationToShot: Scalars["Boolean"]["output"]; | ||||||
|   createBucketSet: BucketSetGql; |   createBucketSet: BucketSetGql; | ||||||
|   createUploadStream: CreateUploadStreamReturn; |   createUploadStream: CreateUploadStreamReturn; | ||||||
|   deleteVideo: Scalars["Boolean"]["output"]; |   deleteVideo: Scalars["Boolean"]["output"]; | ||||||
| @@ -1089,6 +1102,11 @@ export type Mutation = { | |||||||
|   setSegmentDuration: Scalars["Boolean"]["output"]; |   setSegmentDuration: Scalars["Boolean"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type MutationAddAnnotationToShotArgs = { | ||||||
|  |   annotationName: Scalars["String"]["input"]; | ||||||
|  |   shotId: Scalars["Int"]["input"]; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type MutationCreateBucketSetArgs = { | export type MutationCreateBucketSetArgs = { | ||||||
|   params: CreateBucketSetInput; |   params: CreateBucketSetInput; | ||||||
| }; | }; | ||||||
| @@ -1163,6 +1181,17 @@ export type PocketingIntentionFeaturesGql = { | |||||||
|   targetPocketDistance?: Maybe<Scalars["Float"]["output"]>; |   targetPocketDistance?: Maybe<Scalars["Float"]["output"]>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export enum ProcessingStatusEnum { | ||||||
|  |   Created = "CREATED", | ||||||
|  |   Failed = "FAILED", | ||||||
|  |   Queued = "QUEUED", | ||||||
|  |   ReextractingFeatures = "REEXTRACTING_FEATURES", | ||||||
|  |   Running = "RUNNING", | ||||||
|  |   Started = "STARTED", | ||||||
|  |   Succeeded = "SUCCEEDED", | ||||||
|  |   Suspended = "SUSPENDED", | ||||||
|  | } | ||||||
|  |  | ||||||
| export type Query = { | export type Query = { | ||||||
|   __typename?: "Query"; |   __typename?: "Query"; | ||||||
|   getAggregatedShotMetrics: Array<AggregateResultGql>; |   getAggregatedShotMetrics: Array<AggregateResultGql>; | ||||||
| @@ -1179,6 +1208,7 @@ export type Query = { | |||||||
|   getVideo: VideoGql; |   getVideo: VideoGql; | ||||||
|   getVideoMakePercentageIntervals: Array<MakePercentageIntervalGql>; |   getVideoMakePercentageIntervals: Array<MakePercentageIntervalGql>; | ||||||
|   getVideos: Array<VideoGql>; |   getVideos: Array<VideoGql>; | ||||||
|  |   waitFor: Scalars["Float"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type QueryGetAggregatedShotMetricsArgs = { | export type QueryGetAggregatedShotMetricsArgs = { | ||||||
| @@ -1195,6 +1225,8 @@ export type QueryGetPlayTimeArgs = { | |||||||
|  |  | ||||||
| export type QueryGetShotsArgs = { | export type QueryGetShotsArgs = { | ||||||
|   filterInput: FilterInput; |   filterInput: FilterInput; | ||||||
|  |   limit?: Scalars["Int"]["input"]; | ||||||
|  |   shotsPagination?: InputMaybe<GetShotsPagination>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type QueryGetUserArgs = { | export type QueryGetUserArgs = { | ||||||
| @@ -1215,6 +1247,7 @@ export type QueryGetUsernamesArgs = { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| export type QueryGetVideoArgs = { | export type QueryGetVideoArgs = { | ||||||
|  |   debuggingJson?: InputMaybe<Scalars["JSON"]["input"]>; | ||||||
|   videoId: Scalars["Int"]["input"]; |   videoId: Scalars["Int"]["input"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1227,6 +1260,10 @@ export type QueryGetVideosArgs = { | |||||||
|   videoIds: Array<Scalars["Int"]["input"]>; |   videoIds: Array<Scalars["Int"]["input"]>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | export type QueryWaitForArgs = { | ||||||
|  |   duration: Scalars["Float"]["input"]; | ||||||
|  | }; | ||||||
|  |  | ||||||
| export type RangeFilter = { | export type RangeFilter = { | ||||||
|   greaterThanEqualTo?: InputMaybe<Scalars["Float"]["input"]>; |   greaterThanEqualTo?: InputMaybe<Scalars["Float"]["input"]>; | ||||||
|   includeOnNone?: Scalars["Boolean"]["input"]; |   includeOnNone?: Scalars["Boolean"]["input"]; | ||||||
| @@ -1278,6 +1315,7 @@ export type ShotGql = { | |||||||
|   startFrame: Scalars["Int"]["output"]; |   startFrame: Scalars["Int"]["output"]; | ||||||
|   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; |   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||||
|   user?: Maybe<UserGql>; |   user?: Maybe<UserGql>; | ||||||
|  |   video?: Maybe<VideoGql>; | ||||||
|   videoId: Scalars["Int"]["output"]; |   videoId: Scalars["Int"]["output"]; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -1424,6 +1462,17 @@ export type VideoProcessingErrorGql = { | |||||||
| export type VideoProcessingGql = { | export type VideoProcessingGql = { | ||||||
|   __typename?: "VideoProcessingGQL"; |   __typename?: "VideoProcessingGQL"; | ||||||
|   errors: Array<VideoProcessingErrorGql>; |   errors: Array<VideoProcessingErrorGql>; | ||||||
|  |   status: ProcessingStatusEnum; | ||||||
|  |   statuses: Array<VideoProcessingStatusGql>; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | export type VideoProcessingStatusGql = { | ||||||
|  |   __typename?: "VideoProcessingStatusGQL"; | ||||||
|  |   appVersion: Scalars["String"]["output"]; | ||||||
|  |   createdAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||||
|  |   sequenceId: Scalars["Int"]["output"]; | ||||||
|  |   status: ProcessingStatusEnum; | ||||||
|  |   updatedAt?: Maybe<Scalars["DateTime"]["output"]>; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| export type VideoResolution = { | export type VideoResolution = { | ||||||
| @@ -1551,6 +1600,8 @@ export type GetVideoMakePercentageIntervalsQuery = { | |||||||
|  |  | ||||||
| export type GetShotsQueryVariables = Exact<{ | export type GetShotsQueryVariables = Exact<{ | ||||||
|   filterInput: FilterInput; |   filterInput: FilterInput; | ||||||
|  |   shotsPagination?: InputMaybe<GetShotsPagination>; | ||||||
|  |   limit?: InputMaybe<Scalars["Int"]["input"]>; | ||||||
|   includeCreatedAt?: Scalars["Boolean"]["input"]; |   includeCreatedAt?: Scalars["Boolean"]["input"]; | ||||||
|   includeUpdatedAt?: Scalars["Boolean"]["input"]; |   includeUpdatedAt?: Scalars["Boolean"]["input"]; | ||||||
|   includeCueObjectFeatures?: Scalars["Boolean"]["input"]; |   includeCueObjectFeatures?: Scalars["Boolean"]["input"]; | ||||||
| @@ -1845,6 +1896,7 @@ export type GetVideoQuery = { | |||||||
|     } | null; |     } | null; | ||||||
|     homographyHistory: Array<{ |     homographyHistory: Array<{ | ||||||
|       __typename?: "HomographyInfoGQL"; |       __typename?: "HomographyInfoGQL"; | ||||||
|  |       frameIndex: number; | ||||||
|       crop: { |       crop: { | ||||||
|         __typename?: "BoundingBoxGQL"; |         __typename?: "BoundingBoxGQL"; | ||||||
|         left: number; |         left: number; | ||||||
| @@ -1931,6 +1983,7 @@ export type GetVideoForClipTimesQuery = { | |||||||
|   getVideo: { |   getVideo: { | ||||||
|     __typename?: "VideoGQL"; |     __typename?: "VideoGQL"; | ||||||
|     id: number; |     id: number; | ||||||
|  |     framesPerSecond: number; | ||||||
|     playlist?: { |     playlist?: { | ||||||
|       __typename?: "HLSPlaylistGQL"; |       __typename?: "HLSPlaylistGQL"; | ||||||
|       segmentDurations: Array<number>; |       segmentDurations: Array<number>; | ||||||
| @@ -2058,6 +2111,7 @@ export type GetUploadStreamsWithDetailsQuery = { | |||||||
|         isCompleted: boolean; |         isCompleted: boolean; | ||||||
|         lastIntendedSegmentBound?: number | null; |         lastIntendedSegmentBound?: number | null; | ||||||
|         uploadCompletionCursor: number; |         uploadCompletionCursor: number; | ||||||
|  |         uploadsCompleted: number; | ||||||
|       } | null; |       } | null; | ||||||
|     }>; |     }>; | ||||||
|     pageInfo: { |     pageInfo: { | ||||||
| @@ -2408,6 +2462,8 @@ export type GetVideoMakePercentageIntervalsQueryResult = Apollo.QueryResult< | |||||||
| export const GetShotsDocument = gql` | export const GetShotsDocument = gql` | ||||||
|   query GetShots( |   query GetShots( | ||||||
|     $filterInput: FilterInput! |     $filterInput: FilterInput! | ||||||
|  |     $shotsPagination: GetShotsPagination | ||||||
|  |     $limit: Int | ||||||
|     $includeCreatedAt: Boolean! = false |     $includeCreatedAt: Boolean! = false | ||||||
|     $includeUpdatedAt: Boolean! = false |     $includeUpdatedAt: Boolean! = false | ||||||
|     $includeCueObjectFeatures: Boolean! = false |     $includeCueObjectFeatures: Boolean! = false | ||||||
| @@ -2420,7 +2476,11 @@ export const GetShotsDocument = gql` | |||||||
|     $includeMake: Boolean! = false |     $includeMake: Boolean! = false | ||||||
|     $includeIntendedPocketType: Boolean! = false |     $includeIntendedPocketType: Boolean! = false | ||||||
|   ) { |   ) { | ||||||
|     getShots(filterInput: $filterInput) { |     getShots( | ||||||
|  |       filterInput: $filterInput | ||||||
|  |       shotsPagination: $shotsPagination | ||||||
|  |       limit: $limit | ||||||
|  |     ) { | ||||||
|       id |       id | ||||||
|       videoId |       videoId | ||||||
|       startFrame |       startFrame | ||||||
| @@ -2460,6 +2520,8 @@ export const GetShotsDocument = gql` | |||||||
|  * const { data, loading, error } = useGetShotsQuery({ |  * const { data, loading, error } = useGetShotsQuery({ | ||||||
|  *   variables: { |  *   variables: { | ||||||
|  *      filterInput: // value for 'filterInput' |  *      filterInput: // value for 'filterInput' | ||||||
|  |  *      shotsPagination: // value for 'shotsPagination' | ||||||
|  |  *      limit: // value for 'limit' | ||||||
|  *      includeCreatedAt: // value for 'includeCreatedAt' |  *      includeCreatedAt: // value for 'includeCreatedAt' | ||||||
|  *      includeUpdatedAt: // value for 'includeUpdatedAt' |  *      includeUpdatedAt: // value for 'includeUpdatedAt' | ||||||
|  *      includeCueObjectFeatures: // value for 'includeCueObjectFeatures' |  *      includeCueObjectFeatures: // value for 'includeCueObjectFeatures' | ||||||
| @@ -3379,6 +3441,7 @@ export const GetVideoDocument = gql` | |||||||
|         segmentDurations |         segmentDurations | ||||||
|       } |       } | ||||||
|       homographyHistory { |       homographyHistory { | ||||||
|  |         frameIndex | ||||||
|         crop { |         crop { | ||||||
|           left |           left | ||||||
|           top |           top | ||||||
| @@ -3720,6 +3783,7 @@ export const GetVideoForClipTimesDocument = gql` | |||||||
|   query GetVideoForClipTimes($videoId: Int!) { |   query GetVideoForClipTimes($videoId: Int!) { | ||||||
|     getVideo(videoId: $videoId) { |     getVideo(videoId: $videoId) { | ||||||
|       id |       id | ||||||
|  |       framesPerSecond | ||||||
|       playlist { |       playlist { | ||||||
|         segmentDurations |         segmentDurations | ||||||
|       } |       } | ||||||
| @@ -4172,6 +4236,7 @@ export const GetUploadStreamsWithDetailsDocument = gql` | |||||||
|           isCompleted |           isCompleted | ||||||
|           lastIntendedSegmentBound |           lastIntendedSegmentBound | ||||||
|           uploadCompletionCursor |           uploadCompletionCursor | ||||||
|  |           uploadsCompleted | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|       pageInfo { |       pageInfo { | ||||||
|   | |||||||
| @@ -1,5 +1,7 @@ | |||||||
| query GetShots( | query GetShots( | ||||||
|   $filterInput: FilterInput! |   $filterInput: FilterInput! | ||||||
|  |   $shotsPagination: GetShotsPagination | ||||||
|  |   $limit: Int | ||||||
|   $includeCreatedAt: Boolean! = false |   $includeCreatedAt: Boolean! = false | ||||||
|   $includeUpdatedAt: Boolean! = false |   $includeUpdatedAt: Boolean! = false | ||||||
|   $includeCueObjectFeatures: Boolean! = false |   $includeCueObjectFeatures: Boolean! = false | ||||||
| @@ -12,7 +14,11 @@ query GetShots( | |||||||
|   $includeMake: Boolean! = false |   $includeMake: Boolean! = false | ||||||
|   $includeIntendedPocketType: Boolean! = false |   $includeIntendedPocketType: Boolean! = false | ||||||
| ) { | ) { | ||||||
|   getShots(filterInput: $filterInput) { |   getShots( | ||||||
|  |     filterInput: $filterInput | ||||||
|  |     shotsPagination: $shotsPagination | ||||||
|  |     limit: $limit | ||||||
|  |   ) { | ||||||
|     id |     id | ||||||
|     videoId |     videoId | ||||||
|     startFrame |     startFrame | ||||||
|   | |||||||
| @@ -139,6 +139,7 @@ query GetVideo($videoId: Int!) { | |||||||
|       segmentDurations |       segmentDurations | ||||||
|     } |     } | ||||||
|     homographyHistory { |     homographyHistory { | ||||||
|  |       frameIndex | ||||||
|       crop { |       crop { | ||||||
|         left |         left | ||||||
|         top |         top | ||||||
| @@ -215,6 +216,7 @@ query GetMedianRunForVideo($videoId: Int!) { | |||||||
| query GetVideoForClipTimes($videoId: Int!) { | query GetVideoForClipTimes($videoId: Int!) { | ||||||
|   getVideo(videoId: $videoId) { |   getVideo(videoId: $videoId) { | ||||||
|     id |     id | ||||||
|  |     framesPerSecond | ||||||
|     playlist { |     playlist { | ||||||
|       segmentDurations |       segmentDurations | ||||||
|     } |     } | ||||||
|   | |||||||
| @@ -72,6 +72,7 @@ query GetUploadStreamsWithDetails( | |||||||
|         isCompleted |         isCompleted | ||||||
|         lastIntendedSegmentBound |         lastIntendedSegmentBound | ||||||
|         uploadCompletionCursor |         uploadCompletionCursor | ||||||
|  |         uploadsCompleted | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     pageInfo { |     pageInfo { | ||||||
|   | |||||||
| @@ -4,11 +4,16 @@ type Query { | |||||||
|   ): [AggregateResultGQL!]! |   ): [AggregateResultGQL!]! | ||||||
|   getBucketSet(keyName: String!): BucketSetGQL |   getBucketSet(keyName: String!): BucketSetGQL | ||||||
|   getDeployedConfig: DeployedConfigGQL! |   getDeployedConfig: DeployedConfigGQL! | ||||||
|  |   waitFor(duration: Float!): Float! | ||||||
|   getVideoMakePercentageIntervals( |   getVideoMakePercentageIntervals( | ||||||
|     videoId: ID! |     videoId: ID! | ||||||
|     intervalDuration: Int! = 300 |     intervalDuration: Int! = 300 | ||||||
|   ): [MakePercentageIntervalGQL!]! |   ): [MakePercentageIntervalGQL!]! | ||||||
|   getShots(filterInput: FilterInput!): [ShotGQL!]! |   getShots( | ||||||
|  |     filterInput: FilterInput! | ||||||
|  |     shotsPagination: GetShotsPagination = null | ||||||
|  |     limit: Int! = 500 | ||||||
|  |   ): [ShotGQL!]! | ||||||
|   getShotAnnotationTypes: [ShotAnnotationTypeGQL!]! |   getShotAnnotationTypes: [ShotAnnotationTypeGQL!]! | ||||||
|   getUser(userId: Int!): UserGQL |   getUser(userId: Int!): UserGQL | ||||||
|   getLoggedInUser: UserGQL |   getLoggedInUser: UserGQL | ||||||
| @@ -25,7 +30,7 @@ type Query { | |||||||
|     filters: VideoFilterInput = null |     filters: VideoFilterInput = null | ||||||
|   ): VideoHistoryGQL! |   ): VideoHistoryGQL! | ||||||
|   getUserTags: [TagGQL!]! |   getUserTags: [TagGQL!]! | ||||||
|   getVideo(videoId: Int!): VideoGQL! |   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! | ||||||
|   getVideos(videoIds: [Int!]!): [VideoGQL!]! |   getVideos(videoIds: [Int!]!): [VideoGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -168,6 +173,7 @@ type ShotGQL { | |||||||
|   user: UserGQL |   user: UserGQL | ||||||
|   annotations: [ShotAnnotationGQL!]! |   annotations: [ShotAnnotationGQL!]! | ||||||
|   falsePositiveScore: Float |   falsePositiveScore: Float | ||||||
|  |   video: VideoGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| """ | """ | ||||||
| @@ -229,15 +235,6 @@ type ShotAnnotationTypeGQL { | |||||||
|   name: String! |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| type UserPlayTimeGQL { |  | ||||||
|   totalSeconds: Float! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoHistoryGQL { |  | ||||||
|   videos: [VideoGQL!]! |  | ||||||
|   pageInfo: PageInfoGQL! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoGQL { | type VideoGQL { | ||||||
|   id: Int! |   id: Int! | ||||||
|   owner: UserGQL |   owner: UserGQL | ||||||
| @@ -356,6 +353,8 @@ type IntPoint2D { | |||||||
|  |  | ||||||
| type VideoProcessingGQL { | type VideoProcessingGQL { | ||||||
|   errors: [VideoProcessingErrorGQL!]! |   errors: [VideoProcessingErrorGQL!]! | ||||||
|  |   status: ProcessingStatusEnum! | ||||||
|  |   statuses: [VideoProcessingStatusGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| type VideoProcessingErrorGQL { | type VideoProcessingErrorGQL { | ||||||
| @@ -364,6 +363,44 @@ type VideoProcessingErrorGQL { | |||||||
|   endSegmentIndex: Int |   endSegmentIndex: Int | ||||||
| } | } | ||||||
|  |  | ||||||
|  | enum ProcessingStatusEnum { | ||||||
|  |   STARTED | ||||||
|  |   FAILED | ||||||
|  |   SUCCEEDED | ||||||
|  |   SUSPENDED | ||||||
|  |   CREATED | ||||||
|  |   QUEUED | ||||||
|  |   RUNNING | ||||||
|  |   REEXTRACTING_FEATURES | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type VideoProcessingStatusGQL { | ||||||
|  |   status: ProcessingStatusEnum! | ||||||
|  |   appVersion: String! | ||||||
|  |   sequenceId: Int! | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input GetShotsPagination { | ||||||
|  |   createdAfter: CreatedAfter! | ||||||
|  |   startFrameAfter: Int! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input CreatedAfter @oneOf { | ||||||
|  |   videoId: Int | ||||||
|  |   createdAt: DateTime | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type UserPlayTimeGQL { | ||||||
|  |   totalSeconds: Float! | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type VideoHistoryGQL { | ||||||
|  |   videos: [VideoGQL!]! | ||||||
|  |   pageInfo: PageInfoGQL! | ||||||
|  | } | ||||||
|  |  | ||||||
| type PageInfoGQL { | type PageInfoGQL { | ||||||
|   hasNextPage: Boolean! |   hasNextPage: Boolean! | ||||||
|   endCursor: String |   endCursor: String | ||||||
| @@ -380,9 +417,18 @@ type TagGQL { | |||||||
|   group: String |   group: String | ||||||
| } | } | ||||||
|  |  | ||||||
|  | """ | ||||||
|  | The `JSON` scalar type represents JSON values as specified by [ECMA-404](https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf). | ||||||
|  | """ | ||||||
|  | scalar JSON | ||||||
|  |   @specifiedBy( | ||||||
|  |     url: "https://ecma-international.org/wp-content/uploads/ECMA-404_2nd_edition_december_2017.pdf" | ||||||
|  |   ) | ||||||
|  |  | ||||||
| type Mutation { | type Mutation { | ||||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! |   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||||
|   setLoggerLevel(path: String!, level: String!): Boolean! |   setLoggerLevel(path: String!, level: String!): Boolean! | ||||||
|  |   addAnnotationToShot(shotId: Int!, annotationName: String!): Boolean! | ||||||
|   getProfileImageUploadLink(fileExt: String = ".png"): GetUploadLinkReturn! |   getProfileImageUploadLink(fileExt: String = ".png"): GetUploadLinkReturn! | ||||||
|   editProfileImageUri(profileImageUri: String!): UserGQL! |   editProfileImageUri(profileImageUri: String!): UserGQL! | ||||||
|   createUploadStream( |   createUploadStream( | ||||||
| @@ -408,6 +454,7 @@ input CreateBucketSetInput { | |||||||
| type GetUploadLinkReturn { | type GetUploadLinkReturn { | ||||||
|   uploadUrl: String! |   uploadUrl: String! | ||||||
|   headers: [Header]! |   headers: [Header]! | ||||||
|  |   uploadCompletionCursor: Int | ||||||
| } | } | ||||||
|  |  | ||||||
| type Header { | type Header { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user