Skip to content
Snippets Groups Projects
Select Git revision
  • 0798881334227dbae57b2d6f0e57e18eba965a0b
  • master default protected
  • release/beta-qt-202301101210
  • stable
  • release/beta-qt-202211182015
  • release/beta-qt-202211181752
  • release/beta-qt-202211171508
  • release/beta-qt-202211081754
  • release/beta-qt-202211071518
  • release/beta-qt-202210270957
  • release/beta-qt-202210071648
  • release/beta-qt-202209291549
  • release/beta-qt-202209011129
  • release/beta-qt-202208261640
  • release/beta-qt-202208241511
  • release/beta-qt-202208231849
  • release/beta-qt-202208091525
  • release/beta-qt-202207191241
  • release/beta-qt-202207181708
  • release/beta-qt-202207131914
  • release/beta-qt-202207131513
  • android/release_358
  • android/release_357
  • android/release_356
  • android/release_355
  • android/release_354
  • 20221220.0956.79e1207
  • android/release_353
  • android/release_352
  • android/release_350
  • android/release_349
  • android/release_348
  • android/release_347
  • 20221031.1308.130cc26
  • android/release_346
  • android/release_345
  • android/release_344
  • android/release_343
  • android/release_342
  • android/release_341
  • android/release_340
41 results

install.sh

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    main.cpp 6.11 KiB
    /*
     *  Copyright (C) 2004-2019 Savoir-faire Linux Inc.
     *
     *  Author: Alexandre Bourget <alexandre.bourget@savoirfairelinux.com>
     *  Author: Yan Morin <yan.morin@savoirfairelinux.com>
     *  Author: Laurielle Lea <laurielle.lea@savoirfairelinux.com>
     *  Author: Simon Zeni <simon.zeni@savoirfairelinux.com>
     *
     *  This program 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, write to the Free Software
     *  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301 USA.
     */
    
    #include "dring/dring.h"
    
    #include "logger.h"
    
    #if REST_API
    #include "restcpp/restclient.h"
    #else
    #include "dbus/dbusclient.h"
    #endif
    
    #include "fileutils.h"
    
    #include <signal.h>
    #include <getopt.h>
    
    #include <iostream>
    #include <thread>
    #include <memory>
    #include <cstring>
    #include <cstdlib>
    
    static int ringFlags = 0;
    static int port = 8080;
    
    #if REST_API
    static std::weak_ptr<RestClient> weakClient;
    #else
    static std::weak_ptr<DBusClient> weakClient;
    #endif
    
    static void
    print_title()
    {
        std::cout
            << "Jami Daemon " << DRing::version()
            << ", by Savoir-faire Linux 2004-2019" << std::endl
            << "https://jami.net/" << std::endl
    #ifdef ENABLE_VIDEO
            << "[Video support enabled]" << std::endl
    #endif
            << std::endl;
    }
    
    static void
    print_usage()
    {
        std::cout << std::endl <<
        "-c, --console \t- Log in console (instead of syslog)" << std::endl <<
        "-d, --debug \t- Debug mode (more verbose)" << std::endl <<
        "-p, --persistent \t- Stay alive after client quits" << std::endl <<
        "--port \t- Port to use for the rest API. Default is 8080" << std::endl <<
        "--auto-answer \t- Force automatic answer to incoming calls" << std::endl <<
        "-h, --help \t- Print help" << std::endl;
    }
    
    // Parse command line arguments, setting debug options or printing a help
    // message accordingly.
    // returns true if we should quit (i.e. help was printed), false otherwise
    static bool
    parse_args(int argc, char *argv[], bool& persistent)
    {
        int consoleFlag = false;
        int debugFlag = false;
        int helpFlag = false;
        int versionFlag = false;
        int autoAnswer = false;
    
        const struct option long_options[] = {
            /* These options set a flag. */
            {"debug",       no_argument,        nullptr,    'd'},
            {"console",     no_argument,        nullptr,    'c'},
            {"persistent",  no_argument,        nullptr,    'p'},
            {"help",        no_argument,        nullptr,    'h'},
            {"version",     no_argument,        nullptr,    'v'},
            {"auto-answer", no_argument,        &autoAnswer, true},
            {"port",        optional_argument,  nullptr,    'x'},
            {nullptr,       0,                  nullptr,     0} /* Sentinel */
        };
    
        while (true) {
            /* getopt_long stores the option index here. */
            int option_index = 0;
    
            auto c = getopt_long(argc, argv, "dcphvx:", long_options, &option_index);
    
            // end of the options
            if (c == -1)
                break;
    
            switch (c) {
                case 'd':
                    debugFlag = true;
                    break;
    
                case 'c':
                    consoleFlag = true;
                    break;
    
                case 'p':
                    persistent = true;
                    break;
    
                case 'h':
                case '?':
                    helpFlag = true;
                    break;
    
                case 'v':
                    versionFlag = true;
                    break;
    
                case 'x':
                    port = std::atoi(optarg);
                    break;
    
                default:
                    break;
            }
        }
    
        if (helpFlag) {
            print_usage();
            return true;
        }
    
        if (versionFlag) {
            // We've always print the title/version, so we can just exit
            return true;
        }
    
        if (consoleFlag)
            ringFlags |= DRing::DRING_FLAG_CONSOLE_LOG;
    
        if (debugFlag)
            ringFlags |= DRing::DRING_FLAG_DEBUG;
    
        if (autoAnswer)
            ringFlags |= DRing::DRING_FLAG_AUTOANSWER;
    
        return false;
    }
    
    static void
    signal_handler(int code)
    {
        std::cerr << "Caught signal " << strsignal(code)
                  << ", terminating..." << std::endl;
    
        // Unset signal handlers
        signal(SIGHUP, SIG_DFL);
        signal(SIGINT, SIG_DFL);
        signal(SIGTERM, SIG_DFL);
    
        // Interrupt the process
        if (auto client = weakClient.lock())
            client->exit();
    }
    
    int
    main(int argc, char *argv [])
    {
        // make a copy as we don't want to modify argv[0], copy it to a vector to
        // guarantee that memory is correctly managed/exception safe
        std::string programName {argv[0]};
        std::vector<char> writable(programName.size() + 1);
        std::copy(programName.begin(), programName.end(), writable.begin());
    
        jami::fileutils::set_program_dir(writable.data());
    
    #ifdef TOP_BUILDDIR
        if (!getenv("CODECS_PATH"))
            setenv("CODECS_PATH", TOP_BUILDDIR "/src/media/audio/codecs", 1);
    #endif
    
        print_title();
    
        bool persistent = false;
        if (parse_args(argc, argv, persistent))
            return 0;
    
        // TODO: Block signals for all threads but the main thread, decide how/if we should
        // handle other signals
        signal(SIGINT, signal_handler);
        signal(SIGHUP, signal_handler);
        signal(SIGTERM, signal_handler);
        signal(SIGPIPE, SIG_IGN);
    
        try {
    #if REST_API
            if (auto client = std::make_shared<RestClient>(port, ringFlags, persistent))
    #else
            if (auto client = std::make_shared<DBusClient>(ringFlags, persistent))
    #endif
            {
                weakClient = client;
                return client->event_loop();
            }
        } catch (const std::exception& ex) {
            std::cerr << "One does not simply initialize the client: " << ex.what() << std::endl;
        }
        return 1;
    }