module GraphQL # A finite set of possible values, represented in query strings with # SCREAMING_CASE_NAMES # # @example An enum of programming languages # # LanguageEnum = GraphQL::EnumType.define do # name "Languages" # description "Programming languages for Web projects" # value("PYTHON", "A dynamic, function-oriented language") # value("RUBY", "A very dynamic language aimed at programmer happiness") # value("JAVASCRIPT", "Accidental lingua franca of the web") # end class EnumType < GraphQL::BaseType accepts_definitions value: GraphQL::Define::AssignEnumValue def initialize @values_by_name = {} @values_by_value = {} end def values=(new_values) @values_by_name = {} @values_by_value = {} new_values.each { |enum_value| add_value(enum_value) } end def add_value(enum_value) @values_by_name[enum_value.name] = enum_value @values_by_value[enum_value.value] = enum_value end def values ensure_defined @values_by_name end def kind GraphQL::TypeKinds::ENUM end def validate_non_null_input(value_name) ensure_defined result = GraphQL::Query::InputValidationResult.new if !@values_by_name.key?(value_name) result.add_problem("Expected #{JSON.dump(value_name)} to be one of: #{@values_by_name.keys.join(', ')}") end result end # Get the underlying value for this enum value # # @example get episode value from Enum # episode = EpisodeEnum.coerce("NEWHOPE") # episode # => 6 # # @param value_name [String] the string representation of this enum value # @return [Object] the underlying value for this enum value def coerce_non_null_input(value_name) ensure_defined if @values_by_name.key?(value_name) @values_by_name.fetch(value_name).value else nil end end def coerce_result(value) ensure_defined @values_by_value.fetch(value).name end def to_s name end # A value within an {EnumType} # # Created with {EnumType#value} class EnumValue attr_accessor :name, :description, :deprecation_reason, :value def initialize(name:, description:, deprecation_reason:, value:) @name = name @description = description @deprecation_reason = deprecation_reason @value = value end end end end