![Create React App Officially Deprecated Amid React 19 Compatibility Issues](https://cdn.sanity.io/images/cgdhsj6q/production/04fa08cf844d798abc0e1a6391c129363cc7e2ab-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Create React App Officially Deprecated Amid React 19 Compatibility Issues
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.
This project is a library for loading Travis CI build configuration.
It can create a configuration both from a normal Ruby Hash or a YAML string. These config objects generally behave like normal primitives (hashes, arrays, etc).
require 'travis/yaml'
config = Travis::Yaml.parse('language: ruby')
config = Travis::Yaml.parse(language: 'ruby')
config[:language] # ruby
config.language # ruby
# using parse! instead of parse will print out warnings
Travis::Yaml.parse! deploy: []
# .travis.yml: missing key "language", defaulting to "ruby"
# .travis.yml: value for "deploy" section is empty, dropping
# have it generate the build matrix for you
Travis::Yaml.matrix('rvm: [jruby, 2.0.0]').each do |matrix_entry|
puts matrix_entry.ruby
end
node: 1.10
does not get converted to node: 1.1
internally, because travis-yaml knows to expect a string here rather than a float.config = Travis::Yaml.parse('language: ruby') # parse from a yaml string
config = Travis::Yaml.parse(language: "ruby") # parse from Ruby object
For Psych/YAML compatibility, parse
is also aliased to load
.
Nodes generally behave like normal Ruby objects. Mappings accept both symbols and strings as keys. Known fields on mappings are exposed as methods.
puts config.language
puts config[:language]
puts config['language']
Travis::Yaml.parse("foo: bar").nested_warnings.each do |key, warning|
puts "#{key.join('.')}: #{warning}"
end
# will print nested warnings to stderr, will raise on top level error
Travis::Yaml.parse! "foo: bar"
Secure variables are stored as Travis::Yaml::SecureString
internally. A secure string has at least an encrypted_string
or a decrypted_string
, or both.
You can use decrypt
/encrypt
with a block to generate the missing string:
secret = Travis::Yaml::SecureString.new("foo")
secret.encrypted_string # => "foo"
secret.decrypted_string # => nil
secret.encrypted? # => true
secret.decrypted? # => false
secret.decrypt { |string| string.upcase }
secret.encrypted_string # => "foo"
secret.decrypted_string # => "FOO"
secret.encrypted? # => true
secret.decrypted? # => true
To avoid having to walk the whole structure manually or hardcoding the values to decrypt, these methods are also exposed on any node:
config = Travis::Yaml.load 'env: { secure: foo }'
config.decrypted? # => false
config.decrypt { |string| string.upcase }
config.decrypted? # => true
config.env.matrix.first.decrypted_string # => "FOO"
This can even be done right with the parse step:
content = File.read('.travis.yml')
Travis::Yaml.parse! content do |config|
config.decrypt { |string| string.upcase }
end
A travis-yaml document can be serialized to a few other formats via the serialize
method:
pp config.serialize(:ruby)
puts config.serialize(:json, pretty: true)
Serializer | Descriptions | Options |
---|---|---|
ruby | Corresponding Ruby objects, secure values will be SecureString s | secure , symbol_keys |
legacy | Format compatible with Travis CI's old fetch_config service | secure , symbol_keys |
json | Serialize as JSON, parsable via Travis::Yaml.load | secure , pretty |
yaml | Serialize as YAML, parsable via Travis::Yaml.load | secure , symbol_keys , indentation , line_width , canonical , avoid_tags |
The secure
option can be set to :decrypted
or :encrypted
, enforcing the decrypted or encrypted form of secure strings to be serialized. In some serializations, this might lead to secure strings being mapped to normal strings if set to :decrypted
.
Good starting points for getting into the code are the root node and the language node.
A parsed configuration is very similar to a syntax tree. To create a new node type, you should inherit from one of the abstract types. Internal vocabulary is taken from the YAML spec rather than the Ruby names (ie, sequence vs array, mapping vs hash).
Most of the time, scalar values are just strings. In fact, if you create a new scalar node class and don't specify and other supported type, it will treat everything as string.
module Travis::Yaml::Nodes
class Example < Scalar
end
end
This will parse foo
to "foo"
and 1.10
to 1.10
. This will also generate a warning and discard values like !float 1.10
.
You can also allow other types and change the default type unsupported implicit types are cast to.
module Travis::Yaml::Nodes
class Example < Scalar
cast :str, :binary, :int
default_type :int
end
end
Available types are str
, binary
, bool
, float
, int
, time
, regexp
, secure
and null
.
It is also possible to give a scalar a default value.
module Travis::Yaml::Nodes
class Example < Scalar
default_value "example"
end
end
This is handy when using it for a required entry in a mapping (for instance, language
is required, but has a default).
For entries that have a well defined set of values, you can inherit from FixedValue
:
module Travis::Yaml::Nodes
class Example < FixedValue
ignore_case
default_value :example
value :foo, :bar, baz: :bar
end
end
This will, for example, map FOO
to "foo"
, baz
to "bar"
, and blah
to "example"
(and generate a warning about blah
being not supported).
There are shorthands for creating Scalar
and FixedValue
subclasses:
module Travis::Yaml::Nodes
class Example < Map
map :foo, to: Scalar[:int]
map :bar, to: FixedValue[:foo, :bar]
end
end
Sequences correspond to Ruby arrays. If you pass in a scalar or mapping instead of a sequence, it will be treated as if it was a sequence with a single entry of that value.
module Travis::Yaml::Nodes
class ExampleList < Sequence
type ExampleValue # node type, defaults to Scalar
end
end
Mappings correspond to hashes in Ruby.
module Travis::Yaml::Nodes
class ExampleMapping < Mapping
# map the value for the "example" key to an Example node
# map the value for the "other" key to an Other node
map :example, :other
# map the values for "foo" and "bar" to a Scalar
map :foo, :bar, to: Scalar
# map "list" to a Sequence, keep it even if it's empty
map :list, to: Sequence, drop_empty: false
# require "setting" to be present
map :setting, required: true
# make "option" an alias for "setting"
map :option, to: :setting
# if a scalar is passed in instead of a mapping, treat it as
# the value of "setting" ("foo" becomes { setting: "foo" })
prefix_scalar :setting
end
end
Sometimes it is not possible to define all available keys for a mapping. You can solve this by using an open mapping:
module Travis::Yaml::Nodes
class ExampleMapping < OpenMapping
# node type for entries not specified (defaults to Scalar)
default_type ExampleValue
# map "setting" to Setting node, make it a requirement
map :setting, required: true
end
end
You can also limit the possible keys by overriding accept_key?
.
module Travis::Yaml::Nodes
class ExampleMapping < OpenMapping
default_type ExampleValue
def accept_key?(key)
key.start_with? "example_"
end
end
end
Besides the generated warnings, validations and normalizations inherent to the structure, you can define your own checks and normalizations by overriding the verify
method.
module Travis::Yaml::Nodes
class Example < Scalar
def verify
if value == "foo"
warning "foo is deprecated, using bar instead"
self.value = "bar"
end
super
end
end
end
The warning
method will generate track a warning, so it can be presented to the user later on. The error
method will lead to the node being removed from its parent node. It will also propagate the error message as a warning in the parent node.
When reflecting upon a node, warnings
and errors
will only contain the messages for that specific node. To get all the warnings for the entire tree, use nested_warnings
, which will also give you the path (as array of strings).
config.nested_warnings.each do |path, message|
p path # ["my", "example", "key"]
p message # "this is the warning"
end
This project requires Ruby 1.9.3 or 2.0.0 and Psych ~> 2.0 (part of the stdlib).
FAQs
Unknown package
We found that travis-yaml demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Create React App is officially deprecated due to React 19 issues and lack of maintenance—developers should switch to Vite or other modern alternatives.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.