inst/gui/server.R

.get.connection.list <- function ()
{
    id <- GreenplumR:::.localVars$conn.id[,1]
    as.character(id)
}

## ------------------------------------------------------------------------

.get.connection.info <- function (conn.id)
{
    if (identical(conn.id, integer(0)))
        data.frame(Host = "", User = "", Database = "", DBMS = "")
    else {
        idx <- GreenplumR:::.localVars$conn.id[GreenplumR:::.localVars$conn.id[,1] == conn.id, 2]
        db <- GreenplumR:::.get.dbms.str(conn.id)
        data.frame(Host = GreenplumR:::.localVars$db[[idx]]$host,
                   User = GreenplumR:::.localVars$db[[idx]]$user,
                   Database = GreenplumR:::.localVars$db[[idx]]$dbname,
                   DBMS = paste(db$db.str, db$version.str))
    }
}

## -----------------------------------------------------------------------

## Define server logic required to plot various variables against mpg
shinyServer(function(input, output, session) {
    ## Return the requested dataset
    conInput <- reactive({
        as.integer(input$connection)
    })

    db.obj.list <- reactive({
        id <- conInput()
        if (identical(id, integer(0)) ||
            !GreenplumR:::.is.conn.id.valid(id))
            ""
        else
            db.objects(conn.id = id)
    })

    ## ------------------------------------------------
    
    output$conn.controls <- renderUI({
        selectInput("connection", "Select a connection",
                    choices = .get.connection.list())
    })

    output$tbl.controls <- renderUI({
        selectInput("table", "Select a table:",
                    choices = c("", db.obj.list()),
                    selected = "")
    })

    output$dep.controls <- renderUI({
        id <- conInput()
        tbl <- input$table
        if (identical(id, integer(0)) || is.null(tbl) || tbl == "")
            vars <- c("")
        else
            vars <- c("", names(db.data.frame(tbl, conn.id = id,
                                              verbose = FALSE)))
        selectInput("dep", "Select the dependent variable:",
                    choices = vars,
                    selected = "")
    })

    output$ind.controls <- renderUI({
        id <- conInput()
        tbl <- input$table
        if (identical(id, integer(0)) || is.null(tbl) || tbl == "")
            vars <- c("")
        else
            vars <- names(db.data.frame(tbl, conn.id = id,
                                        verbose = FALSE))
        checkboxGroupInput("ind", "Select the independent variables:",
                           choices = vars)
    })

    output$grp.controls <- renderUI({
        id <- conInput()
        tbl <- input$table
        if (identical(id, integer(0)) || is.null(tbl) || tbl == "")
            vars <- c("")
        else
            vars <- names(db.data.frame(tbl, conn.id = id,
                                        verbose = FALSE))
        checkboxGroupInput("grp", "Select the grouping variables:",
                           choices = vars)
    })

    observe({
        if (is.null(input$model) || input$model == "" ||
            input$table == "")
            updateTabsetPanel(session, "tabset", selected = "Summary")
        else
            updateTabsetPanel(session, "tabset", selected = "Computation")
    })

    observe({
        if (!is.null(input$table) && !is.null(input$model) &&
            input$table == "")
             updateSelectInput(session, "model",
                               "Select a model/operation:",
                               choices = c("", "Linear Regression",
                               "Logistic Regression"), selected = "")
    })
    
    ## ------------------------------------------------
    
    output$con.info <- renderTable({
       conn.id <- conInput()
       .get.connection.info(conn.id)
    })

    output$tbl.info <- renderTable({
        conn.id <- conInput()
        tbl <- input$table
        if (is.null(tbl) || tbl == "") {
            data.frame()
        } else {
            x <- db.data.frame(tbl, conn.id = conn.id, verbose = FALSE)
            res <- madlib.summary(x)
            class(res) <- "data.frame"
            res[,-c(1,2)]
        }
    })

    output$model.info <- renderPrint({
        conn.id <- conInput()
        tbl <- input$table
        dep <- input$dep
        ind <- input$ind
        grp <- input$grp
        fml <- input$rformula
        use.fml <- input$formula
        
        empty.res <- "No model"
        class(empty.res) <- "none.obj"
    
        if (is.null(tbl) || tbl == "" ||
            ((is.null(dep) || is.null(ind)) && fml == "")) {
            empty.res
        } else {
            x <- db.data.frame(tbl, conn.id = conn.id, verbose = FALSE)
            if (is.null(use.fml) || !use.fml) {
                f <- paste(dep, "~", paste(ind, collapse = " + "))
                if (!is.null(grp))
                    f <- paste(f, "|", paste(grp, collapse = " + "))
            } else {
                f <- fml
            }
            cat("\nf =", f, "\n--------------------------------------\n")
            if (input$model == "Linear Regression")
                res <- try(madlib.lm(formula(f), data = x),
                           silent = TRUE)
            else if (input$model == "Logistic Regression")
                res <- try(madlib.glm(formula(f), data = x,
                                      family = "binomial"),
                           silent = TRUE)
            if (is(res, GreenplumR:::.err.class))
                return (empty.res)
            else
                res
        }
    })
})
greenplum-db/GreenplumR documentation built on Sept. 2, 2023, 8:09 a.m.