
Research
/Security News
10 npm Typosquatted Packages Deploy Multi-Stage Credential Harvester
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.
dw-currency-converter
Advanced tools
** Documentation Please see the tests in [[./spec/money_spec.rb][RSpec Money Test]] as an example of usage.
** Canidate Challenge *** Canidate Note I added simplified exception handling for attempted conversions that are not covered.
*** Requirements and Expectations Hello dear candidate,
as part of the interview process to join the DaWanda Engineering Team, we would ask you to complete a short homework task. We hope you will enjoy it :)
We estimate the time needed to complete this task to be in the range of a few hours. During evaluation, we focus mostly on:
Here is your task:
Write a Ruby gem to perform currency conversion and arithmetics with different currencies (we know there are already gems for that, but for the sake of the exercise implement your own ;) ). The expected features and the usage of the gem should be something like this:
#+BEGIN_EXAMPLE # Configure the currency rates with respect to a base currency (here EUR):
Money.conversion_rates('EUR', {
'USD' => 1.11,
'Bitcoin' => 0.0047
})
# Instantiate money objects:
fifty_eur = Money.new(50, 'EUR')
# Get amount and currency:
fifty_eur.amount # => 50
fifty_eur.currency # => "EUR"
fifty_eur.inspect # => "50.00 E0UR"
# Convert to a different currency (should return a Money
# instance, not a String):
fifty_eur.convert_to('USD') # => 55.50 USD
# Perform operations in different currencies:
twenty_dollars = Money.new(20, 'USD')
# Arithmetics:
fifty_eur + twenty_dollars # => 68.02 EUR
fifty_eur - twenty_dollars # => 31.98 EUR
fifty_eur / 2 # => 25 EUR
twenty_dollars * 3 # => 60 USD
# Comparisons (also in different currencies):
twenty_dollars == Money.new(20, 'USD') # => true
twenty_dollars == Money.new(30, 'USD') # => false
fifty_eur_in_usd = fifty_eur.convert_to('USD')
fifty_eur_in_usd == fifty_eur # => true
twenty_dollars > Money.new(5, 'USD') # => true
twenty_dollars < fifty_eur # => true
#+END_EXAMPLE
For the purpose of this exercise, when implementing equality, you can consider two monetary amounts as equal if they agree up to the cents.
You might want to namespace your gem not to conflict with existing gems with the same name.
Keep it simple, no need to support other features rather than these. The clearer your code the better. But please write tests or documentation whenever it makes sense. Think as if other people will have to use your gem or contribute to it.
Please note that the actual numbers here are based on the conversion rate at the time we wrote the task. With different rates you will get different numbers.
FAQs
Unknown package
We found that dw-currency-converter 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.

Research
/Security News
Socket researchers found 10 typosquatted npm packages that auto-run on install, show fake CAPTCHAs, fingerprint by IP, and deploy a credential stealer.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.