Search code examples
rubyruby-on-rails-3dockerdiscourse

How to bind localhost RoR app to discourse docker container?


I've a ruby on rails app which is on 0.0.0.0:3000 and discourse docker container on port 0.0.0.0:80 . I want to bind localhost RoR app with docker container because postgreSQL is running inside the docker container and want to connect RoR app with postgreSQL which is inside docker container. How can I make db connection between RoR app and docker container postgrePSQL.

Here is my RoR controller.

class CronController < ApplicationController

    # slack channel hook
    $slackHook = "https://hooks.slack.com/services/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"
    $discourseHost = 'community.cloudways.com/';
    $messageText = "New Notification";

    # import http module
    require 'net/http'

=begin
    A method which build connection with postgreSQL and fetch last 24hr records 
=end

    def slackNotification
        logger.debug "*******Cron Started********"
        begin
            $query = "SELECT users.username AS username, topics.title AS topic_title, topics.id AS topic_id, posts.raw AS raw FROM post_replies 
                JOIN posts ON posts.id = post_replies.post_id 
                JOIN users ON users.id = posts.user_id 
                JOIN topics ON topics.user_id = users.id
                WHERE post_replies.created_at BETWEEN current_date AND current_date - INTERVAL '1' DAY;"
            $res = ActiveRecord::Base.connection.exec_query(query);

            # iteration on each record
            $res.each do |row|
                sendNotifications row
            end

            logger.debug "*******Cron successfully executed.********"
            render :json => {:status => "true", :message => "Cron successfully executed."}

        rescue Exception => e
            logger.fatal "Exception: #{e}"
        end
    end

=begin
    such method which take payload and send it to slack hook url
    @params row
=end
    def sendNotifications row
        $title = row['topic_title']
        $topicId = row['topic_id']
        $content = row['raw']
        begin
            uri = URI.parse($slackHook)
            # Full control
            http = Net::HTTP.new(uri.host, uri.port)
            response = Net::HTTP.post_form(uri, {
                'payload' => '{
                    "fallback": "#{$messageText}",
                    "text": "#{$title}",
                    "pretext": "<http://#{$discourseHost}|#{$title}>",
                    "color": "#36a64f",
                    "fields": [
                        {
                            "title": "#{$title}" , 
                            "value": "#{$content}",
                            "short": false 
                        }
                    ]
                }'
            })
        rescue Exception => e
            logger.fatal " Attributes: title: #{$title}, topicId: #{$topicId}, content: #{$content}, URL: <http://#{$discourseHost}|#{$title}> "
            logger.fatal "Exception: #{e}"
        end
    end
end

Solution

  • The publish option maps the ports docker-compose run --publish 3000:3000

    You can also specify in your docker yml file

    ports: - "881:80" - "3000:3000"