-
Notifications
You must be signed in to change notification settings - Fork 0
/
schema.graphql
13781 lines (13049 loc) · 484 KB
/
schema.graphql
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
# This file was generated based on ".graphqlconfig". Do not edit manually.
schema {
query: Query
mutation: Mutation
}
"Represents an object which can take actions on GitHub. Typically a User or Bot."
interface Actor {
"A URL pointing to the actor's public avatar."
avatarUrl(
#The size of the resulting square image.
size: Int
): URI!
"The username of the actor."
login: String!
"The HTTP path for this actor."
resourcePath: URI!
"The HTTP URL for this actor."
url: URI!
}
"An object that can have users assigned to it."
interface Assignable {
"A list of Users assigned to this object."
assignees(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int
): UserConnection!
}
"An entry in the audit log."
interface AuditEntry {
"The action name"
action: String!
"The user who initiated the action"
actor: AuditEntryActor
"The IP address of the actor"
actorIp: String
"A readable representation of the actor's location"
actorLocation: ActorLocation
"The username of the user who initiated the action"
actorLogin: String
"The HTTP path for the actor."
actorResourcePath: URI
"The HTTP URL for the actor."
actorUrl: URI
"The time the action was initiated"
createdAt: PreciseDateTime!
"The user affected by the action"
user: User
"For actions involving two users, the actor is the initiator and the user is the affected user."
userLogin: String
"The HTTP path for the user."
userResourcePath: URI
"The HTTP URL for the user."
userUrl: URI
}
"An object that can be closed"
interface Closable {
"`true` if the object is closed (definition of closed may depend on type)"
closed: Boolean!
"Identifies the date and time when the object was closed."
closedAt: DateTime
}
"Represents a comment."
interface Comment {
"The actor who authored the comment."
author: Actor
"Author's association with the subject of the comment."
authorAssociation: CommentAuthorAssociation!
"The body as Markdown."
body: String!
"The body rendered to HTML."
bodyHTML: HTML!
"The body rendered to text."
bodyText: String!
"Identifies the date and time when the object was created."
createdAt: DateTime!
"Check if this comment was created via an email reply."
createdViaEmail: Boolean!
"The actor who edited the comment."
editor: Actor
id: ID!
"Check if this comment was edited and includes an edit with the creation data"
includesCreatedEdit: Boolean!
"The moment the editor made the last edit"
lastEditedAt: DateTime
"Identifies when the comment was published at."
publishedAt: DateTime
"Identifies the date and time when the object was last updated."
updatedAt: DateTime!
"A list of edits to this content."
userContentEdits(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int
): UserContentEditConnection
"Did the viewer author this comment."
viewerDidAuthor: Boolean!
}
"Represents a contribution a user made on GitHub, such as opening an issue."
interface Contribution {
"""
Whether this contribution is associated with a record you do not have access to. For
example, your own 'first issue' contribution may have been made on a repository you can no
longer access.
"""
isRestricted: Boolean!
"When this contribution was made."
occurredAt: DateTime!
"The HTTP path for this contribution."
resourcePath: URI!
"The HTTP URL for this contribution."
url: URI!
"""
The user who made this contribution.
"""
user: User!
}
"Entities that can be deleted."
interface Deletable {
"Check if the current viewer can delete this object."
viewerCanDelete: Boolean!
}
"Metadata for an audit entry containing enterprise account information."
interface EnterpriseAuditEntryData {
"The HTTP path for this enterprise."
enterpriseResourcePath: URI
"The slug of the enterprise."
enterpriseSlug: String
"The HTTP URL for this enterprise."
enterpriseUrl: URI
}
"Represents a Git object."
interface GitObject {
"An abbreviated version of the Git object ID"
abbreviatedOid: String!
"The HTTP path for this Git object"
commitResourcePath: URI!
"The HTTP URL for this Git object"
commitUrl: URI!
id: ID!
"The Git object ID"
oid: GitObjectID!
"The Repository the Git object belongs to"
repository: Repository!
}
"Information about a signature (GPG or S/MIME) on a Commit or Tag."
interface GitSignature {
"Email used to sign this object."
email: String!
"True if the signature is valid and verified by GitHub."
isValid: Boolean!
"Payload for GPG signing object. Raw ODB object without the signature header."
payload: String!
"ASCII-armored signature header from object."
signature: String!
"GitHub user corresponding to the email signing this commit."
signer: User
"The state of this signature. `VALID` if signature is valid and verified by GitHub, otherwise represents reason why signature is considered invalid."
state: GitSignatureState!
"True if the signature was made with GitHub's signing key."
wasSignedByGitHub: Boolean!
}
"An object that can have labels assigned to it."
interface Labelable {
"A list of labels associated with the object."
labels(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int
): LabelConnection
}
"An object that can be locked."
interface Lockable {
"Reason that the conversation was locked."
activeLockReason: LockReason
"`true` if the object is locked"
locked: Boolean!
}
"Entities that have members who can set status messages."
interface MemberStatusable {
"Get the status messages members of this entity have set that are either public or visible only to the organization."
memberStatuses(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Ordering options for user statuses returned from the connection.
orderBy: UserStatusOrder
): UserStatusConnection!
}
"An object with an ID."
interface Node {
"ID of the object."
id: ID!
}
"Metadata for an audit entry with action oauth_application.*"
interface OauthApplicationAuditEntryData {
"The name of the OAuth Application."
oauthApplicationName: String
"The HTTP path for the OAuth Application"
oauthApplicationResourcePath: URI
"The HTTP URL for the OAuth Application"
oauthApplicationUrl: URI
}
"Metadata for an audit entry with action org.*"
interface OrganizationAuditEntryData {
"The Organization associated with the Audit Entry."
organization: Organization
"The name of the Organization."
organizationName: String
"The HTTP path for the organization"
organizationResourcePath: URI
"The HTTP URL for the organization"
organizationUrl: URI
}
"Represents any entity on GitHub that has a profile page."
interface ProfileOwner {
"Determine if this repository owner has any items that can be pinned to their profile."
anyPinnableItems(
#Filter to only a particular kind of pinnable item.
type: PinnableItemType
): Boolean!
"The public profile email."
email: String
id: ID!
"Showcases a selection of repositories and gists that the profile owner has either curated or that have been selected automatically based on popularity."
itemShowcase: ProfileItemShowcase!
"The public profile location."
location: String
"The username used to login."
login: String!
"The public profile name."
name: String
"A list of repositories and gists this profile owner can pin to their profile."
pinnableItems(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Filter the types of pinnable items that are returned.
types: [PinnableItemType!]
): PinnableItemConnection!
"A list of repositories and gists this profile owner has pinned to their profile"
pinnedItems(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Filter the types of pinned items that are returned.
types: [PinnableItemType!]
): PinnableItemConnection!
"Returns how many more items this profile owner can pin to their profile."
pinnedItemsRemaining: Int!
"Can the viewer pin repositories and gists to the profile?"
viewerCanChangePinnedItems: Boolean!
"The public profile website URL."
websiteUrl: URI
}
"Represents an owner of a Project."
interface ProjectOwner {
id: ID!
"Find project by number."
project(
#The project number to find.
number: Int!
): Project
"A list of projects under the owner."
projects(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Ordering options for projects returned from the connection
orderBy: ProjectOrder,
#Query to search projects by, currently only searching by name.
search: String,
#A list of states to filter the projects by.
states: [ProjectState!]
): ProjectConnection!
"The HTTP path listing owners projects"
projectsResourcePath: URI!
"The HTTP URL listing owners projects"
projectsUrl: URI!
"Can the current viewer create new projects on this owner."
viewerCanCreateProjects: Boolean!
}
"Represents a subject that can be reacted on."
interface Reactable {
"Identifies the primary key from the database."
databaseId: Int
id: ID!
"A list of reactions grouped by content left on the subject."
reactionGroups: [ReactionGroup!]
"A list of Reactions left on the Issue."
reactions(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Allows filtering Reactions by emoji.
content: ReactionContent,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Allows specifying the order in which reactions are returned.
orderBy: ReactionOrder
): ReactionConnection!
"Can user react to this subject"
viewerCanReact: Boolean!
}
"Represents an owner of a registry package."
interface RegistryPackageOwner {
id: ID!
"A list of registry packages under the owner."
registryPackages(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Find registry package by name.
name: String,
#Find registry packages by their names.
names: [String],
#Filter registry package by type.
packageType: RegistryPackageType,
#Filter registry package by whether it is publicly visible
publicOnly: Boolean,
#Filter registry package by type (string).
registryPackageType: String,
#Find registry packages in a repository.
repositoryId: ID
): RegistryPackageConnection!
}
"Represents an interface to search packages on an object."
interface RegistryPackageSearch {
id: ID!
"A list of registry packages for a particular search query."
registryPackagesForQuery(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Filter registry package by type.
packageType: RegistryPackageType,
#Find registry package by search query.
query: String
): RegistryPackageConnection!
}
"Metadata for an audit entry with action repo.*"
interface RepositoryAuditEntryData {
"The repository associated with the action"
repository: Repository
"The name of the repository"
repositoryName: String
"The HTTP path for the repository"
repositoryResourcePath: URI
"The HTTP URL for the repository"
repositoryUrl: URI
}
"A subset of repository info."
interface RepositoryInfo {
"Identifies the date and time when the object was created."
createdAt: DateTime!
"The description of the repository."
description: String
"The description of the repository rendered to HTML."
descriptionHTML: HTML!
"Returns how many forks there are of this repository in the whole network."
forkCount: Int!
"Indicates if the repository has issues feature enabled."
hasIssuesEnabled: Boolean!
"Indicates if the repository has wiki feature enabled."
hasWikiEnabled: Boolean!
"The repository's URL."
homepageUrl: URI
"Indicates if the repository is unmaintained."
isArchived: Boolean!
"Identifies if the repository is a fork."
isFork: Boolean!
"Indicates if the repository has been locked or not."
isLocked: Boolean!
"Identifies if the repository is a mirror."
isMirror: Boolean!
"Identifies if the repository is private."
isPrivate: Boolean!
"Identifies if the repository is a template that can be used to generate new repositories."
isTemplate: Boolean!
"The license associated with the repository"
licenseInfo: License
"The reason the repository has been locked."
lockReason: RepositoryLockReason
"The repository's original mirror URL."
mirrorUrl: URI
"The name of the repository."
name: String!
"The repository's name with owner."
nameWithOwner: String!
"The image used to represent this repository in Open Graph data."
openGraphImageUrl: URI!
"The User owner of the repository."
owner: RepositoryOwner!
"Identifies when the repository was last pushed to."
pushedAt: DateTime
"The HTTP path for this repository"
resourcePath: URI!
"A description of the repository, rendered to HTML without any links in it."
shortDescriptionHTML(
#How many characters to return.
limit: Int
): HTML!
"Identifies the date and time when the object was last updated."
updatedAt: DateTime!
"The HTTP URL for this repository"
url: URI!
"Whether this repository has a custom image to use with Open Graph as opposed to being represented by the owner's avatar."
usesCustomOpenGraphImage: Boolean!
}
"Represents a object that belongs to a repository."
interface RepositoryNode {
"The repository associated with this node."
repository: Repository!
}
"Represents an owner of a Repository."
interface RepositoryOwner {
"A URL pointing to the owner's public avatar."
avatarUrl(
#The size of the resulting square image.
size: Int
): URI!
id: ID!
"The username used to login."
login: String!
"A list of repositories this user has pinned to their profile"
pinnedRepositories(
#Array of viewer's affiliation options for repositories returned from the connection. For example, OWNER will include only repositories that the current viewer owns.
affiliations: [RepositoryAffiliation],
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#If non-null, filters repositories according to whether they have been locked
isLocked: Boolean,
#Returns the last _n_ elements from the list.
last: Int,
#Ordering options for repositories returned from the connection
orderBy: RepositoryOrder,
#Array of owner's affiliation options for repositories returned from the connection. For example, OWNER will include only repositories that the organization or user being viewed owns.
ownerAffiliations: [RepositoryAffiliation],
#If non-null, filters repositories according to privacy
privacy: RepositoryPrivacy
): RepositoryConnection! @deprecated(reason : "pinnedRepositories will be removed Use ProfileOwner.pinnedItems instead. Removal on 2019-10-01 UTC.")
"A list of repositories that the user owns."
repositories(
#Array of viewer's affiliation options for repositories returned from the connection. For example, OWNER will include only repositories that the current viewer owns.
affiliations: [RepositoryAffiliation],
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#If non-null, filters repositories according to whether they are forks of another repository
isFork: Boolean,
#If non-null, filters repositories according to whether they have been locked
isLocked: Boolean,
#Returns the last _n_ elements from the list.
last: Int,
#Ordering options for repositories returned from the connection
orderBy: RepositoryOrder,
#Array of owner's affiliation options for repositories returned from the connection. For example, OWNER will include only repositories that the organization or user being viewed owns.
ownerAffiliations: [RepositoryAffiliation],
#If non-null, filters repositories according to privacy
privacy: RepositoryPrivacy
): RepositoryConnection!
"Find Repository."
repository(
#Name of Repository to find.
name: String!
): Repository
"The HTTP URL for the owner."
resourcePath: URI!
"The HTTP URL for the owner."
url: URI!
}
"Entities that can be sponsored through GitHub Sponsors"
interface Sponsorable {
"This object's sponsorships as the maintainer."
sponsorshipsAsMaintainer(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Whether or not to include private sponsorships in the result set
includePrivate: Boolean,
#Returns the last _n_ elements from the list.
last: Int,
#Ordering options for sponsorships returned from this connection. If left blank, the sponsorships will be ordered based on relevancy to the viewer.
orderBy: SponsorshipOrder
): SponsorshipConnection!
"This object's sponsorships as the sponsor."
sponsorshipsAsSponsor(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Ordering options for sponsorships returned from this connection. If left blank, the sponsorships will be ordered based on relevancy to the viewer.
orderBy: SponsorshipOrder
): SponsorshipConnection!
}
"Things that can be starred."
interface Starrable {
id: ID!
"A list of users who have starred this starrable."
stargazers(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int,
#Order for connection
orderBy: StarOrder
): StargazerConnection!
"Returns a boolean indicating whether the viewing user has starred this starrable."
viewerHasStarred: Boolean!
}
"Entities that can be subscribed to for web and email notifications."
interface Subscribable {
id: ID!
"Check if the viewer is able to change their subscription status for the repository."
viewerCanSubscribe: Boolean!
"Identifies if the viewer is watching, not watching, or ignoring the subscribable entity."
viewerSubscription: SubscriptionState
}
"Metadata for an audit entry with action team.*"
interface TeamAuditEntryData {
"The team associated with the action"
team: Team
"The name of the team"
teamName: String
"The HTTP path for this team"
teamResourcePath: URI
"The HTTP URL for this team"
teamUrl: URI
}
"Metadata for an audit entry with a topic."
interface TopicAuditEntryData {
"The name of the topic added to the repository"
topic: Topic
"The name of the topic added to the repository"
topicName: String
}
"Represents a type that can be retrieved by a URL."
interface UniformResourceLocatable {
"The HTML path to this resource."
resourcePath: URI!
"The URL to this resource."
url: URI!
}
"Entities that can be updated."
interface Updatable {
"Check if the current viewer can update this object."
viewerCanUpdate: Boolean!
}
"Comments that can be updated."
interface UpdatableComment {
"Reasons why the current viewer can not update this comment."
viewerCannotUpdateReasons: [CommentCannotUpdateReason!]!
}
"Types that can be assigned to issues."
union Assignee = Bot | Mannequin | Organization | User
"Types that can initiate an audit log event."
union AuditEntryActor = Bot | Organization | User
"The object which triggered a `ClosedEvent`."
union Closer = Commit | PullRequest
"Types that can be inside Collection Items."
union CollectionItemContent = Organization | Repository | User
"Represents either a issue the viewer can access or a restricted contribution."
union CreatedIssueOrRestrictedContribution = CreatedIssueContribution | RestrictedContribution
"Represents either a pull request the viewer can access or a restricted contribution."
union CreatedPullRequestOrRestrictedContribution = CreatedPullRequestContribution | RestrictedContribution
"Represents either a repository the viewer can access or a restricted contribution."
union CreatedRepositoryOrRestrictedContribution = CreatedRepositoryContribution | RestrictedContribution
"Used for return value of Repository.issueOrPullRequest."
union IssueOrPullRequest = Issue | PullRequest
"An item in an issue timeline"
union IssueTimelineItem = AssignedEvent | ClosedEvent | Commit | CrossReferencedEvent | DemilestonedEvent | IssueComment | LabeledEvent | LockedEvent | MilestonedEvent | ReferencedEvent | RenamedTitleEvent | ReopenedEvent | SubscribedEvent | TransferredEvent | UnassignedEvent | UnlabeledEvent | UnlockedEvent | UnsubscribedEvent | UserBlockedEvent
"An item in an issue timeline"
union IssueTimelineItems = AddedToProjectEvent | AssignedEvent | ClosedEvent | CommentDeletedEvent | ConvertedNoteToIssueEvent | CrossReferencedEvent | DemilestonedEvent | IssueComment | LabeledEvent | LockedEvent | MarkedAsDuplicateEvent | MentionedEvent | MilestonedEvent | MovedColumnsInProjectEvent | PinnedEvent | ReferencedEvent | RemovedFromProjectEvent | RenamedTitleEvent | ReopenedEvent | SubscribedEvent | TransferredEvent | UnassignedEvent | UnlabeledEvent | UnlockedEvent | UnpinnedEvent | UnsubscribedEvent | UserBlockedEvent
"Types that can be inside a Milestone."
union MilestoneItem = Issue | PullRequest
"Types of memberships that can be restored for an Organization member."
union OrgRestoreMemberAuditEntryMembership = OrgRestoreMemberMembershipOrganizationAuditEntryData | OrgRestoreMemberMembershipRepositoryAuditEntryData | OrgRestoreMemberMembershipTeamAuditEntryData
"An audit entry in an organization audit log."
union OrganizationAuditEntry = MembersCanDeleteReposClearAuditEntry | MembersCanDeleteReposDisableAuditEntry | MembersCanDeleteReposEnableAuditEntry | OauthApplicationCreateAuditEntry | OrgAddBillingManagerAuditEntry | OrgAddMemberAuditEntry | OrgBlockUserAuditEntry | OrgConfigDisableCollaboratorsOnlyAuditEntry | OrgConfigEnableCollaboratorsOnlyAuditEntry | OrgDisableOauthAppRestrictionsAuditEntry | OrgDisableSamlAuditEntry | OrgDisableTwoFactorRequirementAuditEntry | OrgEnableOauthAppRestrictionsAuditEntry | OrgEnableSamlAuditEntry | OrgEnableTwoFactorRequirementAuditEntry | OrgInviteMemberAuditEntry | OrgInviteToBusinessAuditEntry | OrgOauthAppAccessApprovedAuditEntry | OrgOauthAppAccessDeniedAuditEntry | OrgOauthAppAccessRequestedAuditEntry | OrgRemoveBillingManagerAuditEntry | OrgRemoveMemberAuditEntry | OrgRemoveOutsideCollaboratorAuditEntry | OrgRestoreMemberAuditEntry | OrgUnblockUserAuditEntry | OrgUpdateDefaultRepositoryPermissionAuditEntry | OrgUpdateMemberAuditEntry | OrgUpdateMemberRepositoryCreationPermissionAuditEntry | OrgUpdateMemberRepositoryInvitationPermissionAuditEntry | PrivateRepositoryForkingDisableAuditEntry | PrivateRepositoryForkingEnableAuditEntry | RepoAccessAuditEntry | RepoAddMemberAuditEntry | RepoAddTopicAuditEntry | RepoArchivedAuditEntry | RepoChangeMergeSettingAuditEntry | RepoConfigDisableAnonymousGitAccessAuditEntry | RepoConfigDisableCollaboratorsOnlyAuditEntry | RepoConfigDisableContributorsOnlyAuditEntry | RepoConfigDisableSockpuppetDisallowedAuditEntry | RepoConfigEnableAnonymousGitAccessAuditEntry | RepoConfigEnableCollaboratorsOnlyAuditEntry | RepoConfigEnableContributorsOnlyAuditEntry | RepoConfigEnableSockpuppetDisallowedAuditEntry | RepoConfigLockAnonymousGitAccessAuditEntry | RepoConfigUnlockAnonymousGitAccessAuditEntry | RepoCreateAuditEntry | RepoDestroyAuditEntry | RepoRemoveMemberAuditEntry | RepoRemoveTopicAuditEntry | RepositoryVisibilityChangeDisableAuditEntry | RepositoryVisibilityChangeEnableAuditEntry | TeamAddMemberAuditEntry | TeamAddRepositoryAuditEntry | TeamChangeParentTeamAuditEntry | TeamRemoveMemberAuditEntry | TeamRemoveRepositoryAuditEntry
"Types that can grant permissions on a repository to a user"
union PermissionGranter = Organization | Repository | Team
"Types that can be pinned to a profile page."
union PinnableItem = Gist | Repository
"Types that can be inside Project Cards."
union ProjectCardItem = Issue | PullRequest
"An item in an pull request timeline"
union PullRequestTimelineItem = AssignedEvent | BaseRefForcePushedEvent | ClosedEvent | Commit | CommitCommentThread | CrossReferencedEvent | DemilestonedEvent | DeployedEvent | DeploymentEnvironmentChangedEvent | HeadRefDeletedEvent | HeadRefForcePushedEvent | HeadRefRestoredEvent | IssueComment | LabeledEvent | LockedEvent | MergedEvent | MilestonedEvent | PullRequestReview | PullRequestReviewComment | PullRequestReviewThread | ReferencedEvent | RenamedTitleEvent | ReopenedEvent | ReviewDismissedEvent | ReviewRequestRemovedEvent | ReviewRequestedEvent | SubscribedEvent | UnassignedEvent | UnlabeledEvent | UnlockedEvent | UnsubscribedEvent | UserBlockedEvent
"An item in a pull request timeline"
union PullRequestTimelineItems = AddedToProjectEvent | AssignedEvent | BaseRefChangedEvent | BaseRefForcePushedEvent | ClosedEvent | CommentDeletedEvent | ConvertedNoteToIssueEvent | CrossReferencedEvent | DemilestonedEvent | DeployedEvent | DeploymentEnvironmentChangedEvent | HeadRefDeletedEvent | HeadRefForcePushedEvent | HeadRefRestoredEvent | IssueComment | LabeledEvent | LockedEvent | MarkedAsDuplicateEvent | MentionedEvent | MergedEvent | MilestonedEvent | MovedColumnsInProjectEvent | PinnedEvent | PullRequestCommit | PullRequestCommitCommentThread | PullRequestReview | PullRequestReviewThread | PullRequestRevisionMarker | ReadyForReviewEvent | ReferencedEvent | RemovedFromProjectEvent | RenamedTitleEvent | ReopenedEvent | ReviewDismissedEvent | ReviewRequestRemovedEvent | ReviewRequestedEvent | SubscribedEvent | TransferredEvent | UnassignedEvent | UnlabeledEvent | UnlockedEvent | UnpinnedEvent | UnsubscribedEvent | UserBlockedEvent
"Types that can be an actor."
union PushAllowanceActor = Team | User
"Any referencable object"
union ReferencedSubject = Issue | PullRequest
"An object which has a renamable title"
union RenamedTitleSubject = Issue | PullRequest
"Types that can be requested reviewers."
union RequestedReviewer = Mannequin | Team | User
"Types that can be an actor."
union ReviewDismissalAllowanceActor = Team | User
"The results of a search."
union SearchResultItem = App | Issue | MarketplaceListing | Organization | PullRequest | Repository | User
"Autogenerated return type of AcceptTopicSuggestion"
type AcceptTopicSuggestionPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The accepted topic."
topic: Topic
}
"Location information for an actor"
type ActorLocation {
"City"
city: String
"Country name"
country: String
"Country code"
countryCode: String
"Region name"
region: String
"Region or state code"
regionCode: String
}
"Autogenerated return type of AddAssigneesToAssignable"
type AddAssigneesToAssignablePayload {
"The item that was assigned."
assignable: Assignable
"A unique identifier for the client performing the mutation."
clientMutationId: String
}
"Autogenerated return type of AddComment"
type AddCommentPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The edge from the subject's comment connection."
commentEdge: IssueCommentEdge
"The subject"
subject: Node
"The edge from the subject's timeline connection."
timelineEdge: IssueTimelineItemEdge
}
"Autogenerated return type of AddLabelsToLabelable"
type AddLabelsToLabelablePayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The item that was labeled."
labelable: Labelable
}
"Autogenerated return type of AddProjectCard"
type AddProjectCardPayload {
"The edge from the ProjectColumn's card connection."
cardEdge: ProjectCardEdge
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The ProjectColumn"
projectColumn: ProjectColumn
}
"Autogenerated return type of AddProjectColumn"
type AddProjectColumnPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The edge from the project's column connection."
columnEdge: ProjectColumnEdge
"The project"
project: Project
}
"Autogenerated return type of AddPullRequestReviewComment"
type AddPullRequestReviewCommentPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The newly created comment."
comment: PullRequestReviewComment
"The edge from the review's comment connection."
commentEdge: PullRequestReviewCommentEdge
}
"Autogenerated return type of AddPullRequestReview"
type AddPullRequestReviewPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The newly created pull request review."
pullRequestReview: PullRequestReview
"The edge from the pull request's review connection."
reviewEdge: PullRequestReviewEdge
}
"Autogenerated return type of AddReaction"
type AddReactionPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The reaction object."
reaction: Reaction
"The reactable subject."
subject: Reactable
}
"Autogenerated return type of AddStar"
type AddStarPayload {
"A unique identifier for the client performing the mutation."
clientMutationId: String
"The starrable."
starrable: Starrable
}
"Represents a 'added_to_project' event on a given issue or pull request."
type AddedToProjectEvent implements Node {
"Identifies the actor who performed the event."
actor: Actor
"Identifies the date and time when the object was created."
createdAt: DateTime!
"Identifies the primary key from the database."
databaseId: Int
id: ID!
}
"A GitHub App."
type App implements Node {
"Identifies the date and time when the object was created."
createdAt: DateTime!
"Identifies the primary key from the database."
databaseId: Int
"The description of the app."
description: String
id: ID!
"The hex color code, without the leading '#', for the logo background."
logoBackgroundColor: String!
"A URL pointing to the app's logo."
logoUrl(
#The size of the resulting image.
size: Int
): URI!
"The name of the app."
name: String!
"A slug based on the name of the app for use in URLs."
slug: String!
"Identifies the date and time when the object was last updated."
updatedAt: DateTime!
"The URL to the app's homepage."
url: URI!
}
"An edge in a connection."
type AppEdge {
"A cursor for use in pagination."
cursor: String!
"The item at the end of the edge."
node: App
}
"Represents an 'assigned' event on any assignable object."
type AssignedEvent implements Node {
"Identifies the actor who performed the event."
actor: Actor
"Identifies the assignable associated with the event."
assignable: Assignable!
"Identifies the user or mannequin that was assigned."
assignee: Assignee
"Identifies the date and time when the object was created."
createdAt: DateTime!
id: ID!
"Identifies the user who was assigned."
user: User @deprecated(reason : "Assignees can now be mannequins. Use the `assignee` field instead. Removal on 2020-01-01 UTC.")
}
"Represents a 'base_ref_changed' event on a given issue or pull request."
type BaseRefChangedEvent implements Node {
"Identifies the actor who performed the event."
actor: Actor
"Identifies the date and time when the object was created."
createdAt: DateTime!
"Identifies the primary key from the database."
databaseId: Int
id: ID!
}
"Represents a 'base_ref_force_pushed' event on a given pull request."
type BaseRefForcePushedEvent implements Node {
"Identifies the actor who performed the event."
actor: Actor
"Identifies the after commit SHA for the 'base_ref_force_pushed' event."
afterCommit: Commit
"Identifies the before commit SHA for the 'base_ref_force_pushed' event."
beforeCommit: Commit
"Identifies the date and time when the object was created."
createdAt: DateTime!
id: ID!
"PullRequest referenced by event."
pullRequest: PullRequest!
"Identifies the fully qualified ref name for the 'base_ref_force_pushed' event."
ref: Ref
}
"Represents a Git blame."
type Blame {
"The list of ranges from a Git blame."
ranges: [BlameRange!]!
}
"Represents a range of information from a Git blame."
type BlameRange {
"Identifies the recency of the change, from 1 (new) to 10 (old). This is calculated as a 2-quantile and determines the length of distance between the median age of all the changes in the file and the recency of the current range's change."
age: Int!
"Identifies the line author"
commit: Commit!
"The ending line for the range"
endingLine: Int!
"The starting line for the range"
startingLine: Int!
}
"Represents a Git blob."
type Blob implements GitObject & Node {
"An abbreviated version of the Git object ID"
abbreviatedOid: String!
"Byte size of Blob object"
byteSize: Int!
"The HTTP path for this Git object"
commitResourcePath: URI!
"The HTTP URL for this Git object"
commitUrl: URI!
id: ID!
"Indicates whether the Blob is binary or text"
isBinary: Boolean!
"Indicates whether the contents is truncated"
isTruncated: Boolean!
"The Git object ID"
oid: GitObjectID!
"The Repository the Git object belongs to"
repository: Repository!
"UTF8 text data or null if the Blob is binary"
text: String
}
"A special type of user which takes actions on behalf of GitHub Apps."
type Bot implements Actor & Node & UniformResourceLocatable {
"A URL pointing to the GitHub App's public avatar."
avatarUrl(
#The size of the resulting square image.
size: Int
): URI!
"Identifies the date and time when the object was created."
createdAt: DateTime!
"Identifies the primary key from the database."
databaseId: Int
id: ID!
"The username of the actor."
login: String!
"The HTTP path for this bot"
resourcePath: URI!
"Identifies the date and time when the object was last updated."
updatedAt: DateTime!
"The HTTP URL for this bot"
url: URI!
}
"A branch protection rule."
type BranchProtectionRule implements Node {
"A list of conflicts matching branches protection rule and other branch protection rules"
branchProtectionRuleConflicts(
#Returns the elements in the list that come after the specified cursor.
after: String,
#Returns the elements in the list that come before the specified cursor.
before: String,
#Returns the first _n_ elements from the list.
first: Int,
#Returns the last _n_ elements from the list.
last: Int
): BranchProtectionRuleConflictConnection!
"The actor who created this branch protection rule."
creator: Actor