An unofficial, mostly Bitwarden-compatible API server written in Ruby (Sinatra and ActiveRecord)
1#
2# Copyright (c) 2017 joshua stein <jcs@jcs.org>
3#
4# Permission to use, copy, modify, and distribute this software for any
5# purpose with or without fee is hereby granted, provided that the above
6# copyright notice and this permission notice appear in all copies.
7#
8# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9# WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10# MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11# ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12# WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13# ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14# OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
15#
16
17Encoding.default_internal = Encoding.default_external = Encoding::UTF_8
18
19APP_ROOT = File.realpath(File.dirname(__FILE__) + "/../")
20
21RUBYWARDEN_ENV ||= (ENV["RUBYWARDEN_ENV"] || ENV["RACK_ENV"] || "development")
22
23require "sqlite3"
24require "active_record"
25
26require "sinatra/base"
27require "sinatra/namespace"
28require "cgi"
29
30require "#{APP_ROOT}/lib/bitwarden.rb"
31require "#{APP_ROOT}/lib/helper.rb"
32
33require "#{APP_ROOT}/lib/db.rb"
34require "#{APP_ROOT}/lib/dbmodel.rb"
35require "#{APP_ROOT}/lib/user.rb"
36require "#{APP_ROOT}/lib/device.rb"
37require "#{APP_ROOT}/lib/cipher.rb"
38require "#{APP_ROOT}/lib/folder.rb"
39require "#{APP_ROOT}/lib/attachment.rb"
40
41BASE_URL = (ENV["RUBYWARDEN_BASE_URL"] || "/api")
42IDENTITY_BASE_URL = (ENV["RUBYWARDEN_IDENTITY_BASE_URL"] || "/identity")
43ICONS_URL = (ENV["RUBYWARDEN_ICONS_URL"] || "/icons")
44ATTACHMENTS_URL = (ENV["RUBYWARDEN_ATTACHMENTS_URL"] || "/attachments")
45
46# whether to allow new users
47if !defined?(ALLOW_SIGNUPS)
48 ALLOW_SIGNUPS = (ENV["RUBYWARDEN_ALLOW_SIGNUPS"] || ENV["ALLOW_SIGNUPS"] || false)
49end
50
51# create/load JWT signing keys
52Bitwarden::Token.load_keys
53
54# connect to db
55Db.connect(environment: RUBYWARDEN_ENV)