Compare commits
	
		
			1 Commits
		
	
	
		
			051555f9fc
			...
			kat/get-id
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 478c04215f | 
| @@ -1,7 +1,5 @@ | |||||||
| overwrite: true | overwrite: true | ||||||
| schema: | schema: "src/schema.gql" | ||||||
|   - "src/schema.gql" |  | ||||||
|   - "src/client-schema.gql" |  | ||||||
| documents: "src/**/*.gql" | documents: "src/**/*.gql" | ||||||
| generates: | generates: | ||||||
|   src/index.tsx: |   src/index.tsx: | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ | |||||||
|   "author": "Ivan Malison <IvanMalison@gmail.com>", |   "author": "Ivan Malison <IvanMalison@gmail.com>", | ||||||
|   "license": "MIT", |   "license": "MIT", | ||||||
|   "dependencies": { |   "dependencies": { | ||||||
|     "@apollo/client": "^3.11.10", |     "@apollo/client": "^3.9.2", | ||||||
|     "@graphql-codegen/cli": "^5.0.0", |     "@graphql-codegen/cli": "^5.0.0", | ||||||
|     "@graphql-codegen/typescript": "^4.0.1", |     "@graphql-codegen/typescript": "^4.0.1", | ||||||
|     "@graphql-codegen/typescript-operations": "^4.0.1", |     "@graphql-codegen/typescript-operations": "^4.0.1", | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ readme = "README.md" | |||||||
| packages = [{include = "rbproto"}] | packages = [{include = "rbproto"}] | ||||||
|  |  | ||||||
| [tool.poetry.dependencies] | [tool.poetry.dependencies] | ||||||
| python = ">=3.10,<=3.13" | python = ">=3.10,<3.12" | ||||||
| protobuf = "^4.25.3" | protobuf = "^4.25.3" | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,32 +0,0 @@ | |||||||
| # see: https://www.apollographql.com/docs/react/local-state/managing-state-with-field-policies/ |  | ||||||
| directive @client on FIELD |  | ||||||
|  |  | ||||||
| type SegmentInfo { |  | ||||||
|   index: Int! |  | ||||||
|   time: Float! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| extend type ShotGQL { |  | ||||||
|   startTime: Float! |  | ||||||
|   endTime: Float! |  | ||||||
|   startSegment: SegmentInfo! |  | ||||||
|   endSegment: SegmentInfo! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| extend type UploadStreamGQL { |  | ||||||
|   segmentEndFrames: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| extend type HLSPlaylistGQL { |  | ||||||
|   segmentStartTimes: [Float!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type SegmentEndFramesGQL { |  | ||||||
|   id: Int! |  | ||||||
|   segmentEndFrames: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type SegmentStartTimesGQL { |  | ||||||
|   id: Int! |  | ||||||
|   segmentStartTimes: [Float!]! |  | ||||||
| } |  | ||||||
							
								
								
									
										6047
									
								
								src/index.tsx
									
									
									
									
									
								
							
							
						
						
									
										6047
									
								
								src/index.tsx
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,19 +0,0 @@ | |||||||
| mutation CommentOnVideo( |  | ||||||
|   $videoId: Int! |  | ||||||
|   $message: String! |  | ||||||
|   $parentCommentId: Int |  | ||||||
| ) { |  | ||||||
|   commentOnVideo( |  | ||||||
|     videoId: $videoId |  | ||||||
|     message: $message |  | ||||||
|     parentCommentId: $parentCommentId |  | ||||||
|   ) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation EditComment($videoId: Int!, $commentId: Int!, $newMessage: String!) { |  | ||||||
|   editComment(videoId: $videoId, commentId: $commentId, newMessage: $newMessage) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation DeleteComment($videoId: Int!, $commentId: Int!) { |  | ||||||
|   deleteComment(videoId: $videoId, commentId: $commentId) |  | ||||||
| } |  | ||||||
| @@ -5,14 +5,5 @@ query getDeployedConfig { | |||||||
|     environment |     environment | ||||||
|     firebase |     firebase | ||||||
|     minimumAllowedAppVersion |     minimumAllowedAppVersion | ||||||
|     subscriptionGatingEnabled |  | ||||||
|     bannerMessages { |  | ||||||
|       color |  | ||||||
|       dismissible |  | ||||||
|       id |  | ||||||
|       kind |  | ||||||
|       message |  | ||||||
|       priority |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,15 +0,0 @@ | |||||||
| mutation blockContent($videoId: Int!) { |  | ||||||
|   blockContent(videoId: $videoId) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation blockUser($userId: Int!) { |  | ||||||
|   blockUser(userId: $userId) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation reportContent( |  | ||||||
|   $videoId: Int! |  | ||||||
|   $reason: ReportReasonEnum! |  | ||||||
|   $customReason: String = null |  | ||||||
| ) { |  | ||||||
|   reportContent(videoId: $videoId, reason: $reason, customReason: $customReason) |  | ||||||
| } |  | ||||||
| @@ -1,4 +1,3 @@ | |||||||
| # DO NOT USE: use getVideoFeed instead |  | ||||||
| query GetFeed( | query GetFeed( | ||||||
|   $limit: Int! = 5 |   $limit: Int! = 5 | ||||||
|   $after: String = null |   $after: String = null | ||||||
| @@ -6,52 +5,23 @@ query GetFeed( | |||||||
| ) { | ) { | ||||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|     videos { |     videos { | ||||||
|       ...VideoCardFields |  | ||||||
|     } |  | ||||||
|     pageInfo { |  | ||||||
|       hasNextPage |  | ||||||
|       endCursor |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment UserSocialsFields on UserGQL { |  | ||||||
|   id |  | ||||||
|   username |  | ||||||
|   profileImageUri |  | ||||||
|   followers { |  | ||||||
|     id |  | ||||||
|     username |  | ||||||
|     profileImageUri |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment VideoCardFields on VideoGQL { |  | ||||||
|       id |       id | ||||||
|       owner { |       owner { | ||||||
|     id |  | ||||||
|         username |         username | ||||||
|     profileImageUri |  | ||||||
|       } |       } | ||||||
|       name |       name | ||||||
|       screenshotUri |       screenshotUri | ||||||
|       totalShotsMade |       totalShotsMade | ||||||
|       totalShots |       totalShots | ||||||
|       makePercentage |       makePercentage | ||||||
|   averageTimeBetweenShots |  | ||||||
|   averageDifficulty |  | ||||||
|       createdAt |       createdAt | ||||||
|       updatedAt |       updatedAt | ||||||
|       startTime |       startTime | ||||||
|       endTime |       endTime | ||||||
|   private |  | ||||||
|       elapsedTime |       elapsedTime | ||||||
|       screenshotUri |       screenshotUri | ||||||
|       stream { |       stream { | ||||||
|     id |  | ||||||
|     lastIntendedSegmentBound |  | ||||||
|         isCompleted |         isCompleted | ||||||
|     streamSegmentType |  | ||||||
|       } |       } | ||||||
|       tableSize |       tableSize | ||||||
|       tags { |       tags { | ||||||
| @@ -60,57 +30,6 @@ fragment VideoCardFields on VideoGQL { | |||||||
|         } |         } | ||||||
|         name |         name | ||||||
|       } |       } | ||||||
|   currentProcessing { |  | ||||||
|     id |  | ||||||
|     errors { |  | ||||||
|       message |  | ||||||
|     } |  | ||||||
|     status |  | ||||||
|     statuses { |  | ||||||
|       status |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
|   reactions { |  | ||||||
|     videoId |  | ||||||
|     user { |  | ||||||
|       ...UserSocialsFields |  | ||||||
|     } |  | ||||||
|     reaction |  | ||||||
|   } |  | ||||||
|   comments { |  | ||||||
|     id |  | ||||||
|     message |  | ||||||
|     user { |  | ||||||
|       ...UserSocialsFields |  | ||||||
|     } |  | ||||||
|     replies { |  | ||||||
|       id |  | ||||||
|       message |  | ||||||
|       user { |  | ||||||
|         ...UserSocialsFields |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetVideoFeed( |  | ||||||
|   $limit: Int! = 5 |  | ||||||
|   $after: String = null |  | ||||||
|   $filters: VideoFilterInput = null |  | ||||||
|   $includeCallersVideos: Boolean = null |  | ||||||
|   $includePrivate: IncludePrivateEnum = MINE |  | ||||||
|   $feedInput: VideoFeedInputGQL = null |  | ||||||
| ) { |  | ||||||
|   getFeedVideos( |  | ||||||
|     limit: $limit |  | ||||||
|     after: $after |  | ||||||
|     filters: $filters |  | ||||||
|     includeCallersVideos: $includeCallersVideos |  | ||||||
|     includePrivate: $includePrivate |  | ||||||
|     feedInput: $feedInput |  | ||||||
|   ) { |  | ||||||
|     videos { |  | ||||||
|       ...VideoCardFields |  | ||||||
|     } |     } | ||||||
|     pageInfo { |     pageInfo { | ||||||
|       hasNextPage |       hasNextPage | ||||||
|   | |||||||
| @@ -1,32 +0,0 @@ | |||||||
| query GetMakesLeaderboard($interval: TimeInterval, $when: DateTime) { |  | ||||||
|   getMakesLeaderboard(interval: $interval, when: $when) { |  | ||||||
|     entries { |  | ||||||
|       user { |  | ||||||
|         id |  | ||||||
|         username |  | ||||||
|         profileImageUri |  | ||||||
|       } |  | ||||||
|       value |  | ||||||
|       proportionMade |  | ||||||
|       total |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetRunsLeaderboard($interval: TimeInterval, $when: DateTime) { |  | ||||||
|   getLongestRunsLeaderboard(interval: $interval, when: $when) { |  | ||||||
|     entries { |  | ||||||
|       id |  | ||||||
|       runLength |  | ||||||
|       video { |  | ||||||
|         name |  | ||||||
|         createdAt |  | ||||||
|       } |  | ||||||
|       user { |  | ||||||
|         id |  | ||||||
|         username |  | ||||||
|         profileImageUri |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,75 +0,0 @@ | |||||||
| fragment MedalFields on MedalGQL { |  | ||||||
|   count |  | ||||||
|   nickname |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query getMedals($scope: MedalScope!, $userId: Int) { |  | ||||||
|   getMedals(scope: $scope, userId: $userId) { |  | ||||||
|     distanceOver78 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     distanceOver90 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength3 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength5 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength8 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength10 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength15 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength20 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength25 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength30 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength40 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     runLength50 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes100 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes500 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes1000 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes5000 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     totalMakes10000 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes50 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes100 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes150 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes200 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|     dailyMakes250 { |  | ||||||
|       ...MedalFields |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,65 +0,0 @@ | |||||||
| mutation EnsureStripeCustomerExists { |  | ||||||
|   ensureStripeCustomerExists { |  | ||||||
|     id |  | ||||||
|     firebaseUid |  | ||||||
|     username |  | ||||||
|     stripeCustomerId |  | ||||||
|     profileImageUri |  | ||||||
|     isAdmin |  | ||||||
|     fargoRating |  | ||||||
|     videosPrivateByDefault |  | ||||||
|     createdAt |  | ||||||
|     updatedAt |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation CreateSubscription($priceId: String!) { |  | ||||||
|   createSubscription(priceId: $priceId) { |  | ||||||
|     checkoutUrl |  | ||||||
|     sessionId |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetAvailableSubscriptionOptions { |  | ||||||
|   getAvailableSubscriptionOptions { |  | ||||||
|     products { |  | ||||||
|       id |  | ||||||
|       name |  | ||||||
|       description |  | ||||||
|       active |  | ||||||
|       prices { |  | ||||||
|         id |  | ||||||
|         currency |  | ||||||
|         unitAmount |  | ||||||
|         recurringInterval |  | ||||||
|         recurringIntervalCount |  | ||||||
|         type |  | ||||||
|         active |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetSubscriptionStatus { |  | ||||||
|   getUserSubscriptionStatus { |  | ||||||
|     hasActiveSubscription |  | ||||||
|     subscriptionStatus |  | ||||||
|     currentPeriodStart |  | ||||||
|     currentPeriodEnd |  | ||||||
|     validUntil |  | ||||||
|     stripePriceId |  | ||||||
|     stripeSubscriptionId |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation CancelSubscription { |  | ||||||
|   cancelSubscription { |  | ||||||
|     hasActiveSubscription |  | ||||||
|     subscriptionStatus |  | ||||||
|     currentPeriodStart |  | ||||||
|     currentPeriodEnd |  | ||||||
|     validUntil |  | ||||||
|     stripePriceId |  | ||||||
|     stripeSubscriptionId |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -1,3 +0,0 @@ | |||||||
| mutation ReactToVideo($videoId: Int!, $reaction: ReactionEnum) { |  | ||||||
|   reactToVideo(videoId: $videoId, reaction: $reaction) |  | ||||||
| } |  | ||||||
| @@ -1,67 +0,0 @@ | |||||||
| query GetRunsForHighlights( |  | ||||||
|   $filterInput: RunFilterInput! |  | ||||||
|   $runIds: [Int!] = null |  | ||||||
|   $runsOrdering: GetRunsOrdering |  | ||||||
|   $limit: Int! = 500 |  | ||||||
|   $countRespectsLimit: Boolean! = false |  | ||||||
| ) { |  | ||||||
|   getRuns( |  | ||||||
|     filterInput: $filterInput |  | ||||||
|     runIds: $runIds |  | ||||||
|     runsOrdering: $runsOrdering |  | ||||||
|     limit: $limit |  | ||||||
|     countRespectsLimit: $countRespectsLimit |  | ||||||
|   ) { |  | ||||||
|     count |  | ||||||
|     runs { |  | ||||||
|       id |  | ||||||
|       runLength |  | ||||||
|       userId |  | ||||||
|       videoId |  | ||||||
|       shots { |  | ||||||
|         videoId |  | ||||||
|         id |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     runIds |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment PocketingIntentionFragment on PocketingIntentionFeaturesGQL { |  | ||||||
|   make |  | ||||||
|   targetPocketDistance |  | ||||||
|   targetPocketAngle |  | ||||||
|   targetPocketAngleDirection |  | ||||||
|   marginOfErrorInDegrees |  | ||||||
|   intendedPocketType |  | ||||||
|   difficulty |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetRunsWithTimestamps( |  | ||||||
|   $filterInput: RunFilterInput! |  | ||||||
|   $runIds: [Int!] = null |  | ||||||
|   $runsOrdering: GetRunsOrdering |  | ||||||
| ) { |  | ||||||
|   getRuns( |  | ||||||
|     filterInput: $filterInput |  | ||||||
|     runIds: $runIds |  | ||||||
|     runsOrdering: $runsOrdering |  | ||||||
|   ) { |  | ||||||
|     count |  | ||||||
|     runs { |  | ||||||
|       id |  | ||||||
|       runLength |  | ||||||
|       userId |  | ||||||
|       videoId |  | ||||||
|       shots { |  | ||||||
|         videoId |  | ||||||
|         id |  | ||||||
|         createdAt |  | ||||||
|         pocketingIntentionFeatures { |  | ||||||
|           ...PocketingIntentionFragment |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     runIds |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| @@ -17,95 +17,6 @@ query GetShotAnnotationTypes { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation UpdateShotAnnotations( |  | ||||||
|   $shotId: Int! |  | ||||||
|   $annotations: [UpdateAnnotationInputGQL!]! |  | ||||||
| ) { |  | ||||||
|   updateShotAnnotations(shotId: $shotId, annotations: $annotations) { |  | ||||||
|     shot { |  | ||||||
|       id |  | ||||||
|       annotations { |  | ||||||
|         shotId |  | ||||||
|         type { |  | ||||||
|           id |  | ||||||
|           name |  | ||||||
|         } |  | ||||||
|         notes |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|     error { |  | ||||||
|       shotId |  | ||||||
|       msg |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ## Should be deprecated |  | ||||||
| query GetShotsWithVideoGql( |  | ||||||
|   $filterInput: FilterInput! |  | ||||||
|   $shotsOrdering: GetShotsOrdering |  | ||||||
|   $limit: Int |  | ||||||
| ) { |  | ||||||
|   getOrderedShots( |  | ||||||
|     filterInput: $filterInput |  | ||||||
|     shotsOrdering: $shotsOrdering |  | ||||||
|     limit: $limit |  | ||||||
|   ) { |  | ||||||
|     shots { |  | ||||||
|       id |  | ||||||
|       videoId |  | ||||||
|       video { |  | ||||||
|         screenshotUri |  | ||||||
|         endTime |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetShotsWithJustIds( |  | ||||||
|   $filterInput: FilterInput! |  | ||||||
|   $shotsOrdering: GetShotsOrdering |  | ||||||
|   $limit: Int |  | ||||||
|   $countRespectsLimit: Boolean |  | ||||||
| ) { |  | ||||||
|   getOrderedShots( |  | ||||||
|     filterInput: $filterInput |  | ||||||
|     shotsOrdering: $shotsOrdering |  | ||||||
|     limit: $limit |  | ||||||
|     countRespectsLimit: $countRespectsLimit |  | ||||||
|   ) { |  | ||||||
|     count |  | ||||||
|     shots { |  | ||||||
|       id |  | ||||||
|       videoId |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ## Reserved for playlists (which are created from a filter) |  | ||||||
| query GetShotsWithMetadataFilterResult( |  | ||||||
|   $filterInput: FilterInput! |  | ||||||
|   $shotsOrdering: GetShotsOrdering |  | ||||||
|   $limit: Int |  | ||||||
|   $ids: [Int!] |  | ||||||
|   $countRespectsLimit: Boolean |  | ||||||
| ) { |  | ||||||
|   getOrderedShots( |  | ||||||
|     filterInput: $filterInput |  | ||||||
|     shotsOrdering: $shotsOrdering |  | ||||||
|     limit: $limit |  | ||||||
|     ids: $ids |  | ||||||
|     countRespectsLimit: $countRespectsLimit |  | ||||||
|   ) { |  | ||||||
|     count |  | ||||||
|     shots { |  | ||||||
|       ...ShotWithAllFeatures |  | ||||||
|     } |  | ||||||
|     ids |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| # TODO: Delete |  | ||||||
| query GetShotsWithMetadata( | query GetShotsWithMetadata( | ||||||
|   $filterInput: FilterInput! |   $filterInput: FilterInput! | ||||||
|   $shotsPagination: GetShotsPagination |   $shotsPagination: GetShotsPagination | ||||||
| @@ -137,20 +48,18 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|   videoId |   videoId | ||||||
|   startFrame |   startFrame | ||||||
|   endFrame |   endFrame | ||||||
|   startTime @client |  | ||||||
|   endTime @client |  | ||||||
|   startSegment @client { |  | ||||||
|     index |  | ||||||
|     time |  | ||||||
|   } |  | ||||||
|   endSegment @client { |  | ||||||
|     index |  | ||||||
|     time |  | ||||||
|   } |  | ||||||
|   user { |   user { | ||||||
|     id |     id | ||||||
|   } |   } | ||||||
|   falsePositiveScore |   falsePositiveScore | ||||||
|  |   video { | ||||||
|  |     stream { | ||||||
|  |       resolution { | ||||||
|  |         width | ||||||
|  |         height | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|   createdAt |   createdAt | ||||||
|   updatedAt |   updatedAt | ||||||
|   cueObjectFeatures { |   cueObjectFeatures { | ||||||
| @@ -161,13 +70,9 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|     spinType |     spinType | ||||||
|   } |   } | ||||||
|   pocketingIntentionFeatures { |   pocketingIntentionFeatures { | ||||||
|     make |  | ||||||
|     targetPocketDistance |     targetPocketDistance | ||||||
|     targetPocketAngle |     make | ||||||
|     targetPocketAngleDirection |  | ||||||
|     marginOfErrorInDegrees |  | ||||||
|     intendedPocketType |     intendedPocketType | ||||||
|     difficulty |  | ||||||
|   } |   } | ||||||
|   pocketingIntentionInfo { |   pocketingIntentionInfo { | ||||||
|     ballId |     ballId | ||||||
| @@ -177,31 +82,4 @@ fragment ShotWithAllFeatures on ShotGQL { | |||||||
|   serializedShotPaths { |   serializedShotPaths { | ||||||
|     b64EncodedBuffer |     b64EncodedBuffer | ||||||
|   } |   } | ||||||
|   annotations { |  | ||||||
|     shotId |  | ||||||
|     type { |  | ||||||
|       id |  | ||||||
|       name |  | ||||||
|     } |  | ||||||
|     notes |  | ||||||
|   } |  | ||||||
|   video { |  | ||||||
|     id |  | ||||||
|     stream { |  | ||||||
|       id |  | ||||||
|       streamSegmentType |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation EditShot($shotId: Int!, $fieldsToEdit: EditableShotFieldInputGQL!) { |  | ||||||
|   editShot(shotId: $shotId, fieldsToEdit: $fieldsToEdit) { |  | ||||||
|     error { |  | ||||||
|       shotId |  | ||||||
|       msg |  | ||||||
|     } |  | ||||||
|     shot { |  | ||||||
|       ...ShotWithAllFeatures |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +0,0 @@ | |||||||
| mutation RetireTags($tagIds: [Int!]!) { |  | ||||||
|   retireTags(tagIds: $tagIds) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation DeleteTags($videoId: Int!, $tagsToDelete: [VideoTagInput!]!) { |  | ||||||
|   deleteTags(videoId: $videoId, tagsToDelete: $tagsToDelete) |  | ||||||
| } |  | ||||||
| @@ -21,24 +21,30 @@ mutation getProfileImageUploadLink($fileExt: String = ".png") { | |||||||
|  |  | ||||||
| mutation editProfileImageUri($profileImageUri: String!) { | mutation editProfileImageUri($profileImageUri: String!) { | ||||||
|   editProfileImageUri(profileImageUri: $profileImageUri) { |   editProfileImageUri(profileImageUri: $profileImageUri) { | ||||||
|     ...UserFragment |     id | ||||||
|  |     firebaseUid | ||||||
|  |     username | ||||||
|  |     profileImageUri | ||||||
|  |     createdAt | ||||||
|  |     updatedAt | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query getLoggedInUser { | query getLoggedInUser { | ||||||
|   getLoggedInUser { |   getLoggedInUser { | ||||||
|     ...UserFragment |     id | ||||||
|  |     firebaseUid | ||||||
|  |     username | ||||||
|  |     isAdmin | ||||||
|  |     profileImageUri | ||||||
|  |     activeVideoId | ||||||
|  |     createdAt | ||||||
|  |     updatedAt | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| query GetUser($userId: Int!) { | query GetUserPlayTime($userId: Int!) { | ||||||
|   getUser(userId: $userId) { |   getPlayTime(userId: $userId) { | ||||||
|     ...UserFragment |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetUserPlayTime($userId: Int!, $filters: VideoFilterInput) { |  | ||||||
|   getPlayTime(userId: $userId, filters: $filters) { |  | ||||||
|     totalSeconds |     totalSeconds | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @@ -51,125 +57,9 @@ query getUsernames( | |||||||
|   getUsernames(matchString: $matchString, limit: $limit, after: $after) |   getUsernames(matchString: $matchString, limit: $limit, after: $after) | ||||||
| } | } | ||||||
|  |  | ||||||
| query getUserRelationshipsMatching( |  | ||||||
|   $userId: Int! |  | ||||||
|   $matchString: String! |  | ||||||
|   $limit: Int = null |  | ||||||
|   $after: String = null |  | ||||||
| ) { |  | ||||||
|   getUserRelationshipsMatching( |  | ||||||
|     userId: $userId |  | ||||||
|     matchString: $matchString |  | ||||||
|     limit: $limit |  | ||||||
|     after: $after |  | ||||||
|   ) { |  | ||||||
|     relationships { |  | ||||||
|       toUser { |  | ||||||
|         username |  | ||||||
|         profileImageUri |  | ||||||
|         id |  | ||||||
|       } |  | ||||||
|       toUserFollows |  | ||||||
|       toUserIsFollowedBy |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetUserTags { | query GetUserTags { | ||||||
|   getUserTags { |   getUserTags { | ||||||
|     id |     id | ||||||
|     name |     name | ||||||
|     tagClasses { |  | ||||||
|       id |  | ||||||
|       name |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| mutation followUser($followedUserId: Int!) { |  | ||||||
|   followUser(followedUserId: $followedUserId) { |  | ||||||
|     username |  | ||||||
|     id |  | ||||||
|     following { |  | ||||||
|       id |  | ||||||
|       username |  | ||||||
|     } |  | ||||||
|     followers { |  | ||||||
|       id |  | ||||||
|       username |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation unfollowUser($followedUserId: Int!) { |  | ||||||
|   unfollowUser(followedUserId: $followedUserId) { |  | ||||||
|     username |  | ||||||
|     id |  | ||||||
|     following { |  | ||||||
|       id |  | ||||||
|       username |  | ||||||
|     } |  | ||||||
|     followers { |  | ||||||
|       id |  | ||||||
|       username |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query getUserFollowingFollowers { |  | ||||||
|   getLoggedInUser { |  | ||||||
|     id |  | ||||||
|     following { |  | ||||||
|       id |  | ||||||
|       username |  | ||||||
|       profileImageUri |  | ||||||
|     } |  | ||||||
|     followers { |  | ||||||
|       id |  | ||||||
|       username |  | ||||||
|       profileImageUri |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query doesUsernameExist($candidateUsername: String!) { |  | ||||||
|   doesUsernameExist(candidateUsername: $candidateUsername) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation editUser( |  | ||||||
|   $username: String |  | ||||||
|   $fargoRating: Int |  | ||||||
|   $videosPrivateByDefault: Boolean |  | ||||||
| ) { |  | ||||||
|   editUser( |  | ||||||
|     input: { |  | ||||||
|       username: $username |  | ||||||
|       fargoRating: $fargoRating |  | ||||||
|       videosPrivateByDefault: $videosPrivateByDefault |  | ||||||
|     } |  | ||||||
|   ) { |  | ||||||
|     id |  | ||||||
|     firebaseUid |  | ||||||
|     username |  | ||||||
|     fargoRating |  | ||||||
|     updatedAt |  | ||||||
|     videosPrivateByDefault |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation deleteUser { |  | ||||||
|   deleteUser |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment UserFragment on UserGQL { |  | ||||||
|   id |  | ||||||
|   firebaseUid |  | ||||||
|   username |  | ||||||
|   isAdmin |  | ||||||
|   profileImageUri |  | ||||||
|   fargoRating |  | ||||||
|   activeVideoId |  | ||||||
|   createdAt |  | ||||||
|   updatedAt |  | ||||||
|   videosPrivateByDefault |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -5,10 +5,46 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | |||||||
|     makePercentage |     makePercentage | ||||||
|     elapsedTime |     elapsedTime | ||||||
|     currentHomography { |     currentHomography { | ||||||
|       ...HomographyInfo |       crop { | ||||||
|  |         left | ||||||
|  |         top | ||||||
|  |         width | ||||||
|  |         height | ||||||
|  |       } | ||||||
|  |       pockets { | ||||||
|  |         left | ||||||
|  |         top | ||||||
|  |         width | ||||||
|  |         height | ||||||
|  |       } | ||||||
|  |       sourcePoints { | ||||||
|  |         topLeft { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         topSide { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         topRight { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         bottomLeft { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         bottomSide { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |         bottomRight { | ||||||
|  |           x | ||||||
|  |           y | ||||||
|  |         } | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|     stream { |     stream { | ||||||
|       id |  | ||||||
|       linksRequested |       linksRequested | ||||||
|       uploadsCompleted |       uploadsCompleted | ||||||
|       segmentProcessingCursor |       segmentProcessingCursor | ||||||
| @@ -18,7 +54,6 @@ query GetStreamMonitoringDetails($videoId: Int!, $debuggingJson: JSON) { | |||||||
|       initPlaylistUploadStatus |       initPlaylistUploadStatus | ||||||
|     } |     } | ||||||
|     currentProcessing { |     currentProcessing { | ||||||
|       id |  | ||||||
|       errors { |       errors { | ||||||
|         message |         message | ||||||
|         startSegmentIndex |         startSegmentIndex | ||||||
| @@ -36,7 +71,6 @@ query GetVideoUpdatePageDetails($videoId: Int!) { | |||||||
|     makePercentage |     makePercentage | ||||||
|     elapsedTime |     elapsedTime | ||||||
|     tableSize |     tableSize | ||||||
|     private |  | ||||||
|     tags { |     tags { | ||||||
|       tagClasses { |       tagClasses { | ||||||
|         name |         name | ||||||
| @@ -66,7 +100,6 @@ query GetVideoDetails($videoId: Int!) { | |||||||
|     createdAt |     createdAt | ||||||
|     updatedAt |     updatedAt | ||||||
|     tableSize |     tableSize | ||||||
|     private |  | ||||||
|     owner { |     owner { | ||||||
|       id |       id | ||||||
|       firebaseUid |       firebaseUid | ||||||
| @@ -82,64 +115,8 @@ query GetVideoDetails($videoId: Int!) { | |||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| fragment UserSocialsFields on UserGQL { |  | ||||||
|   id |  | ||||||
|   username |  | ||||||
|   profileImageUri |  | ||||||
|   followers { |  | ||||||
|     id |  | ||||||
|     username |  | ||||||
|     profileImageUri |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetVideoSocialDetailsById($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     id |  | ||||||
|     name |  | ||||||
|     owner { |  | ||||||
|       id |  | ||||||
|       firebaseUid |  | ||||||
|       username |  | ||||||
|       profileImageUri |  | ||||||
|     } |  | ||||||
|     tags { |  | ||||||
|       tagClasses { |  | ||||||
|         name |  | ||||||
|       } |  | ||||||
|       name |  | ||||||
|     } |  | ||||||
|     reactions { |  | ||||||
|       videoId |  | ||||||
|       user { |  | ||||||
|         ...UserSocialsFields |  | ||||||
|       } |  | ||||||
|       reaction |  | ||||||
|     } |  | ||||||
|     comments { |  | ||||||
|       id |  | ||||||
|       message |  | ||||||
|       user { |  | ||||||
|         ...UserSocialsFields |  | ||||||
|       } |  | ||||||
|       replies { |  | ||||||
|         id |  | ||||||
|         message |  | ||||||
|         user { |  | ||||||
|           ...UserSocialsFields |  | ||||||
|         } |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetVideos($videoIds: [Int!]!) { | query GetVideos($videoIds: [Int!]!) { | ||||||
|   getVideos(videoIds: $videoIds) { |   getVideos(videoIds: $videoIds) { | ||||||
|     ...VideoStreamMetadata |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment VideoStreamMetadata on VideoGQL { |  | ||||||
|     id |     id | ||||||
|     framesPerSecond |     framesPerSecond | ||||||
|     stream { |     stream { | ||||||
| @@ -156,11 +133,6 @@ fragment VideoStreamMetadata on VideoGQL { | |||||||
|     playlist { |     playlist { | ||||||
|       segmentDurations |       segmentDurations | ||||||
|     } |     } | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetVideoForShotTime($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     ...VideoStreamMetadata |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -171,128 +143,6 @@ query GetVideo($videoId: Int!) { | |||||||
|       segmentDurations |       segmentDurations | ||||||
|     } |     } | ||||||
|     homographyHistory { |     homographyHistory { | ||||||
|       ...HomographyInfo |  | ||||||
|     } |  | ||||||
|     stream { |  | ||||||
|       id |  | ||||||
|       streamSegmentType |  | ||||||
|       segments { |  | ||||||
|         segmentIndex |  | ||||||
|         endFrameIndex |  | ||||||
|         framesPerSecond |  | ||||||
|       } |  | ||||||
|       resolution { |  | ||||||
|         width |  | ||||||
|         height |  | ||||||
|       } |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetAverageTimePerShotForVideo($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     id |  | ||||||
|     averageTimeBetweenShots |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetElapsedTimeForVideo($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     id |  | ||||||
|     elapsedTime |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetMedianRunForVideo($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     id |  | ||||||
|     medianRun |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment StreamWithEndFrames on UploadStreamGQL { |  | ||||||
|   id |  | ||||||
|   streamSegmentType |  | ||||||
|   segmentEndFrames @client |  | ||||||
|   resolution { |  | ||||||
|     width |  | ||||||
|     height |  | ||||||
|   } |  | ||||||
|   segments { |  | ||||||
|     uploaded |  | ||||||
|     valid |  | ||||||
|     segmentIndex |  | ||||||
|     endFrameIndex |  | ||||||
|     framesPerSecond |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment SegmentEndFrames on SegmentEndFramesGQL { |  | ||||||
|   id |  | ||||||
|   segmentEndFrames |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment SegmentStartTimes on SegmentStartTimesGQL { |  | ||||||
|   id |  | ||||||
|   segmentStartTimes |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment PlaylistWithSegmentStartTimes on HLSPlaylistGQL { |  | ||||||
|   videoId |  | ||||||
|   segmentDurations |  | ||||||
|   segmentStartTimes @client |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment VideoDurationData on VideoGQL { |  | ||||||
|   id |  | ||||||
|   framesPerSecond |  | ||||||
|   playlist { |  | ||||||
|     ...PlaylistWithSegmentStartTimes |  | ||||||
|   } |  | ||||||
|   stream { |  | ||||||
|     ...StreamWithEndFrames |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetVideoForClipTimes($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     ...VideoDurationData |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetHeaderInfoByVideoId($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     id |  | ||||||
|     name |  | ||||||
|     startTime |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| query GetBannerInfoByVideoId($videoId: Int!) { |  | ||||||
|   getVideo(videoId: $videoId) { |  | ||||||
|     id |  | ||||||
|     name |  | ||||||
|     stream { |  | ||||||
|       id |  | ||||||
|       lastIntendedSegmentBound |  | ||||||
|     } |  | ||||||
|     owner { |  | ||||||
|       id |  | ||||||
|     } |  | ||||||
|     currentProcessing { |  | ||||||
|       id |  | ||||||
|       status |  | ||||||
|     } |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| mutation FindPrerecordTableLayout($b64Image: String!, $videoId: Int!) { |  | ||||||
|   findPrerecordTableLayout(b64Image: $b64Image, videoId: $videoId) { |  | ||||||
|     ...HomographyInfo |  | ||||||
|   } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| fragment HomographyInfo on HomographyInfoGQL { |  | ||||||
|   id |  | ||||||
|       frameIndex |       frameIndex | ||||||
|       crop { |       crop { | ||||||
|         left |         left | ||||||
| @@ -332,4 +182,58 @@ fragment HomographyInfo on HomographyInfoGQL { | |||||||
|           y |           y | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|  |     } | ||||||
|  |     stream { | ||||||
|  |       streamSegmentType | ||||||
|  |       segments { | ||||||
|  |         segmentIndex | ||||||
|  |         endFrameIndex | ||||||
|  |         framesPerSecond | ||||||
|  |       } | ||||||
|  |       resolution { | ||||||
|  |         width | ||||||
|  |         height | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetAverageTimePerShotForVideo($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     averageTimeBetweenShots | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | query GetElapsedTimeForVideo($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     elapsedTime | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | query GetMedianRunForVideo($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     medianRun | ||||||
|  |   } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | query GetVideoForClipTimes($videoId: Int!) { | ||||||
|  |   getVideo(videoId: $videoId) { | ||||||
|  |     id | ||||||
|  |     framesPerSecond | ||||||
|  |     playlist { | ||||||
|  |       segmentDurations | ||||||
|  |     } | ||||||
|  |     stream { | ||||||
|  |       id | ||||||
|  |       streamSegmentType | ||||||
|  |       segments { | ||||||
|  |         uploaded | ||||||
|  |         valid | ||||||
|  |         segmentIndex | ||||||
|  |         endFrameIndex | ||||||
|  |         framesPerSecond | ||||||
|  |       } | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -101,8 +101,13 @@ query GetUploadStreams( | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | query GetUploadStreamsWithDetails( | ||||||
| fragment UploadStreamWithDetails on VideoGQL { |   $limit: Int! = 5 | ||||||
|  |   $after: String = null | ||||||
|  |   $filters: VideoFilterInput = null | ||||||
|  | ) { | ||||||
|  |   getUserVideos(limit: $limit, after: $after, filters: $filters) { | ||||||
|  |     videos { | ||||||
|       id |       id | ||||||
|       name |       name | ||||||
|       startTime |       startTime | ||||||
| @@ -112,16 +117,6 @@ fragment UploadStreamWithDetails on VideoGQL { | |||||||
|         uploadCompletionCursor |         uploadCompletionCursor | ||||||
|         uploadsCompleted |         uploadsCompleted | ||||||
|       } |       } | ||||||
| } |  | ||||||
|  |  | ||||||
| query GetUploadStreamsWithDetails( |  | ||||||
|   $limit: Int! = 5 |  | ||||||
|   $after: String = null |  | ||||||
|   $filters: VideoFilterInput = null |  | ||||||
| ) { |  | ||||||
|   getUserVideos(limit: $limit, after: $after, filters: $filters) { |  | ||||||
|     videos { |  | ||||||
|       ...UploadStreamWithDetails |  | ||||||
|     } |     } | ||||||
|     pageInfo { |     pageInfo { | ||||||
|       hasNextPage |       hasNextPage | ||||||
|   | |||||||
							
								
								
									
										585
									
								
								src/schema.gql
									
									
									
									
									
								
							
							
						
						
									
										585
									
								
								src/schema.gql
									
									
									
									
									
								
							| @@ -5,92 +5,38 @@ type Query { | |||||||
|   getBucketSet(keyName: String!): BucketSetGQL |   getBucketSet(keyName: String!): BucketSetGQL | ||||||
|   getDeployedConfig: DeployedConfigGQL! |   getDeployedConfig: DeployedConfigGQL! | ||||||
|   waitFor(duration: Float!): Float! |   waitFor(duration: Float!): Float! | ||||||
|   getFeedVideos( |  | ||||||
|     limit: Int! = 5 |  | ||||||
|     after: String = null |  | ||||||
|     includePrivate: IncludePrivateEnum! = MINE |  | ||||||
|     includeCallersVideos: Boolean = true |  | ||||||
|     filters: VideoFilterInput = null |  | ||||||
|     feedInput: VideoFeedInputGQL = null |  | ||||||
|   ): VideoHistoryGQL! |  | ||||||
|   getVideoMakePercentageIntervals( |   getVideoMakePercentageIntervals( | ||||||
|     videoId: ID! |     videoId: ID! | ||||||
|     intervalDuration: Int! = 300 |     intervalDuration: Int! = 300 | ||||||
|   ): [MakePercentageIntervalGQL!]! |   ): [MakePercentageIntervalGQL!]! | ||||||
|   getLongestRunsLeaderboard( |  | ||||||
|     interval: TimeInterval = null |  | ||||||
|     when: DateTime = null |  | ||||||
|     limit: Int! = 100 |  | ||||||
|     requiredTags: [String!] = null |  | ||||||
|   ): RunLeaderboardGQL! |  | ||||||
|   getMakesLeaderboard( |  | ||||||
|     interval: TimeInterval = null |  | ||||||
|     when: DateTime = null |  | ||||||
|   ): CountLeaderboardGQL! |  | ||||||
|   getMedals(scope: MedalScope!, userId: Int = null): RequestedMedalsGQL! |  | ||||||
|   getRuns( |  | ||||||
|     filterInput: RunFilterInput! |  | ||||||
|     runIds: [Int!] = null |  | ||||||
|     runsOrdering: GetRunsOrdering = null |  | ||||||
|     limit: Int! = 500 |  | ||||||
|     countRespectsLimit: Boolean! = false |  | ||||||
|   ): GetRunsResult! |  | ||||||
|   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! |  | ||||||
|   getTableState( |  | ||||||
|     b64Image: String! |  | ||||||
|     tableSize: Float = 100 |  | ||||||
|     useHomography: HomographyInputGQL = null |  | ||||||
|   ): TableStateGQL! |  | ||||||
|   getOrderedShots( |  | ||||||
|     filterInput: FilterInput! |  | ||||||
|     ids: [Int!] = null |  | ||||||
|     shotsOrdering: GetShotsOrdering = null |  | ||||||
|     limit: Int! = 500 |  | ||||||
|     countRespectsLimit: Boolean! = false |  | ||||||
|   ): GetShotsResult! |  | ||||||
|   getShotsWithMetadata( |   getShotsWithMetadata( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     ids: [Int!] = null |     ids: [Int!] = null | ||||||
|     shotsPagination: GetShotsPagination = null |     shotsPagination: GetShotsPagination = null | ||||||
|     limit: Int! = 500 |     limit: Int! = 500 | ||||||
|     countRespectsLimit: Boolean! = false |  | ||||||
|   ): GetShotsResult! |   ): GetShotsResult! | ||||||
|   getShots( |   getShots( | ||||||
|     filterInput: FilterInput! |     filterInput: FilterInput! | ||||||
|     shotsPagination: GetShotsPagination = null |     shotsPagination: GetShotsPagination = null | ||||||
|     limit: Int! = 500 |     limit: Int! = 500 | ||||||
|     countRespectsLimit: Boolean! = false |  | ||||||
|   ): [ShotGQL!]! |   ): [ShotGQL!]! | ||||||
|   getShotsByIds(ids: [Int!]!): [ShotGQL!]! |   getShotsByIds(ids: [Int!]!): [ShotGQL!]! | ||||||
|  |   getShotAnnotationTypes(errorTypes: Boolean = false): [ShotAnnotationTypeGQL!]! | ||||||
|   getUser(userId: Int!): UserGQL |   getUser(userId: Int!): UserGQL | ||||||
|   doesUsernameExist(candidateUsername: String!): Boolean! |  | ||||||
|   getLoggedInUser: UserGQL |   getLoggedInUser: UserGQL | ||||||
|   getUsernames( |   getUsernames( | ||||||
|     matchString: String = null |     matchString: String = null | ||||||
|     limit: Int = null |     limit: Int = null | ||||||
|     after: String = null |     after: String = null | ||||||
|   ): [String!]! |   ): [String!]! | ||||||
|   getUsersMatching( |   getPlayTime(userId: Int!): UserPlayTimeGQL! | ||||||
|     matchString: String = null |  | ||||||
|     limit: Int = null |  | ||||||
|     after: String = null |  | ||||||
|   ): [UserGQL!]! |  | ||||||
|   getUserRelationshipsMatching( |  | ||||||
|     userId: Int! |  | ||||||
|     matchString: String = null |  | ||||||
|     limit: Int = 100 |  | ||||||
|     after: String = null |  | ||||||
|   ): UserRelationshipsResult! |  | ||||||
|   getAvailableSubscriptionOptions: StripeSubscriptionOptionsGQL! |  | ||||||
|   getUserSubscriptionStatus: UserSubscriptionStatusGQL! |  | ||||||
|   getPlayTime(userId: Int!, filters: VideoFilterInput = null): UserPlayTimeGQL! |  | ||||||
|   getUserVideos( |   getUserVideos( | ||||||
|     userId: Int = null |     userId: Int = null | ||||||
|     limit: Int! = 5 |     limit: Int! = 5 | ||||||
|     after: String = null |     after: String = null | ||||||
|     filters: VideoFilterInput = null |     filters: VideoFilterInput = null | ||||||
|   ): VideoHistoryGQL! |   ): VideoHistoryGQL! | ||||||
|   getUserTags(includeRetiredTags: Boolean = false): [TagGQL!]! |   getUserTags: [TagGQL!]! | ||||||
|   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! |   getVideo(videoId: Int!, debuggingJson: JSON = null): VideoGQL! | ||||||
|   getVideos(videoIds: [Int!]!): [VideoGQL!]! |   getVideos(videoIds: [Int!]!): [VideoGQL!]! | ||||||
| } | } | ||||||
| @@ -179,7 +125,6 @@ enum AlignedIntervalEnum { | |||||||
|   MONTH |   MONTH | ||||||
|   YEAR |   YEAR | ||||||
|   WEEK |   WEEK | ||||||
|   DAY |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input FilterInput @oneOf { | input FilterInput @oneOf { | ||||||
| @@ -195,9 +140,6 @@ input FilterInput @oneOf { | |||||||
|   shotDirection: [ShotDirectionEnum!] |   shotDirection: [ShotDirectionEnum!] | ||||||
|   videoId: [Int!] |   videoId: [Int!] | ||||||
|   userId: [Int!] |   userId: [Int!] | ||||||
|   runId: [Int!] |  | ||||||
|   username: [String!] |  | ||||||
|   fargoRating: FloatRangeFilter |  | ||||||
|   make: [Boolean!] |   make: [Boolean!] | ||||||
|   tags: [VideoTagInput!] |   tags: [VideoTagInput!] | ||||||
|   annotations: [ShotAnnotationInput!] |   annotations: [ShotAnnotationInput!] | ||||||
| @@ -207,7 +149,6 @@ input FilterInput @oneOf { | |||||||
|   isLeftMiss: [Boolean!] |   isLeftMiss: [Boolean!] | ||||||
|   isRightMiss: [Boolean!] |   isRightMiss: [Boolean!] | ||||||
|   isDirect: [Boolean!] |   isDirect: [Boolean!] | ||||||
|   isBreakHeuristic: [Boolean!] |  | ||||||
|   tableSize: FloatRangeFilter |   tableSize: FloatRangeFilter | ||||||
|   bankAngle: FloatRangeFilter |   bankAngle: FloatRangeFilter | ||||||
|   bankDistance: FloatRangeFilter |   bankDistance: FloatRangeFilter | ||||||
| @@ -221,10 +162,7 @@ input FilterInput @oneOf { | |||||||
|   targetPocketAngleDirection: [ShotDirectionEnum!] |   targetPocketAngleDirection: [ShotDirectionEnum!] | ||||||
|   targetPocketAngle: FloatRangeFilter |   targetPocketAngle: FloatRangeFilter | ||||||
|   missAngleInDegrees: FloatRangeFilter |   missAngleInDegrees: FloatRangeFilter | ||||||
|   marginOfErrorInDegrees: FloatRangeFilter |  | ||||||
|   createdAt: DateRangeFilter |   createdAt: DateRangeFilter | ||||||
|   totalDistance: FloatRangeFilter |  | ||||||
|   runLength: FloatRangeFilter |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input FloatRangeFilter { | input FloatRangeFilter { | ||||||
| @@ -298,74 +236,17 @@ type DeployedConfigGQL { | |||||||
|   devMode: Boolean! |   devMode: Boolean! | ||||||
|   environment: String! |   environment: String! | ||||||
|   minimumAllowedAppVersion: String! |   minimumAllowedAppVersion: String! | ||||||
|   subscriptionGatingEnabled: Boolean! |  | ||||||
|   bannerMessages: [BannerGQL!]! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type BannerGQL { | type MakePercentageIntervalGQL { | ||||||
|   id: Int! |  | ||||||
|   message: String! |  | ||||||
|   color: String! |  | ||||||
|   kind: BannerKindEnum! |  | ||||||
|   dismissible: Boolean! |  | ||||||
|   priority: Int! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| enum BannerKindEnum { |  | ||||||
|   INFO |  | ||||||
|   WARNING |  | ||||||
|   ERROR |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoHistoryGQL { |  | ||||||
|   videos: [VideoGQL!]! |  | ||||||
|   pageInfo: PageInfoGQL! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoGQL { |  | ||||||
|   id: Int! |  | ||||||
|   owner: UserGQL |  | ||||||
|   name: String |  | ||||||
|   screenshotUri: String |  | ||||||
|   totalShotsMade: Int! |  | ||||||
|   totalShots: Int! |  | ||||||
|   makePercentage: Float! |   makePercentage: Float! | ||||||
|   medianRun: Float |   elapsedTime: Float! | ||||||
|   averageTimeBetweenShots: Float |  | ||||||
|   averageDifficulty: Float |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
|   shots: [ShotGQL!]! |  | ||||||
|   startTime: DateTime |  | ||||||
|   endTime: DateTime |  | ||||||
|   elapsedTime: Float |  | ||||||
|   framesPerSecond: Float! |  | ||||||
|   tableSize: Float! |  | ||||||
|   private: Boolean! |  | ||||||
|   stream: UploadStreamGQL |  | ||||||
|   playlist: HLSPlaylistGQL |  | ||||||
|   tags: [VideoTag!]! |  | ||||||
|   currentHomography: HomographyInfoGQL |  | ||||||
|   homographyHistory: [HomographyInfoGQL!]! |  | ||||||
|   currentProcessing: VideoProcessingGQL |  | ||||||
|   reactions: [ReactionGQL!]! |  | ||||||
|   comments: [CommentGQL!]! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type UserGQL { | type GetShotsResult { | ||||||
|   id: Int! |   shots: [ShotGQL!]! | ||||||
|   firebaseUid: String |   count: Int | ||||||
|   username: String! |   ids: [Int!]! | ||||||
|   isAdmin: Boolean |  | ||||||
|   fargoRating: Int |  | ||||||
|   activeVideoId: Int |  | ||||||
|   stripeCustomerId: String |  | ||||||
|   profileImageUri: String |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
|   videosPrivateByDefault: Boolean |  | ||||||
|   following: [UserGQL!] |  | ||||||
|   followers: [UserGQL!] |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type ShotGQL { | type ShotGQL { | ||||||
| @@ -384,8 +265,6 @@ type ShotGQL { | |||||||
|   annotations: [ShotAnnotationGQL!]! |   annotations: [ShotAnnotationGQL!]! | ||||||
|   falsePositiveScore: Float |   falsePositiveScore: Float | ||||||
|   video: VideoGQL |   video: VideoGQL | ||||||
|   run: RunGQL |  | ||||||
|   runFeatures: RunFeaturesGQL |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type CueObjectFeaturesGQL { | type CueObjectFeaturesGQL { | ||||||
| @@ -403,7 +282,6 @@ type PocketingIntentionFeaturesGQL { | |||||||
|   difficulty: Float |   difficulty: Float | ||||||
|   targetPocketAngle: Float |   targetPocketAngle: Float | ||||||
|   targetPocketAngleDirection: ShotDirectionEnum |   targetPocketAngleDirection: ShotDirectionEnum | ||||||
|   marginOfErrorInDegrees: Float |  | ||||||
|   backcut: Boolean |   backcut: Boolean | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -437,6 +315,17 @@ type SerializedShotPathsGQL { | |||||||
|   b64EncodedBuffer: String |   b64EncodedBuffer: String | ||||||
| } | } | ||||||
|  |  | ||||||
|  | type UserGQL { | ||||||
|  |   id: Int! | ||||||
|  |   firebaseUid: String! | ||||||
|  |   username: String! | ||||||
|  |   isAdmin: Boolean! | ||||||
|  |   activeVideoId: Int | ||||||
|  |   profileImageUri: String | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|  | } | ||||||
|  |  | ||||||
| type ShotAnnotationGQL { | type ShotAnnotationGQL { | ||||||
|   shotId: Int! |   shotId: Int! | ||||||
|   type: ShotAnnotationTypeGQL! |   type: ShotAnnotationTypeGQL! | ||||||
| @@ -452,19 +341,30 @@ type ShotAnnotationTypeGQL { | |||||||
|   name: String! |   name: String! | ||||||
| } | } | ||||||
|  |  | ||||||
| type RunGQL { | type VideoGQL { | ||||||
|   id: Int! |   id: Int! | ||||||
|   runLength: Int! |   owner: UserGQL | ||||||
|   videoId: Int! |   name: String | ||||||
|   userId: Int! |   screenshotUri: String | ||||||
|  |   totalShotsMade: Int! | ||||||
|  |   totalShots: Int! | ||||||
|  |   makePercentage: Float! | ||||||
|  |   medianRun: Float | ||||||
|  |   averageTimeBetweenShots: Float | ||||||
|  |   createdAt: DateTime | ||||||
|  |   updatedAt: DateTime | ||||||
|   shots: [ShotGQL!]! |   shots: [ShotGQL!]! | ||||||
|   video: VideoGQL! |   startTime: DateTime | ||||||
|   user: UserGQL! |   endTime: DateTime | ||||||
| } |   elapsedTime: Float | ||||||
|  |   framesPerSecond: Float! | ||||||
| type RunFeaturesGQL { |   tableSize: Float! | ||||||
|   runId: Int! |   stream: UploadStreamGQL | ||||||
|   indexInRun: Int! |   playlist: HLSPlaylistGQL | ||||||
|  |   tags: [VideoTag!]! | ||||||
|  |   currentHomography: HomographyInfoGQL | ||||||
|  |   homographyHistory: [HomographyInfoGQL!]! | ||||||
|  |   currentProcessing: VideoProcessingGQL | ||||||
| } | } | ||||||
|  |  | ||||||
| type UploadStreamGQL { | type UploadStreamGQL { | ||||||
| @@ -481,7 +381,6 @@ type UploadStreamGQL { | |||||||
|   createdAt: DateTime! |   createdAt: DateTime! | ||||||
|   updatedAt: DateTime! |   updatedAt: DateTime! | ||||||
|   segments: [UploadSegmentGQL!]! |   segments: [UploadSegmentGQL!]! | ||||||
|   clientUploadStatus: ClientUploadStatusEnum |  | ||||||
|   resolution: VideoResolutionGQL! |   resolution: VideoResolutionGQL! | ||||||
|   streamSegmentType: StreamSegmentTypeEnum! |   streamSegmentType: StreamSegmentTypeEnum! | ||||||
| } | } | ||||||
| @@ -506,11 +405,6 @@ type UploadSegmentGQL { | |||||||
|   linksRequested: Int! |   linksRequested: Int! | ||||||
| } | } | ||||||
|  |  | ||||||
| enum ClientUploadStatusEnum { |  | ||||||
|   UPLOAD_ENABLED |  | ||||||
|   UPLOAD_DISABLED |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type VideoResolutionGQL { | type VideoResolutionGQL { | ||||||
|   width: Int |   width: Int | ||||||
|   height: Int |   height: Int | ||||||
| @@ -537,7 +431,6 @@ type VideoTagClass { | |||||||
| } | } | ||||||
|  |  | ||||||
| type HomographyInfoGQL { | type HomographyInfoGQL { | ||||||
|   id: Int! |  | ||||||
|   frameIndex: Int! |   frameIndex: Int! | ||||||
|   crop: BoundingBoxGQL! |   crop: BoundingBoxGQL! | ||||||
|   pockets: [BoundingBoxGQL!]! |   pockets: [BoundingBoxGQL!]! | ||||||
| @@ -567,13 +460,9 @@ type IntPoint2D { | |||||||
| } | } | ||||||
|  |  | ||||||
| type VideoProcessingGQL { | type VideoProcessingGQL { | ||||||
|   id: Int! |  | ||||||
|   errors: [VideoProcessingErrorGQL!]! |   errors: [VideoProcessingErrorGQL!]! | ||||||
|   status: ProcessingStatusEnum! |   status: ProcessingStatusEnum! | ||||||
|   statuses: [VideoProcessingStatusGQL!]! |   statuses: [VideoProcessingStatusGQL!]! | ||||||
|   framesProcessed: Int |  | ||||||
|   currentSegment: Int |  | ||||||
|   progressPercentage: Float |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type VideoProcessingErrorGQL { | type VideoProcessingErrorGQL { | ||||||
| @@ -601,213 +490,6 @@ type VideoProcessingStatusGQL { | |||||||
|   updatedAt: DateTime |   updatedAt: DateTime | ||||||
| } | } | ||||||
|  |  | ||||||
| type ReactionGQL { |  | ||||||
|   videoId: Int! |  | ||||||
|   user: UserGQL! |  | ||||||
|   reaction: ReactionEnum! |  | ||||||
|   createdAt: DateTime |  | ||||||
|   updatedAt: DateTime |  | ||||||
| } |  | ||||||
|  |  | ||||||
| enum ReactionEnum { |  | ||||||
|   LIKE |  | ||||||
|   HEART |  | ||||||
|   BULLSEYE |  | ||||||
|   HUNDRED |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type CommentGQL { |  | ||||||
|   id: Int! |  | ||||||
|   user: UserGQL! |  | ||||||
|   message: String! |  | ||||||
|   replies: [CommentGQL!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type PageInfoGQL { |  | ||||||
|   hasNextPage: Boolean! |  | ||||||
|   endCursor: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| enum IncludePrivateEnum { |  | ||||||
|   ALL |  | ||||||
|   MINE |  | ||||||
|   NONE |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input VideoFilterInput { |  | ||||||
|   isStreamCompleted: Boolean = null |  | ||||||
|   requireCursorCompletion: Boolean! = true |  | ||||||
|   createdAt: DateRangeFilter = null |  | ||||||
|   excludeVideosWithNoShots: Boolean = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input VideoFeedInputGQL @oneOf { |  | ||||||
|   followedByUserId: Int |  | ||||||
|   userId: Int |  | ||||||
|   allUsers: Boolean |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type MakePercentageIntervalGQL { |  | ||||||
|   makePercentage: Float! |  | ||||||
|   elapsedTime: Float! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type RunLeaderboardGQL { |  | ||||||
|   entries: [RunGQL!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type CountLeaderboardGQL { |  | ||||||
|   entries: [UserShotCountEntry!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type UserShotCountEntry { |  | ||||||
|   user: UserGQL! |  | ||||||
|   value: Int! |  | ||||||
|   total: Int! |  | ||||||
|   proportionMade: Float! |  | ||||||
|   videos: Int! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type RequestedMedalsGQL { |  | ||||||
|   distanceOver66: MedalGQL |  | ||||||
|   distanceOver78: MedalGQL |  | ||||||
|   distanceOver90: MedalGQL |  | ||||||
|   runLength3: MedalGQL |  | ||||||
|   runLength5: MedalGQL |  | ||||||
|   runLength8: MedalGQL |  | ||||||
|   runLength10: MedalGQL |  | ||||||
|   runLength15: MedalGQL |  | ||||||
|   runLength20: MedalGQL |  | ||||||
|   runLength25: MedalGQL |  | ||||||
|   runLength30: MedalGQL |  | ||||||
|   runLength40: MedalGQL |  | ||||||
|   runLength50: MedalGQL |  | ||||||
|   totalMakes25: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes50: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes75: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes200: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes300: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes400: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes750: MedalGQL @deprecated(reason: "no longer supported") |  | ||||||
|   totalMakes100: MedalGQL |  | ||||||
|   totalMakes500: MedalGQL |  | ||||||
|   totalMakes1000: MedalGQL |  | ||||||
|   totalMakes5000: MedalGQL |  | ||||||
|   totalMakes10000: MedalGQL |  | ||||||
|   dailyMakes50: MedalGQL |  | ||||||
|   dailyMakes100: MedalGQL |  | ||||||
|   dailyMakes150: MedalGQL |  | ||||||
|   dailyMakes200: MedalGQL |  | ||||||
|   dailyMakes250: MedalGQL |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type MedalGQL { |  | ||||||
|   count: Int! |  | ||||||
|   nickname: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input MedalScope @oneOf { |  | ||||||
|   videoId: Int |  | ||||||
|   interval: TimeInterval |  | ||||||
|     @deprecated(reason: "NO LONGER SUPPORTED, USE DATETIME_RANGE") |  | ||||||
|   datetimeRange: DatetimeRangeAggregationInput |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type GetRunsResult { |  | ||||||
|   runs: [RunGQL!]! |  | ||||||
|   count: Int |  | ||||||
|   runIds: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input RunFilterInput { |  | ||||||
|   videoId: [Int!] |  | ||||||
|   userId: [Int!] |  | ||||||
|   username: [String!] |  | ||||||
|   andFilters: [RunFilterInput!] |  | ||||||
|   orFilters: [RunFilterInput!] |  | ||||||
|   notFilter: RunFilterInput |  | ||||||
|   tableSize: FloatRangeFilter |  | ||||||
|   createdAt: DateRangeFilter |  | ||||||
|   runLength: FloatRangeFilter |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input GetRunsOrdering { |  | ||||||
|   orderings: [RunsOrderingComponent!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input RunsOrderingComponent @oneOf { |  | ||||||
|   runLength: IntOrdering |  | ||||||
|   videoId: IntOrdering |  | ||||||
|   videoCreation: DatetimeOrdering |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input IntOrdering { |  | ||||||
|   descending: Boolean! = true |  | ||||||
|   startingAt: Int = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input DatetimeOrdering { |  | ||||||
|   descending: Boolean! = true |  | ||||||
|   startingAt: DateTime = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type TableStateGQL { |  | ||||||
|   identifierToPosition: [[Float!]!]! |  | ||||||
|   homography: HomographyInfoGQL |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input HomographyInputGQL { |  | ||||||
|   crop: BoundingBoxInputGQL! |  | ||||||
|   pockets: [BoundingBoxInputGQL!]! |  | ||||||
|   sourcePoints: PocketPointsInputGQL! |  | ||||||
|   destPoints: PocketPointsInputGQL! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input BoundingBoxInputGQL { |  | ||||||
|   left: Float! |  | ||||||
|   top: Float! |  | ||||||
|   width: Float! |  | ||||||
|   height: Float! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input PocketPointsInputGQL { |  | ||||||
|   topLeft: IntPoint2DInput! |  | ||||||
|   topSide: IntPoint2DInput! |  | ||||||
|   topRight: IntPoint2DInput! |  | ||||||
|   bottomLeft: IntPoint2DInput! |  | ||||||
|   bottomSide: IntPoint2DInput! |  | ||||||
|   bottomRight: IntPoint2DInput! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input IntPoint2DInput { |  | ||||||
|   x: Int! |  | ||||||
|   y: Int! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type GetShotsResult { |  | ||||||
|   shots: [ShotGQL!]! |  | ||||||
|   count: Int |  | ||||||
|   ids: [Int!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input GetShotsOrdering { |  | ||||||
|   orderings: [ShotsOrderingComponent!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input ShotsOrderingComponent @oneOf { |  | ||||||
|   videoCreation: DatetimeOrdering |  | ||||||
|   marginOfError: FloatOrdering |  | ||||||
|   difficulty: FloatOrdering |  | ||||||
|   videoId: IntOrdering |  | ||||||
|   startFrame: IntOrdering |  | ||||||
|   runLength: IntOrdering |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input FloatOrdering { |  | ||||||
|   descending: Boolean! = true |  | ||||||
|   startingAt: Float = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input GetShotsPagination { | input GetShotsPagination { | ||||||
|   createdAfter: CreatedAfter! |   createdAfter: CreatedAfter! | ||||||
|   startFrameAfter: Int! |   startFrameAfter: Int! | ||||||
| @@ -818,74 +500,29 @@ input CreatedAfter @oneOf { | |||||||
|   createdAt: DateTime |   createdAt: DateTime | ||||||
| } | } | ||||||
|  |  | ||||||
| type UserRelationshipsResult { |  | ||||||
|   inquiringUser: UserGQL! |  | ||||||
|   relationships: [UserRelationship!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type UserRelationship { |  | ||||||
|   toUser: UserGQL! |  | ||||||
|   toUserFollows: Boolean! |  | ||||||
|   toUserIsFollowedBy: Boolean! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type StripeSubscriptionOptionsGQL { |  | ||||||
|   products: [StripeProductGQL!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type StripeProductGQL { |  | ||||||
|   id: String! |  | ||||||
|   name: String! |  | ||||||
|   description: String |  | ||||||
|   active: Boolean! |  | ||||||
|   prices: [StripePriceGQL!]! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type StripePriceGQL { |  | ||||||
|   id: String! |  | ||||||
|   currency: String! |  | ||||||
|   unitAmount: Int |  | ||||||
|   recurringInterval: String |  | ||||||
|   recurringIntervalCount: Int |  | ||||||
|   type: String! |  | ||||||
|   active: Boolean! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type UserSubscriptionStatusGQL { |  | ||||||
|   hasActiveSubscription: Boolean! |  | ||||||
|   subscriptionStatus: StripeSubscriptionStatusEnum |  | ||||||
|   currentPeriodStart: DateTime |  | ||||||
|   currentPeriodEnd: DateTime |  | ||||||
|   validUntil: DateTime |  | ||||||
|   stripePriceId: String |  | ||||||
|   stripeSubscriptionId: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| enum StripeSubscriptionStatusEnum { |  | ||||||
|   INCOMPLETE |  | ||||||
|   INCOMPLETE_EXPIRED |  | ||||||
|   TRIALING |  | ||||||
|   ACTIVE |  | ||||||
|   PAST_DUE |  | ||||||
|   CANCELED |  | ||||||
|   UNPAID |  | ||||||
|   PAUSED |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type UserPlayTimeGQL { | type UserPlayTimeGQL { | ||||||
|   totalSeconds: Float! |   totalSeconds: Float! | ||||||
| } | } | ||||||
|  |  | ||||||
| type TagGQL { | type VideoHistoryGQL { | ||||||
|   id: Int! |   videos: [VideoGQL!]! | ||||||
|   name: String! |   pageInfo: PageInfoGQL! | ||||||
|   tagClasses: [TagClassGQL!] |  | ||||||
|   retired: Boolean! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| type TagClassGQL { | type PageInfoGQL { | ||||||
|   id: Int! |   hasNextPage: Boolean! | ||||||
|  |   endCursor: String | ||||||
|  | } | ||||||
|  |  | ||||||
|  | input VideoFilterInput { | ||||||
|  |   isStreamCompleted: Boolean = null | ||||||
|  |   requireCursorCompletion: Boolean! = true | ||||||
|  | } | ||||||
|  |  | ||||||
|  | type TagGQL { | ||||||
|   name: String! |   name: String! | ||||||
|  |   id: Int! | ||||||
|  |   group: String | ||||||
| } | } | ||||||
|  |  | ||||||
| """ | """ | ||||||
| @@ -899,47 +536,15 @@ scalar JSON | |||||||
| type Mutation { | type Mutation { | ||||||
|   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! |   createBucketSet(params: CreateBucketSetInput!): BucketSetGQL! | ||||||
|   setLoggerLevel(path: String!, level: String!): Boolean! |   setLoggerLevel(path: String!, level: String!): Boolean! | ||||||
|   reactToVideo(videoId: Int!, reaction: ReactionEnum): Boolean! |  | ||||||
|   commentOnVideo( |  | ||||||
|     videoId: Int! |  | ||||||
|     message: String! |  | ||||||
|     parentCommentId: Int |  | ||||||
|   ): Boolean! |  | ||||||
|   editComment(videoId: Int!, commentId: Int!, newMessage: String!): Boolean! |  | ||||||
|   deleteComment(videoId: Int!, commentId: Int!): Boolean! |  | ||||||
|   blockContent(videoId: Int!): Boolean! |  | ||||||
|   blockUser(userId: Int!): Boolean! |  | ||||||
|   reportContent( |  | ||||||
|     videoId: Int! |  | ||||||
|     reason: ReportReasonEnum! |  | ||||||
|     customReason: String = null |  | ||||||
|   ): Boolean! |  | ||||||
|   addAnnotationToShot( |   addAnnotationToShot( | ||||||
|     shotId: Int! |     shotId: Int! | ||||||
|     annotationName: String! |     annotationName: String! | ||||||
|     notes: String = null |     notes: String = null | ||||||
|   ): AddShotAnnotationReturn! |   ): AddShotAnnotationReturn! | ||||||
|   updateShotAnnotations( |  | ||||||
|     shotId: Int! |  | ||||||
|     annotations: [UpdateAnnotationInputGQL!]! |  | ||||||
|   ): UpdateShotAnnotationReturn! |  | ||||||
|   editShot( |  | ||||||
|     shotId: Int! |  | ||||||
|     fieldsToEdit: EditableShotFieldInputGQL! |  | ||||||
|   ): EditShotReturn! |  | ||||||
|   getProfileImageUploadLink( |   getProfileImageUploadLink( | ||||||
|     fileExt: String = ".png" |     fileExt: String = ".png" | ||||||
|   ): GetProfileUploadLinkReturn! |   ): GetProfileUploadLinkReturn! | ||||||
|   editProfileImageUri(profileImageUri: String!): UserGQL! |   editProfileImageUri(profileImageUri: String!): UserGQL! | ||||||
|   editUser(input: EditUserInputGQL!): UserGQL! |  | ||||||
|   followUser(followedUserId: Int!): UserGQL! |  | ||||||
|   unfollowUser(followedUserId: Int!): UserGQL! |  | ||||||
|   retireTags(tagIds: [Int!]!): Boolean! |  | ||||||
|   ensureStripeCustomerExists: UserGQL! |  | ||||||
|   deleteUser: Boolean! |  | ||||||
|   createSubscription(priceId: String!): CreateSubscriptionResultGQL! |  | ||||||
|   cancelSubscription: UserSubscriptionStatusGQL! |  | ||||||
|   findPrerecordTableLayout(b64Image: String!, videoId: Int!): HomographyInfoGQL |  | ||||||
|   createUploadStream( |   createUploadStream( | ||||||
|     videoMetadata: VideoMetadataInput! |     videoMetadata: VideoMetadataInput! | ||||||
|   ): CreateUploadStreamReturn! |   ): CreateUploadStreamReturn! | ||||||
| @@ -952,7 +557,6 @@ type Mutation { | |||||||
|   ): Boolean! |   ): Boolean! | ||||||
|   editUploadStream(videoId: Int!, videoMetadata: VideoMetadataInput!): Boolean! |   editUploadStream(videoId: Int!, videoMetadata: VideoMetadataInput!): Boolean! | ||||||
|   deleteVideo(videoId: Int!): Boolean! |   deleteVideo(videoId: Int!): Boolean! | ||||||
|   deleteTags(videoId: Int!, tagsToDelete: [VideoTagInput!]!): Boolean! |  | ||||||
| } | } | ||||||
|  |  | ||||||
| input CreateBucketSetInput { | input CreateBucketSetInput { | ||||||
| @@ -961,15 +565,6 @@ input CreateBucketSetInput { | |||||||
|   buckets: [BucketInputGQL!]! |   buckets: [BucketInputGQL!]! | ||||||
| } | } | ||||||
|  |  | ||||||
| enum ReportReasonEnum { |  | ||||||
|   SPAM |  | ||||||
|   NUDITY |  | ||||||
|   VIOLENCE |  | ||||||
|   HATE |  | ||||||
|   COPYRIGHT |  | ||||||
|   OTHER |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type AddShotAnnotationReturn { | type AddShotAnnotationReturn { | ||||||
|   value: SuccessfulAddAddShotAnnotationErrors! |   value: SuccessfulAddAddShotAnnotationErrors! | ||||||
| } | } | ||||||
| @@ -999,32 +594,6 @@ type OtherErrorNeedsNote { | |||||||
|   msg: String |   msg: String | ||||||
| } | } | ||||||
|  |  | ||||||
| type UpdateShotAnnotationReturn { |  | ||||||
|   shot: ShotGQL |  | ||||||
|   error: DoesNotOwnShotErr |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input UpdateAnnotationInputGQL { |  | ||||||
|   name: String! |  | ||||||
|   notes: String = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type EditShotReturn { |  | ||||||
|   shot: ShotGQL |  | ||||||
|   error: DoesNotOwnShotErr |  | ||||||
| } |  | ||||||
|  |  | ||||||
| input EditableShotFieldInputGQL { |  | ||||||
|   intendedPocketType: PocketEnum |  | ||||||
|   shotDirection: ShotDirectionEnum |  | ||||||
|   spinType: SpinTypeEnum |  | ||||||
|   targetPocketAngleDirection: ShotDirectionEnum |  | ||||||
|   make: Boolean |  | ||||||
|   backcut: Boolean |  | ||||||
|   excludeFromStats: Boolean |  | ||||||
|   notes: String |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type GetProfileUploadLinkReturn { | type GetProfileUploadLinkReturn { | ||||||
|   value: UploadLinkGetProfileUploadLinkErrors! |   value: UploadLinkGetProfileUploadLinkErrors! | ||||||
| } | } | ||||||
| @@ -1051,17 +620,6 @@ type TooManyProfileImageUploadsErr { | |||||||
|   linksRequested: Int! |   linksRequested: Int! | ||||||
| } | } | ||||||
|  |  | ||||||
| input EditUserInputGQL { |  | ||||||
|   username: String = null |  | ||||||
|   fargoRating: Int = null |  | ||||||
|   videosPrivateByDefault: Boolean = null |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type CreateSubscriptionResultGQL { |  | ||||||
|   checkoutUrl: String! |  | ||||||
|   sessionId: String! |  | ||||||
| } |  | ||||||
|  |  | ||||||
| type CreateUploadStreamReturn { | type CreateUploadStreamReturn { | ||||||
|   videoId: Int! |   videoId: Int! | ||||||
| } | } | ||||||
| @@ -1071,22 +629,33 @@ input VideoMetadataInput { | |||||||
|   startTime: DateTime = null |   startTime: DateTime = null | ||||||
|   endTime: DateTime = null |   endTime: DateTime = null | ||||||
|   gameType: String = null |   gameType: String = null | ||||||
|     @deprecated(reason: "`game_type` is deprecated. Use `tags` instead.") |  | ||||||
|  |  | ||||||
|   """ |  | ||||||
|   A list of tags associated with the video. Replace `game_type` |  | ||||||
|   """ |  | ||||||
|   tags: [VideoTagInput!] = null |  | ||||||
|   tableSize: Float = null |   tableSize: Float = null | ||||||
|  |   uploadStreamMetadataInput: UploadStreamMetadataInput = null | ||||||
|   lastIntendedSegmentBound: Int = null |   lastIntendedSegmentBound: Int = null | ||||||
|   streamSegmentType: StreamSegmentTypeEnum = null |   streamSegmentType: StreamSegmentTypeEnum = null | ||||||
|   private: Boolean = null |  | ||||||
|   endStream: Boolean! = false |   endStream: Boolean! = false | ||||||
|   clientUploadStatus: ClientUploadStatusEnum = null |  | ||||||
|   resolution: VideoResolution = null |   resolution: VideoResolution = null | ||||||
|   framesPerSecond: Float = null |   framesPerSecond: Float = null | ||||||
| } | } | ||||||
|  |  | ||||||
|  | input UploadStreamMetadataInput { | ||||||
|  |   deviceType: DeviceTypeEnum = null | ||||||
|  |   osVersion: String = null | ||||||
|  |   appVersion: String = null | ||||||
|  |   browserName: String = null | ||||||
|  |   browserVersion: String = null | ||||||
|  |   locale: String = null | ||||||
|  |   timezone: String = null | ||||||
|  |   networkType: String = null | ||||||
|  |   ipAddress: String = null | ||||||
|  | } | ||||||
|  |  | ||||||
|  | enum DeviceTypeEnum { | ||||||
|  |   IOS | ||||||
|  |   ANDROID | ||||||
|  |   BROWSER | ||||||
|  | } | ||||||
|  |  | ||||||
| input VideoResolution { | input VideoResolution { | ||||||
|   width: Int! |   width: Int! | ||||||
|   height: Int! |   height: Int! | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -10,10 +10,10 @@ | |||||||
|     "@jridgewell/gen-mapping" "^0.3.0" |     "@jridgewell/gen-mapping" "^0.3.0" | ||||||
|     "@jridgewell/trace-mapping" "^0.3.9" |     "@jridgewell/trace-mapping" "^0.3.9" | ||||||
|  |  | ||||||
| "@apollo/client@^3.11.10": | "@apollo/client@^3.9.2": | ||||||
|   version "3.12.3" |   version "3.9.2" | ||||||
|   resolved "https://registry.yarnpkg.com/@apollo/client/-/client-3.12.3.tgz#0d252749baad8328e06883fe118dc7e73e3bbb1f" |   resolved "https://registry.yarnpkg.com/@apollo/client/-/client-3.9.2.tgz#96edf2c212f828bad1ef3d84234fa473c5a27ff8" | ||||||
|   integrity sha512-KZ5zymRdb8bMbGUb1wP2U04ff7qIGgaC1BCdCVC+IPFiXkxEhHBc5fDEQOwAUT+vUo9KbBh3g7QK/JCOswn59w== |   integrity sha512-Zw9WvXjqhpbgkvAvnj52vstOWwM0iedKWtn1hSq1cODQyoe1CF2uFwMYFI7l56BrAY9CzLi6MQA0AhxpgJgvxw== | ||||||
|   dependencies: |   dependencies: | ||||||
|     "@graphql-typed-document-node/core" "^3.1.1" |     "@graphql-typed-document-node/core" "^3.1.1" | ||||||
|     "@wry/caches" "^1.0.0" |     "@wry/caches" "^1.0.0" | ||||||
| @@ -23,7 +23,7 @@ | |||||||
|     hoist-non-react-statics "^3.3.2" |     hoist-non-react-statics "^3.3.2" | ||||||
|     optimism "^0.18.0" |     optimism "^0.18.0" | ||||||
|     prop-types "^15.7.2" |     prop-types "^15.7.2" | ||||||
|     rehackt "^0.1.0" |     rehackt "0.0.3" | ||||||
|     response-iterator "^0.2.6" |     response-iterator "^0.2.6" | ||||||
|     symbol-observable "^4.0.0" |     symbol-observable "^4.0.0" | ||||||
|     ts-invariant "^0.10.3" |     ts-invariant "^0.10.3" | ||||||
| @@ -2633,10 +2633,10 @@ regenerator-runtime@^0.14.0: | |||||||
|   resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz#356ade10263f685dda125100cd862c1db895327f" |   resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.14.1.tgz#356ade10263f685dda125100cd862c1db895327f" | ||||||
|   integrity sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw== |   integrity sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw== | ||||||
|  |  | ||||||
| rehackt@^0.1.0: | rehackt@0.0.3: | ||||||
|   version "0.1.0" |   version "0.0.3" | ||||||
|   resolved "https://registry.yarnpkg.com/rehackt/-/rehackt-0.1.0.tgz#a7c5e289c87345f70da8728a7eb878e5d03c696b" |   resolved "https://registry.yarnpkg.com/rehackt/-/rehackt-0.0.3.tgz#1ea454620d4641db8342e2db44595cf0e7ac6aa0" | ||||||
|   integrity sha512-7kRDOuLHB87D/JESKxQoRwv4DzbIdwkAGQ7p6QKGdVlY1IZheUnVhlk/4UZlNUVxdAXpyxikE3URsG067ybVzw== |   integrity sha512-aBRHudKhOWwsTvCbSoinzq+Lej/7R8e8UoPvLZo5HirZIIBLGAgdG7SL9QpdcBoQ7+3QYPi3lRLknAzXBlhZ7g== | ||||||
|  |  | ||||||
| relay-runtime@12.0.0: | relay-runtime@12.0.0: | ||||||
|   version "12.0.0" |   version "12.0.0" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user