tuna-timer/tuna-timer-api

View on GitHub
commands/status.go

Summary

Maintainability
A
1 hr
Test Coverage
package commands

import (
    "context"

    "github.com/cleverua/tuna-timer-api/data"
    "github.com/cleverua/tuna-timer-api/models"
    "github.com/cleverua/tuna-timer-api/themes"
    "github.com/cleverua/tuna-timer-api/utils"
    "gopkg.in/mgo.v2"
    "time"
)

//Status - handles the '/timer status` command received from Slack
type Status struct {
    session      *mgo.Session
    teamService  *data.TeamService
    timerService *data.TimerService
    userService  *data.UserService
    passService  *data.PassService
    report       *models.StatusCommandReport
    ctx          context.Context
    theme        themes.SlackMessageTheme
}

func NewStatus(ctx context.Context) *Status {
    session := utils.GetMongoSessionFromContext(ctx)

    status := &Status{
        session:      session,
        teamService:  data.NewTeamService(session),
        timerService: data.NewTimerService(session),
        userService:  data.NewUserService(session),
        passService:  data.NewPassService(session),
        report:       &models.StatusCommandReport{},
        ctx:          ctx,
        theme:        utils.GetThemeFromContext(ctx).(themes.SlackMessageTheme),
    }

    return status
}

// Handle - SlackCustomCommandHandler interface
// todo test it!
func (c *Status) Handle(ctx context.Context, slackCommand models.SlackCustomCommand) *ResponseToSlack {
    team, project, err := c.teamService.EnsureTeamSetUp(&slackCommand)
    if err != nil {
        // todo: format a decent Slack error message so user knows what's wrong and how to solve the issue
    }

    teamUser, err := c.userService.EnsureUser(team, slackCommand.UserID)
    if err != nil {
        // todo: format a decent Slack error message so user knows what's wrong and how to solve the issue
    }

    pass, err := c.passService.EnsurePass(team, teamUser, project)
    if err != nil {
        // todo: format a decent Slack error message so user knows what's wrong and how to solve the issue
    }

    c.report.Team = team
    c.report.Project = project
    c.report.TeamUser = teamUser
    c.report.Pass = pass

    day := time.Now().Add(time.Duration(teamUser.SlackUserInfo.TZOffset) * time.Second)
    c.report.PeriodName = "today"

    if slackCommand.Text == "yesterday" {
        day = day.AddDate(0, 0, -1)
        c.report.PeriodName = "yesterday"
    }

    tasks, err := c.timerService.GetCompletedTasksForDay(day.Year(), day.Month(), day.Day(), teamUser)
    if err != nil {
        // todo: format a decent Slack error message so user knows what's wrong and how to solve the issue
    }
    c.report.Tasks = tasks
    c.report.UserTotalForPeriod = c.timerService.TotalCompletedMinutesForDay(day.Year(), day.Month(), day.Day(), teamUser)

    if c.report.PeriodName == "today" {
        alreadyStartedTimer, _ := c.timerService.GetActiveTimer(team.ID.Hex(), teamUser.ID.Hex())

        if alreadyStartedTimer != nil {
            alreadyStartedTimer.Minutes = c.timerService.CalculateMinutesForActiveTimer(alreadyStartedTimer)
            c.report.AlreadyStartedTimer = alreadyStartedTimer
            c.report.AlreadyStartedTimerTotalForToday = c.timerService.TotalMinutesForTaskToday(alreadyStartedTimer)
            c.report.UserTotalForPeriod += alreadyStartedTimer.Minutes
        }
    }

    return c.response()
}

func (c *Status) response() *ResponseToSlack {
    return &ResponseToSlack{
        Body: []byte(c.theme.FormatStatusCommand(c.report)),
    }
}