SebElink
Lightweight Ruby wrapper for communicating with SEB.lv i-bank payment API.
Solves the cryptographic requirements for you.
Installation
Bundle or manually install the latest version of the gem:
gem 'seb_elink'
Usage
Please note that for consistency in this gem all hash keys are constant-case symbols like :IB_VERSION
.
The gem has three elements represented as Ruby classes:
1. SebElink::Gateway
Think of this as the communication adapter. Initialize it with a base64-encoded private key string (the human-readable .pem format). You can store the instance in a constant to reduce processing overhead.
You can pass an optional options hash as the second argument that will specify default values for communications processed by that gateway instance. Useful for setting company-related data just once.
SebElink::Gateway.new(
<privkey string>,
{
IB_SND_ID: "TESTCOMPANY",
IB_NAME: "Test Inc."
}
)
Additionally, you can rewrite values used by the gem pertaining to SEB.lv i-bank, such as their public key, API uri etc. Here's a complete list:
{
IB_VERSION: "001",
IBANK_CERT: "-----BEGIN CERTIFICATE-----..."
IBANK_API_URI: "https://ibanka.seb.lv/ipc/epakindex.jsp"
}
Instances of SebElink::Gateway
have one method for public use:
gateway.ibank_api_uri
2. SebElink::Message
Instances represent requests to i-bank, generally for payment.
Initialize these with SebElink::Message.new(gateway_instance, message_code, data_hash)
SEB_LV_GATEWAY = SebElink::Gateway.new(<privkey string>)
message_instance = SebElink::Message.new(SEB_LV_GATEWAY, "0002", {IB_SND_ID: ...})
Please consult message_specs.rb
for the full list of data_hash keys.
Instances of SebElink::Message
have two methods:
message_instance.to_h
message_instance.digital_signature
3. SebElink::Response
Instances represent responses from SEB.lv i-bank server.
Well-formedness is not validated since if digital signature is OK, one would think that the bank adheres to it's own spec.
Initialize these with SebElink::Response.new(gateway_instance, response_body)
Please note that the method name #response
is reserved in Rails, use something else for response variable names!
SEB_LV_GATEWAY = SebElink::Gateway.new(<privkey string>)
response_body =
if request.get?
request.query_string
else
request.raw_post
end
response_instance = SebElink::Response.new(SEB_LV_GATEWAY, response_body)
Instances of SebElink::Response
have two methods:
response_instance.valid?
response_instance.to_h
Tests have been written in a documenting manner, so, please,
have a look at the contents of spec/
directory to get a feel of what the gem can do.
Version 001 (current) uses the deprecated SHA-1 hashing algorithm. Let SEB.lv know that v2 that uses SHA-256 is needed.
Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/CreativeGS/seb_elink. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.
The project uses TDD approach to software development, follow these steps to set up:
- fork and clone the repo on github
- Install appropriate Ruby and Bundler
bundle
- See if all specs are green with
rspec
- TDD new features
- Make a Pull Request in github
Releasing a new version
gem push # to set credentials
rake release
License
The gem is available as open source under the terms of the BSD-3-Clause License.
Code of Conduct
Everyone interacting in the SebElink project’s codebases and issue trackers is expected to follow the code of conduct.