Skip to content

Commit

Permalink
Merge pull request #27 from BrightCoders-Institute/sprint3-issue-25#S…
Browse files Browse the repository at this point in the history
…ignUp-configurations

Sign Up configuration and Fixed errors in Post Model
  • Loading branch information
BlazeDex authored Mar 15, 2024
2 parents e5595c5 + c794779 commit 3b9528f
Show file tree
Hide file tree
Showing 16 changed files with 102 additions and 16 deletions.
10 changes: 9 additions & 1 deletion Gemfile.lock
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,12 @@ GEM
jbuilder (2.11.5)
actionview (>= 5.0.0)
activesupport (>= 5.0.0)
jquery-rails (4.6.0)
rails-dom-testing (>= 1, < 3)
railties (>= 4.2.0)
thor (>= 0.14, < 2.0)
jquery-ui-rails (6.0.1)
railties (>= 3.2.16)
json (2.7.1)
jwt (2.8.1)
base64
Expand Down Expand Up @@ -355,6 +361,8 @@ DEPENDENCIES
image_processing (>= 1.2)
importmap-rails
jbuilder
jquery-rails
jquery-ui-rails
omniauth
omniauth-google-oauth2
omniauth-rails_csrf_protection (~> 1.0)
Expand All @@ -371,7 +379,7 @@ DEPENDENCIES
web-console

RUBY VERSION
ruby 3.1.2p20
ruby 3.1.3p185

BUNDLED WITH
2.5.5
7 changes: 7 additions & 0 deletions app/controllers/application_controller.rb
Original file line number Diff line number Diff line change
@@ -1,2 +1,9 @@
class ApplicationController < ActionController::Base
before_action :configure_permitted_parameters, if: :devise_controller?

private

def configure_permitted_parameters
devise_parameter_sanitizer.permit(:sign_up, keys: %i[name lastName image_profile])
end
end
27 changes: 23 additions & 4 deletions app/controllers/posts_controller.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
class PostsController < ApplicationController
before_action :authenticate_user!
before_action :set_post, only: %i[show destroy edit update]
before_action :authenticate_user!, except: %i[show index]

def new
@post = Post.new
end
Expand All @@ -23,9 +24,22 @@ def index
@posts = Post.user_post(current_user)
end

def edit; end
def edit
unless current_user == @post.user
redirect_to root_path, alert: 'You are not authorized to edit this post.'
end
end

def show
@post = Post.find(params[:id])
end

def update
unless current_user == @post.user
redirect_to root_path, alert: 'You are not authorized to update this post.'
return
end

respond_to do |format|
if @post.update(post_params)
update_status(format)
Expand All @@ -37,10 +51,15 @@ def update
end

def destroy
unless current_user == @post.user
redirect_to root_path, alert: 'You are not authorized to delete this post.'
return
end

@post.destroy

respond_to do |format|
format.html { redirect_to root_path, notice: 'Post was succesfully deleted.' }
format.html { redirect_to root_path, notice: 'Post was successfully deleted.' }
format.json { head :no_content }
end
end
Expand All @@ -49,7 +68,7 @@ def destroy

# Use callbacks to share common setup or constraints between actions.
def set_post
@post = Post.user_post(current_user).find(params[:id])
@post = Post.find(params[:id])
end

# Only allow a list of trusted parameters through.
Expand Down
4 changes: 2 additions & 2 deletions app/mailers/application_mailer.rb
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
class ApplicationMailer < ActionMailer::Base
default from: "from@example.com"
layout "mailer"
default from: 'megatorterra@hotmail.com'
layout 'mailer'
end
1 change: 0 additions & 1 deletion app/models/post.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ class Post < ApplicationRecord
has_many_attached :images

validates :body, presence: true
validate :validate_at_least_one_image_attached
validate :validate_image_content_type

attr_accessor :images_to_remove
Expand Down
3 changes: 2 additions & 1 deletion app/models/user.rb
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@ class User < ApplicationRecord
has_many :posts

devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :validatable, :omniauthable, omniauth_providers: %i[google_oauth2]
:recoverable, :rememberable, :validatable,
:confirmable, :omniauthable, omniauth_providers: %i[google_oauth2]

def self.from_omniauth(access_token)
data = access_token.info
Expand Down
15 changes: 15 additions & 0 deletions app/views/devise/registrations/new.html.erb
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,21 @@
<%= form_for(resource, as: resource_name, url: registration_path(resource_name)) do |f| %>
<%= render "devise/shared/error_messages", resource: resource %>

<div class="field">
<%= f.label :name %>
<%= f.text_field :name, autofocus: true %>
</div>

<div class="field">
<%= f.label :lastName %>
<%= f.text_field :lastName, autofocus: true %>
</div>

<div class="field">
<%= f.label :image_profile, "Upload a new image", style: "display: block" %>
<%= f.file_field :image_profile %>
</div>

<div class="field">
<%= f.label :email %>
<%= f.email_field :email, autofocus: true, autocomplete: "email" %>
Expand Down
6 changes: 3 additions & 3 deletions app/views/posts/_cards.html.erb
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<%= link_to "Sign Out", destroy_user_session_path %>
<%= button_to "Sign Out", destroy_user_session_path, method: :delete %>

<div class="posts">
<% @posts.each do |post| %>
Expand All @@ -8,8 +8,8 @@
<div class="user">
<%= image_tag('default-light.png') %>
<div>
<h2>John Doe</h2>
<p>1 hour ago</p>
<h2><%=post.user.name%> <%=post.user.lastName%></h2>
<p><%= post.created_at.strftime("%d-%m-%Y a las %H:%M") %></p>
</div>
</div>
<i class="bi bi-three-dots"></i>
Expand Down
2 changes: 1 addition & 1 deletion app/views/posts/show.html.erb
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
<h1>Publicación de <%= current_user.email %></h1>
<h1>Publicación de <%= @post.user.name %></h1>
<h2><%=@post.body%></h2>
<div class="post-images">
<% if @post.images.attached? %>
Expand Down
12 changes: 11 additions & 1 deletion config/environment.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,15 @@
# Load the Rails application.
require_relative "application"
require_relative 'application'

# Initialize the Rails application.
Rails.application.initialize!

ActionMailer::Base.smtp_settings = {
user_name: 'apikey', # This is the string literal 'apikey', NOT the ID of your API key
password: ENV['SENDGRID_API_KEY'], # This is the secret sendgrid API key which was issued during API key creation
domain: 'hotmail.com',
address: 'smtp.sendgrid.net',
port: 587,
authentication: :plain,
enable_starttls_auto: true
}
1 change: 1 addition & 0 deletions config/environments/development.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

Rails.application.configure do
# Settings specified here will take precedence over those in config/application.rb.
config.action_mailer.default_url_options = { host: 'localhost', port: 3000 }

# In the development environment your application's code is reloaded any time
# it changes. This slows down response time but is perfect for development
Expand Down
2 changes: 1 addition & 1 deletion config/initializers/devise.rb
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
# Configure the e-mail address which will be shown in Devise::Mailer,
# note that it will be overwritten if you use your own mailer class
# with default "from" parameter.
config.mailer_sender = 'please-change-me-at-config-initializers-devise@example.com'
config.mailer_sender = 'megatorterra@hotmail.com'
config.omniauth :google_oauth2, Rails.application.credentials.GOOGLE_OAUTH_CLIENT_ID,
Rails.application.credentials.GOOGLE_OAUTH_CLIENT_SERVER

Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
class AddConfirmableToUsersFromAddDeviseToUsers < ActiveRecord::Migration[7.1]
def change
change_table :users do |t|
## Confirmable
t.string :confirmation_token
t.datetime :confirmed_at
t.datetime :confirmation_sent_at
t.string :unconfirmed_email # Only if using reconfirmable
end
end
end
6 changes: 5 additions & 1 deletion db/schema.rb

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 4 additions & 0 deletions test/mailers/previews/user_notifier_mailer_preview.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
# Preview all emails at http://localhost:3000/rails/mailers/user_notifier_mailer
class UserNotifierMailerPreview < ActionMailer::Preview

end
7 changes: 7 additions & 0 deletions test/mailers/user_notifier_mailer_test.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
require "test_helper"

class UserNotifierMailerTest < ActionMailer::TestCase
# test "the truth" do
# assert true
# end
end

0 comments on commit 3b9528f

Please sign in to comment.