api_authentication_gem 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/api_authentication_gem.rb +36 -0
  3. metadata +72 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA256:
3
+ metadata.gz: 9f9996a17bc8d09dc00047653aa84cc9968eef8466f80adb5aa97ad12140c9c4
4
+ data.tar.gz: 2630ecb1e1974b54becba0597d6d6e014b0ec75d10c15b4b5a82d70b1605e8fa
5
+ SHA512:
6
+ metadata.gz: eae1e2f77c261de0287a6a16e31a5a7883687c83fb63d305818d157f814e82e72b9a49e9b42d10baee942bdbd32fa4218737e061d784a812140b597bb2f80856
7
+ data.tar.gz: e23c574d79bbe9ac96fd9e074ad44a02aa982d20da511b003b626ea186c5906ccaf86340044ab16ad25c631ec4eea47562a3c6b562fab511ce274d76130fb044
@@ -0,0 +1,36 @@
1
+ require "jwt"
2
+ require "bcrypt"
3
+
4
+ module ApiAuthenticationGem
5
+ class Auth
6
+ SECRET_KEY = "your$ecretK3y"
7
+
8
+ def self.signup(email:, password:, user_class:)
9
+ return { error: "Email is required" } unless email
10
+ return { error: "Password must be at least 5 characters long" } if password.nil? || password.length < 5
11
+
12
+ return { error: "Email already exists" } if user_class.find_by(email: email)
13
+
14
+ password_digest = BCrypt::Password.create(password)
15
+ user = user_class.create(email: email, password_digest: password_digest)
16
+
17
+ { message: "User created", user: user }
18
+ end
19
+
20
+ def self.login(email:, password:, user_class:)
21
+ user = user_class.find_by(email: email)
22
+
23
+ return { error: "Invalid email or password" } unless user
24
+ return { error: "Invalid email or password" } unless BCrypt::Password.new(user.password_digest) == password
25
+
26
+ token = JWT.encode({ user_id: user.id, exp: Time.now.to_i + 3600 }, SECRET_KEY, 'HS256')
27
+ { token: token }
28
+ end
29
+
30
+ def self.decode_token(token)
31
+ JWT.decode(token, SECRET_KEY, true, { algorithm: 'HS256' })[0]
32
+ rescue
33
+ nil
34
+ end
35
+ end
36
+ end
metadata ADDED
@@ -0,0 +1,72 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: api_authentication_gem
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ platform: ruby
6
+ authors:
7
+ - Adarsh Mishra
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2025-04-14 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: bcrypt
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: jwt
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ description: Reusable gem for authentication with user-defined models
42
+ email:
43
+ - aadimishra24@gmail.com
44
+ executables: []
45
+ extensions: []
46
+ extra_rdoc_files: []
47
+ files:
48
+ - lib/api_authentication_gem.rb
49
+ homepage: https://rubygems.org/gems/api_authentication_gem
50
+ licenses:
51
+ - MIT
52
+ metadata: {}
53
+ post_install_message:
54
+ rdoc_options: []
55
+ require_paths:
56
+ - lib
57
+ required_ruby_version: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - ">="
60
+ - !ruby/object:Gem::Version
61
+ version: '0'
62
+ required_rubygems_version: !ruby/object:Gem::Requirement
63
+ requirements:
64
+ - - ">="
65
+ - !ruby/object:Gem::Version
66
+ version: '0'
67
+ requirements: []
68
+ rubygems_version: 3.3.3
69
+ signing_key:
70
+ specification_version: 4
71
+ summary: Provides JWT-based signup and login for APIs
72
+ test_files: []