de.jackwhite20.cascade.server.impl.CascadeServer.java Source code

Java tutorial

Introduction

Here is the source code for de.jackwhite20.cascade.server.impl.CascadeServer.java

Source

/*
 * Copyright (c) 2016 "JackWhite20"
 *
 * This file is part of Cascade.
 *
 * Cascade is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

package de.jackwhite20.cascade.server.impl;

import de.jackwhite20.cascade.server.Server;
import de.jackwhite20.cascade.shared.pipeline.PipelineUtils;
import de.jackwhite20.cascade.shared.pipeline.initialize.CascadeChannelInitializer;
import de.jackwhite20.cascade.shared.session.SessionListener;
import de.jackwhite20.cascade.shared.thread.CascadeThreadFactory;
import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.Channel;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;

import java.util.stream.Collectors;

/**
 * Created by JackWhite20 on 24.09.2016.
 */
public class CascadeServer implements Server {

    private ServerConfig serverConfig;

    private EventLoopGroup bossGroup;

    private EventLoopGroup workerGroup;

    private Channel serverChannel;

    public CascadeServer(ServerConfig serverConfig) {

        this.serverConfig = serverConfig;
    }

    @Override
    public void start() {

        bossGroup = new NioEventLoopGroup();
        workerGroup = PipelineUtils.newEventLoopGroup(serverConfig.workerThreads(),
                new CascadeThreadFactory("Server"));

        try {
            ServerBootstrap b = new ServerBootstrap();
            serverChannel = b.group(bossGroup, workerGroup).channel(PipelineUtils.getServerChannel())
                    .childHandler(new CascadeChannelInitializer(serverConfig.protocol(),
                            serverConfig.sessionListener().stream().collect(Collectors.toList())))
                    .option(ChannelOption.TCP_NODELAY, true).option(ChannelOption.SO_BACKLOG, 200)
                    .bind(serverConfig.host(), serverConfig.port()).sync().channel();

            serverConfig.sessionListener().forEach(SessionListener::onStarted);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    @Override
    public void stop() {

        serverChannel.close();

        bossGroup.shutdownGracefully();
        workerGroup.shutdownGracefully();

        serverConfig.sessionListener().forEach(SessionListener::onStopped);
    }

    @Override
    public boolean isRunning() {

        return serverChannel.isActive();
    }

    @Override
    public void addSessionListener(SessionListener... sessionListener) {

        serverConfig.sessionListener(sessionListener);
    }
}