-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathcard.go
1139 lines (863 loc) · 38.2 KB
/
card.go
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
package scryfall
import (
"context"
"fmt"
"net/url"
qs "github.com/google/go-querystring/query"
)
// Lang is an ISO-like language code.
type Lang string
const (
// LangEnglish is the English language code.
LangEnglish Lang = "en"
// LangSpanish is the Spanish language code.
LangSpanish Lang = "es"
// LangFrench is the French language code.
LangFrench Lang = "fr"
// LangGerman is the German language code.
LangGerman Lang = "de"
// LangItalian is the Italian language code.
LangItalian Lang = "it"
// LangPortuguese is the Portuguese language code.
LangPortuguese Lang = "pt"
// LangJapanese is the Japanese language code.
LangJapanese Lang = "ja"
// LangKorean is the Korean language code.
LangKorean Lang = "ko"
// LangRussian is the Russian language code.
LangRussian Lang = "ru"
// LangSimplifiedChinese is the simplified Chinese language code.
LangSimplifiedChinese Lang = "zhs"
// LangTraditionalChinese is the traditional Chinese language code.
LangTraditionalChinese Lang = "zht"
// LangHebrew is the Hebrew language code.
LangHebrew Lang = "he"
// LangLatin is the Latin language code.
LangLatin Lang = "la"
// LangAncientGreek is the ancient Greek language code.
LangAncientGreek Lang = "grc"
// LangArabic is the Arabic language code.
LangArabic Lang = "ar"
// LangSanskrit is the Sanskrit language code.
LangSanskrit Lang = "sa"
// LangPhyrexian is the Phyrexian language code.
LangPhyrexian Lang = "ph"
)
// Layout categorizes the arrangement of card parts, faces, and other bounded
// regions on cards. The layout can be used to programmatically determine which
// other properties on a card you can expect.
type Layout string
const (
// LayoutNormal is a standard Magic card layout with one face.
LayoutNormal Layout = "normal"
// LayoutSplit is a split-faced card layout.
LayoutSplit Layout = "split"
// LayoutFlip is a card layout that inverts vertically with the flip
// keyword.
LayoutFlip Layout = "flip"
// LayoutTransform is a double-sided card layout that transforms.
LayoutTransform Layout = "transform"
// LayoutModalDFC is a double-sided card layout that can be played either-side.
LayoutModalDFC Layout = "modal_dfc"
// LayoutMeld is a card layout with meld parts printed on the back.
LayoutMeld Layout = "meld"
// LayoutLeveler is a level up card layout.
LayoutLeveler Layout = "leveler"
// LayoutClass is class-type enchantment cards layout.
LayoutClass Layout = "class"
// LayoutCase is a case-type enchantment cards layout.
LayoutCase Layout = "case"
// LayoutSaga is saga card layout.
LayoutSaga Layout = "saga"
// LayoutAdventure is a card layout with an Adventure spell part.
LayoutAdventure Layout = "adventure"
// LayoutMutate is mutate card layout.
LayoutMutate Layout = "mutate"
// LayoutPrototype is prototype card layout.
LayoutPrototype Layout = "prototype"
// LayoutBattle is a battle-type card layout.
LayoutBattle Layout = "battle"
// LayoutPlanar is a plane and phenomenon card layout.
LayoutPlanar Layout = "planar"
// LayoutScheme is a scheme card layout.
LayoutScheme Layout = "scheme"
// LayoutVanguard is a vanguard card layout.
LayoutVanguard Layout = "vanguard"
// LayoutToken is a token card layout.
LayoutToken Layout = "token"
// LayoutDoubleFacedToken is a card token layout with another token
// printed on the back.
LayoutDoubleFacedToken Layout = "double_faced_token"
// LayoutEmblem is an emblem card layout.
LayoutEmblem Layout = "emblem"
// LayoutAugment is an augment card layout.
LayoutAugment Layout = "augment"
// LayoutHost is host card layout.
LayoutHost Layout = "host"
// LayoutArtSeries is an Art Series collectable double-faced card layout.
LayoutArtSeries Layout = "art_series"
// LayoutReversible is a card layout with two sides that are unrelated.
LayoutReversible Layout = "reversible_card"
)
// Legality is the legality of a card in a particular format.
type Legality string
const (
// LegalityLegal indicates the card is legal in the format.
LegalityLegal Legality = "legal"
// LegalityNotLegal indicates the card is not legal in the format.
LegalityNotLegal Legality = "not_legal"
// LegalityBanned indicates the card is banned in the format.
LegalityBanned Legality = "banned"
// LegalityRestricted indicates the card is restricted to one copy in
// the format.
LegalityRestricted Legality = "restricted"
)
// Frame tracks the major edition of the card frame of used for the re/print in
// question. The frame has gone though several major revisions in Magic's
// lifetime.
type Frame string
const (
// Frame1993 is the original Magic card frame, starting from Limited
// Edition Alpha.
Frame1993 Frame = "1993"
// Frame1997 is the updated classic frame starting from Mirage block.
Frame1997 Frame = "1997"
// Frame2003 is the “modern” Magic card frame, introduced in Eighth
// Edition and Mirrodin block.
Frame2003 Frame = "2003"
// Frame2015 is the holofoil-stamp Magic card frame, introduced in
// Magic 2015.
Frame2015 Frame = "2015"
// FrameFuture is the frame used on cards from the future.
FrameFuture Frame = "future"
)
// FrameEffect tracks additional frame artwork applied over a particular
// frame. For example, there are both 2003 and 2015-frame cards with the
// Nyx-touched effect.
type FrameEffect string
const (
// FrameEffectLegendary is the legendary crown introduced in Dominaria.
FrameEffectLegendary FrameEffect = "legendary"
// FrameEffectMiracle is the miracle frame effect.
FrameEffectMiracle FrameEffect = "miracle"
// FrameEffectNyxTouched is the Nyx-touched frame effect.
FrameEffectNyxTouched FrameEffect = "nyxtouched"
// FrameEffectDraft is the draft-matters frame effect.
FrameEffectDraft FrameEffect = "draft"
// FrameEffectDevoid is the Devoid frame effect.
FrameEffectDevoid FrameEffect = "devoid"
// FrameEffectTombstone is the Odyssey tombstone mark frame effect.
FrameEffectTombstone FrameEffect = "tombstone"
// FrameEffectColorShifted is the colorshifted frame effect.
FrameEffectColorShifted FrameEffect = "colorshifted"
// FrameEffectInverted is the FNM-style inverted frame effect.
FrameEffectInverted FrameEffect = "inverted"
// FrameEffectSunMoonDFC is the sun and moon transform marks frame
// effect.
FrameEffectSunMoonDFC FrameEffect = "sunmoondfc"
// FrameEffectCompassLandDFC is the compass and land transform marks
// frame effect.
FrameEffectCompassLandDFC FrameEffect = "compasslanddfc"
// FrameEffectOriginPWDFC is the Origins and planeswalker transform
// marks frame effect.
FrameEffectOriginPWDFC FrameEffect = "originpwdfc"
// FrameEffectMoonEldraziDFC is the moon and Eldrazi transform marks
// frame effect.
FrameEffectMoonEldraziDFC FrameEffect = "mooneldrazidfc"
// FrameEffectMoonReverseMoonDFC is the waxing and waning crescent moon
// transform marks frame effect.
FrameEffectMoonReverseMoonDFC FrameEffect = "moonreversemoondfc"
// FrameEffectShowcase is the custom Showcase frame effect.
FrameEffectShowcase FrameEffect = "showcase"
// FrameEffectExtendedArt is the extended art frame effect.
FrameEffectExtendedArt FrameEffect = "extendedart"
// FrameEffectCompanion is the companion frame effect.
FrameEffectCompanion FrameEffect = "companion"
// FrameEffectEtched is the etched foil treatment frame effect.
FrameEffectEtched FrameEffect = "etched"
// FrameEffectSnow is the snowy frame effect.
FrameEffectSnow FrameEffect = "snow"
// FrameEffectLesson is the lesson frame effect.
FrameEffectLesson FrameEffect = "lesson"
// FrameEffectShatteredGlass is the shattered glass frame effect.
FrameEffectShatteredGlass FrameEffect = "shatteredglass"
// FrameEffectConvertDFC is the more than meets the eye marks frame
// effect.
FrameEffectConvertDFC FrameEffect = "convertdfc"
// FrameEffectFanDFC is the fan transforming marks frame effect.
FrameEffectFanDFC FrameEffect = "fandfc"
// FrameEffectUpsideDownDFC is the upside down transforming marks frame
// effect.
FrameEffectUpsideDownDFC FrameEffect = "upsidedowndfc"
// FrameEffectSpree is the spree asterisk frame effect.
FrameEffectSpree FrameEffect = "spree"
)
type Preview struct {
// PreviewedAt is the date this card was previewed.
PreviewedAt Date `json:"previewed_at"`
// SourceURI is a link to the preview for this card.
SourceURI string `json:"source_uri"`
// Source is the name of the source that previewed this card.
Source string `json:"source"`
}
// Component is a field explaining what role a card plays in a relationship.
type Component string
const (
// ComponentToken represents a token related to a card.
ComponentToken Component = "token"
// ComponentMeldPart represents one of the parts of a meld.
ComponentMeldPart Component = "meld_part"
// ComponentMeldResult represents the result of a meld.
ComponentMeldResult Component = "meld_result"
// ComponentComboPiece represents a combo piece related to a card.
ComponentComboPiece Component = "combo_piece"
)
// Finish is a finish a card can come in.
type Finish string
const (
// FinishFoil represents a foild card finish.
FinishFoil Finish = "foil"
// FinishNonFoil represents a nonfoild card finish.
FinishNonFoil Finish = "nonfoil"
// FinishEtched represents a etched card finish.
FinishEtched Finish = "etched"
// FinishGlossy represents a glossy card finish.
FinishGlossy Finish = "glossy"
)
// ImageStatus is a computer-readable indicator for the state of this card's image,
// one of missing, placeholder, lowres, or highres_scan.
type ImageStatus string
const (
// ImageStatusMissing represents that the card has no image, or the image is being processed.
// This value should only be temporary for very new cards.
ImageStatusMissing ImageStatus = "missing"
// ImageStatusPlaceholder represents that Scryfall doesn't have an image of this card,
// but we know it exists and we have uploaded a placeholder in the meantime.
// This value is most common on localized cards.
ImageStatusPlaceholer ImageStatus = "placeholder"
// ImageStatusHighres represents that the card's image is low-quality,
// either because it was just spoiled or we don't have better photography for it yet.
ImageStatusLowres ImageStatus = "lowres"
// ImageStatusHighres represents that the card has a full-resolution scanner image. Crisp and glossy!
ImageStatusHighres ImageStatus = "highres_scan"
)
// Card represents individual Magic: The Gathering cards that players could
// obtain and add to their collection (with a few minor exceptions).
type Card struct {
// ArenaID is this card's Arena ID, if any. A large percentage of cards
// are not available on Arena and do not have this ID.
ArenaID *int `json:"arena_id,omitempty"`
// ID is a unique ID for this card in Scryfall's database.
ID string `json:"id"`
// Lang is the language code for this printing.
Lang Lang `json:"lang"`
// OracleID is a unique ID for this card's oracle identity. This value
// is consistent across reprinted card editions, and unique among
// different cards with the same name (tokens, Unstable variants, etc).
OracleID string `json:"oracle_id"`
// MultiverseIDs is this card's multiverse IDs on Gatherer, if any, as
// an array of integers. Note that Scryfall includes many promo cards,
// tokens, and other esoteric objects that do not have these identifiers.
MultiverseIDs []int `json:"multiverse_ids"`
// MTGOID is this card's Magic Online ID (also known as the Catalog
// ID), if any. A large percentage of cards are not available on Magic
// Online and do not have this ID.
MTGOID *int `json:"mtgo_id,omitempty"`
// MTGOFoilID is this card's foil Magic Online ID (also known as the
// Catalog ID), if any. A large percentage of cards are not available on
// Magic Online and do not have this ID.
MTGOFoilID *int `json:"mtgo_foil_id,omitempty"`
// URI is a link to this card object on Scryfall's API.
URI string `json:"uri"`
// ScryfallURI is a link to this card's permapage on Scryfall's website.
ScryfallURI string `json:"scryfall_uri"`
// TCGPlayerID is this card's ID on TCGplayer's API, also known as the productId.
TCGPlayerID *int `json:"tcgplayer_id,omitempty"`
// TCGPlayerEtchedID is this card's ID on TCGplayer's API, for its etched version if that version is a separate product.
TCGPlayerEtchedID *int `json:"tcgplayer_etched_id,omitempty"`
// CardMarketID is this card's ID on Cardmarket's API, also known as the idProduct.
CardMarketID *int `json:"Integer,omitempty"`
// PrintsSearchURI is a link to where you can begin paginating all
// re/prints for this card on Scryfall's API.
PrintsSearchURI string `json:"prints_search_uri"`
// RulingsURI is a link to this card's rulings on Scryfall's API.
RulingsURI string `json:"rulings_uri"`
// Name is the name of this card. If this card has multiple faces, this
// field will contain both names separated by ␣//␣.
Name string `json:"name"`
// PrintedName is the printed name of this card.
// This will only be set if the card is not in English.
// If this card has multiple faces, this field will not be set.
PrintedName *string `json:"printed_name"`
// Layout is a computer-readable designation for this card's
// layout. See the layout article.
Layout Layout `json:"layout"`
// CMC is the card's converted mana cost. Note that some funny cards
// have fractional mana costs.
CMC float64 `json:"cmc"`
// TypeLine is the type line of this card.
TypeLine string `json:"type_line"`
// PrintedTypeLine is the type line of this card, as writted on the card.
// This will only be set if the card is not in English.
PrintedTypeLine *string `json:"printed_type_line"`
// OracleText is the Oracle text for this card, if any.
OracleText string `json:"oracle_text"`
// PrintedText is the printed text for this card, if any.
// This will only be set if the card is not in English.
PrintedText *string `json:"printed_text"`
// ManaCost is the mana cost for this card. This value will be any
// empty string "" if the cost is absent. Remember that per the game
// rules, a missing mana cost and a mana cost of {0} are different values.
ManaCost string `json:"mana_cost"`
// Power is this card's power, if any. Note that some cards have powers
// that are not numeric, such as *.
Power *string `json:"power"`
// Toughness is this card's toughness, if any. Note that some cards
// have toughnesses that are not numeric, such as *.
Toughness *string `json:"toughness"`
// Loyalty is this loyalty if any. Note that some cards have loyalties
// that are not numeric, such as X.
Loyalty *string `json:"loyalty"`
// Defense is the face's defense, if any.
Defense *string `json:"defense"`
// LifeModifier is this card's life modifier, if it is Vanguard
// card. This value will contain a delta, such as +2.
LifeModifier *string `json:"life_modifier"`
// HandModifier is this card's hand modifier, if it is Vanguard
// card. This value will contain a delta, such as -1.
HandModifier *string `json:"hand_modifier"`
// Colors is this card's colors.
Colors []Color `json:"colors"`
// ColorIndicator is the colors in this card's color indicator, if
// any. A nil value for this field indicates the card does not have one.
ColorIndicator []Color `json:"color_indicator"`
// ColorIdentity is this card's color identity.
ColorIdentity []Color `json:"color_identity"`
// AllParts is a list of closely related cards, if any.
AllParts []RelatedCard `json:"all_parts"`
// CardFaces is An array of card Face objects, if this card is
// multifaced.
CardFaces []CardFace `json:"card_faces"`
// Legalities is an object describing the legality of this card.
Legalities Legalities `json:"legalities"`
// Reserved is true if this card is on the Reserved List.
Reserved bool `json:"reserved"`
// Foil is true if this printing exists in a foil version.
//
// Deprecated: switch to finishes.
// https://scryfall.com/blog/upcoming-api-changes-for-etched-foils-and-glossy-cards-223
Foil bool `json:"foil"`
// NonFoil is true if this printing exists in a nonfoil version.
//
// Deprecated: switch to finishes.
// https://scryfall.com/blog/upcoming-api-changes-for-etched-foils-and-glossy-cards-223
NonFoil bool `json:"nonfoil"`
// Oversized is true if this card is oversized.
Oversized bool `json:"oversized"`
// Promo is true if this card is a promotional print.
Promo bool `json:"promo"`
// EDHRECRank is this card's overall rank/popularity on EDHREC. Not all
// cards are ranked.
EDHRECRank *int `json:"edhrec_rank"`
// Set is this card's set code.
Set string `json:"set"`
// SetName is this card's full set name.
SetName string `json:"set_name"`
// CollectorNumber is this card's collector number. Note that collector
// numbers can contain non-numeric characters, such as letters or ★.
CollectorNumber string `json:"collector_number"`
// SetURI is a link to this card's set on Scryfall's API.
SetURI string `json:"set_uri"`
// SetSearchURI is a link to where you can begin paginating this card's
// set on the Scryfall API.
SetSearchURI string `json:"set_search_uri"`
// ScryfallSetURI is a link to this card's set on Scryfall's website.
ScryfallSetURI string `json:"scryfall_set_uri"`
// ImageURIs is an object listing available imagery for this card.
ImageURIs *ImageURIs `json:"image_uris"`
// Prices contains daily price information for this card, including
// usd, usd_foil, eur, and tix prices.
Prices Prices `json:"prices"`
// HighresImage is true if this card's imagery is high resolution.
HighresImage bool `json:"highres_image"`
// Reprint is true if this card is a reprint.
Reprint bool `json:"reprint"`
// Digital is true if this is a digital card on Magic Online.
Digital bool `json:"digital"`
// Rarity is this card's rarity. One of common, uncommon, rare, or
// mythic.
Rarity string `json:"rarity"`
// FlavorText is the flavor text, if any.
FlavorText *string `json:"flavor_text"`
// Artist is the name of the illustrator of this card. Newly spoiled
// cards may not have this field yet.
Artist *string `json:"artist"`
// IllustrationID is a unique identifier for the card artwork that
// remains consistent across reprints. Newly spoiled cards may not have
// this field yet.
IllustrationID *string `json:"illustration_id"`
// Frame is this card's frame layout.
Frame Frame `json:"frame"`
// FrameEffects is this card's frame effects, if any.
FrameEffects []FrameEffect `json:"frame_effects"`
// FullArt is true if this card's artwork is larger than normal.
FullArt bool `json:"full_art"`
// Watermark is this card's watermark, if any.
Watermark *string `json:"watermark"`
// Preview contains information about who previewed/spoiled this card.
Preview Preview `json:"preview"`
// PromoTypes is an array of promo types for this card, if any.
PromoTypes []string `json:"promo_types,omitempty"`
// BorderColor is this card's border color: black, borderless, gold,
// silver, or white.
BorderColor string `json:"border_color"`
// StorySpotlightNumber is this card's story spotlight number, if any.
StorySpotlightNumber *int `json:"story_spotlight_number"`
// StorySpotlightURI is a URL to this cards's story article, if any.
StorySpotlightURI *string `json:"story_spotlight_uri"`
// RelatedURIs contains links related to a card.
RelatedURIs RelatedURIs `json:"related_uris"`
// PurchaseURIs contains links to the card on online card stores.
PurchaseURIs PurchaseURIs `json:"purchase_uris"`
// Keywords is an array of keywords that this card uses, such as 'Flying' and 'Cumulative upkeep'.
Keywords []string `json:"keywords"`
// ProducedMana are colors of mana that this card could produce.
ProducedMana []Color `json:"produced_mana"`
// Booster is whether this card is found in boosters.
Booster bool `json:"booster"`
// Finishes is an array of computer-readable flags that indicate if this card can come in foil, nonfoil, etched, or glossy finishes.
Finishes []Finish `json:"finishes"`
// ImageStatus is a computer-readable indicator for the state of this card's image.
ImageStatus *ImageStatus `json:"image_status"`
// AttractionLights are the Unfinity attractions lights on this card, if any.
AttractionLights []int `json:"attraction_lights,omitempty"`
// ContentWarning is whether you should consider avoiding use of this
// print downstream.
ContentWarning *bool `json:"content_warning,omitempty"`
// FlavorName is the just-for-fun name printed on the card (such as for
// Godzilla series cards).
FlavorName *string `json:"flavor_name,omitempty"`
}
// RelatedCard is a card that is closely related to another card (because it
// calls it by name, or generates a token, or meld, etc).
type RelatedCard struct {
// ID is a unique ID for this card in Scryfall's database.
ID string `json:"id"`
// Component is a field explaining what role this card plays in the
// relationship.
Component Component `json:"component"`
// Name is the name of this particular related card.
Name string `json:"name"`
// TypeLine is the type line of this particular related card.
TypeLine string `json:"type_line"`
// URI is a URI where you can retrieve a full object describing this
// card on Scryfall's API.
URI string `json:"uri"`
}
// CardFace is a face of a multifaced card.
type CardFace struct {
// Name is the name of this particular face.
Name string `json:"name"`
// PrintedName is the printed name of this particular face.
// This will only be set if the card is not in English.
PrintedName *string `json:"printed_name"`
// TypeLine is the type line of this particular face.
TypeLine string `json:"type_line"`
// PrintedTypeLine is the printed type line of this particular face.
// This will only be set if the card is not in English.
PrintedTypeLine *string `json:"printed_type_line"`
// OracleText is the Oracle text for this face, if any.
OracleText *string `json:"oracle_text"`
// PrintedText is the printed text for this face, if any.
// This will only be set if the card is not in English.
PrintedText *string `json:"printed_text"`
// ManaCost is the mana cost for this face. This value will be any
// empty string "" if the cost is absent. Remember that per the game
// rules, a missing mana cost and a mana cost of {0} are different values.
ManaCost string `json:"mana_cost"`
// Colors is this face's colors.
Colors []Color `json:"colors"`
// ColorIndicator is the colors in this face's color indicator, if any.
ColorIndicator []Color `json:"color_indicator"`
// Power is this face's power, if any. Note that some cards have powers
// that are not numeric, such as *.
Power *string `json:"power"`
// Toughness is this face's toughness, if any.
Toughness *string `json:"toughness"`
// Layout is the layout of this card face, if the card is reversible.
Layout *Layout `json:"layout"`
// Loyalty is this face's loyalty, if any.
Loyalty *string `json:"loyalty"`
// OracleID is the Oracle ID of this particular face, if the card is
// reversible.
OracleID *string `json:"oracle_id,omitempty"`
// Defense is the face's defense, if the game defines colors for the
// individual face of this card.
Defense *string `json:"defense"`
// FlavorText is the flavor text printed on this face, if any.
FlavorText *string `json:"flavor_text"`
// IllustrationID is a unique identifier for the card face artwork that
// remains consistent across reprints. Newly spoiled cards may not have
// this field yet.
IllustrationID *string `json:"illustration_id"`
// ImageURIs is an object providing URIs to imagery for this face, if
// this is a double-sided card. If this card is not double-sided, then the
// image_uris property will be part of the parent object instead.
ImageURIs ImageURIs `json:"image_uris"`
}
// ImageURIs contains links to the different image sizes and crops for a given
// card.
type ImageURIs struct {
// Small is a small full card image. Designed for use as thumbnail or
// list icon.
Small string `json:"small"`
// Normal is a medium-sized full card image.
Normal string `json:"normal"`
// Large is a large full card image.
Large string `json:"large"`
// PNG is a transparent, rounded full card PNG. This is the best image
// to use for videos or other high-quality content.
PNG string `json:"png"`
// ArtCrop is a rectangular crop of the card's art only. Not guaranteed
// to be perfect for cards with outlier designs or strange frame
// arrangements
ArtCrop string `json:"art_crop"`
// BorderCrop is a full card image with the rounded corners and the
// majority of the border cropped off. Designed for dated contexts where
// rounded images can't be used.
BorderCrop string `json:"border_crop"`
}
// Prices contains daily price information for this card, including usd,
// usd_foil, eur, and tix prices.
type Prices struct {
// USD is the price of the card in US dollars.
USD string `json:"usd"`
// USD is the price of the foil card in US dollars.
USDFoil string `json:"usd_foil"`
// USDEtched is the price of the etched card in US dollars.
USDEtched string `json:"usd_etched"`
// EUR is the price of the card in Euros.
EUR string `json:"eur"`
// EURFoil is the price of the foil card in Euros.
EURFoil string `json:"eur_foil"`
// Tix is the price of the card in MTGO event tickets.
Tix string `json:"tix"`
}
// Legalities describes the legality of a card across formats.
type Legalities struct {
Standard Legality `json:"standard"`
Modern Legality `json:"modern"`
Pauper Legality `json:"pauper"`
Pioneer Legality `json:"pioneer"`
Legacy Legality `json:"legacy"`
Penny Legality `json:"penny"`
Vintage Legality `json:"vintage"`
Duel Legality `json:"duel"`
Commander Legality `json:"commander"`
Future Legality `json:"future"`
}
// RelatedURIs contains links related to a card.
type RelatedURIs struct {
Gatherer string `json:"gatherer"`
TCGPlayerDecks string `json:"tcgplayer_decks"`
EDHREC string `json:"edhrec"`
MTGTop8 string `json:"mtgtop8"`
}
// PurchaseURIs contains links to the card on online card stores.
type PurchaseURIs struct {
TCGPlayer string `json:"tcgplayer"`
CardMarket string `json:"cardmarket"`
CardHoarder string `json:"cardhoarder"`
}
// UniqueMode specifies whether Scryfall should remove duplicates from search
// results.
type UniqueMode string
const (
// UniqueModeCards removes duplicate gameplay objects (cards that share
// a name and have the same functionality). For example, if your search
// matches more than one print of Pacifism, only one copy of Pacifism will
// be returned.
UniqueModeCards UniqueMode = "cards"
// UniqueModeArt returns only one copy of each unique artwork for
// matching cards. For example, if your search matches more than one print
// of Pacifism, one card with each different illustration for Pacifism
// will be returned, but any cards that duplicate artwork already in the
// results will be omitted.
UniqueModeArt UniqueMode = "art"
// UniqueModePrints returns all prints for all cards matched (disables
// rollup). For example, if your search matches more than one print of
// Pacifism, all matching prints will be returned.
UniqueModePrints UniqueMode = "prints"
)
// Order is a method used to sort cards.
type Order string
const (
// OrderName sorts cards by name, A → Z.
OrderName Order = "name"
// OrderSet sorts cards by their set and collector number: oldest →
// newest.
OrderSet Order = "set"
// OrderRarity sorts cards by their rarity: Common → Mythic.
OrderRarity Order = "rarity"
// OrderColor sorts cards by their color and color identity: WUBRG →
// multicolor → colorless.
OrderColor Order = "color"
// OrderUSD sorts cards by their lowest known U.S. Dollar price: 0.01 →
// highest, null last.
OrderUSD Order = "usd"
// OrderTix sorts cards by their lowest known TIX price: 0.01 →
// highest, null last.
OrderTix Order = "tix"
// OrderEUR sorts cards by their lowest known Euro price: 0.01 →
// highest, null last.
OrderEUR Order = "eur"
// OrderCMC sorts cards by their converted mana cost: 0 → highest.
OrderCMC Order = "cmc"
// OrderPower sorts cards by their power: null → highest.
OrderPower Order = "power"
// OrderToughness sorts cards by their toughness: null → highest.
OrderToughness Order = "toughness"
// OrderEDHREC sorts cards by their EDHREC ranking: lowest → highest.
OrderEDHREC Order = "edhrec"
// OrderArtist sorts cards by their front-side artist name: A → Z.
OrderArtist Order = "artist"
)
// Dir is a direction used to sort cards.
type Dir string
const (
// DirAuto lets Scryfall automatically choose the most intuitive
// direction to sort.
DirAuto Dir = "auto"
// DirAsc sorts cards in ascending order.
DirAsc Dir = "asc"
// DirDesc sorts cards in descending order.
DirDesc Dir = "desc"
)
// SearchCardsOptions holds the options used to search for cards.
type SearchCardsOptions struct {
// Unique is the strategy for omitting similar cards. The default
// strategy is UniqueModeCards.
Unique UniqueMode `url:"unique,omitempty"`
// Order is the method used to sort the cards. The default method is
// OrderName.
Order Order `url:"order,omitempty"`
// Dir is the direction to sort the cards. The default direction is
// DirAuto.
Dir Dir `url:"dir,omitempty"`
// IncludeExtras determines whether extra cards (tokens, planes, etc.)
// should be included.
IncludeExtras bool `url:"include_extras,omitempty"`
// IncludeMultilingual determines whether cards in every language
// supported by Scryfall will be included. Defaults to false.
IncludeMultilingual bool `url:"include_multilingual,omitempty"`
// IncludeVariations determines whether rare care variants will be
// included, like the Hairy Runesword. Defaults to false.
IncludeVariations bool `url:"include_variations,omitempty"`
// Page is the page number to return. Page numbers start at 1 and the
// default is 1.
Page int `url:"page,omitempty"`
}
// CardListResponse represents a requested sequence of card
// objects. CardListResponse objects may be paginated, and also include
// information about issues raised when generating the list.
type CardListResponse struct {
// Cards is a list of the requested cards.
Cards []Card `json:"data"`
// HasMore is true if this List is paginated and there is a page beyond
// the current page.
HasMore bool `json:"has_more"`
// NextPage contains a full API URI to next page if there is a page
// beyond the current page.
NextPage *string `json:"next_page"`
// TotalCards contains the total number of cards found across all
// pages.
TotalCards int `json:"total_cards"`
// Warnings is a list of human-readable warnings issued when generating
// this list, as strings. Warnings are non-fatal issues that the API
// discovered with your input. In general, they indicate that the List
// will not contain the all of the information you requested. You should
// fix the warnings and re-submit your request.
Warnings []string `json:"warnings"`
}
// SearchCards returns a list cards found using a full text search. The query
// parameter is the full text search query. See the search reference docs for more
// information on the full text search query format:
// https://scryfall.com/docs/reference.
func (c *Client) SearchCards(ctx context.Context, query string, opts SearchCardsOptions) (CardListResponse, error) {
values, err := qs.Values(opts)
if err != nil {
return CardListResponse{}, err
}
values.Set("q", query)
cardsURL := fmt.Sprintf("cards/search?%s", values.Encode())
result := CardListResponse{}
err = c.get(ctx, cardsURL, &result)
if err != nil {
return CardListResponse{}, err
}
return result, nil
}
func (c *Client) getCard(ctx context.Context, url string) (Card, error) {
card := Card{}
err := c.get(ctx, url, &card)
if err != nil {
return Card{}, err
}
return card, nil
}
// GetCardByNameOptions holds the options used to get a card by name.
type GetCardByNameOptions struct {
// Set limits the search to the specified set.
Set string `url:"set,omitempty"`
}
// GetCardByName returns a Card based on a name search string. This method is
// designed for building chat bots, forum bots, and other services that need card
// details quickly.
//
// If the exact parameter is set to true, a card with that exact name is
// returned. Otherwise, an error is returned because no card matches.
//
// If the exact parameter is set to false and a card name matches that string,
// then that card is returned. If not, a fuzzy search is executed for your card
// name. The server allows misspellings and partial words to be provided. For
// example: jac bel will match Jace Beleren.
//
// When fuzzy searching, a card is returned if the server is confident that you
// unambiguously identified a unique name with your string. Otherwise, you will
// receive an error describing the problem: either more than 1 one card matched
// your search, or zero cards matched.
//
// For both exact and fuzzy, card names are case-insensitive and punctuation is
// optional (you can drop apostrophes and periods etc). For example: fIReBALL is
// the same as Fireball and smugglers copter is the same as Smuggler's Copter
func (c *Client) GetCardByName(ctx context.Context, name string, exact bool, opts GetCardByNameOptions) (Card, error) {
values, err := qs.Values(opts)
if err != nil {
return Card{}, err
}
if exact {
values.Set("exact", name)
} else {
values.Set("fuzzy", name)
}
cardURL := fmt.Sprintf("cards/named?%s", values.Encode())
return c.getCard(ctx, cardURL)
}