GitXplorerGitXplorer
G

ha-slack-user

public
25 stars
7 forks
4 issues

Commits

List of commits on branch master.
Verified
27fa89f9beac21ca739ab5b6da37050a22522151

Merge pull request #14 from override80/master

GGeorgeSG committed 2 months ago
Verified
40a57b3b321669106ff0350da636b3f1ec27188b

fix: hass.config_entries.async_forward_entry_setup deprecation

ooverride80 committed 2 months ago
Unverified
16deaa09dfc8fbee1f07535df93e5fea506c1714

0.6

GGeorgeSG committed 2 months ago
Verified
79c3accfa63b12f263263bde2b291c12cfd6d056

Merge pull request #13 from MrFinchMkV/fix/missing_await

GGeorgeSG committed 2 months ago
Unverified
00a215ae5283ecfcb7824e6e60a9bce80823edfe

fix: adds missing await keyword

MMrFinchMkV committed 2 months ago
Unverified
2912639508589867344c039f6855808c47f0356d

Bump version to 0.5

GGeorgeSG committed 2 years ago

README

The README file for this repository.

Slack User Sensor

HACS GitHub Release Project Maintenance License

Description

This is a custom integration for Home Assistant. It provides a sensor for a slack user by a given token.

Installation

ha-slack-user is available through HACS. Open HACS -> Integrations -> Exlpore & Add repositories and search for "Slack User".

Or, install manually by downloading the custom_components/slack_user folder from this repo and placing it in your config/custom_components/ folder.

Setup

ha-slack-user is set up with Config Flow. After installing the integration, go to Configuration -> Integrations, click the + button at the bottom right, and search for "Slack User".

The component requires a Slack Member ID (User ID), and API Token.

Tokens

If you are using the deprecated Legacy Tokens, this should work out of the box.

If you are using a token from a Slack App, it'll need to have access to the following scopes:

  • users.profile:read - to get general profile information - title, profile, status, etc
  • users.profile:write - to set user status
  • users:read - to get presence information
  • users:write - to be able to set presence
  • dnd:read - to get DND information
  • dnd:write to set DND status

Sensor data

After setting up a Slack User sensor, you'll have a sensor.name (with the name you specified during config) with the following attributes:

title: string
real_name: string
display_name: string
status_text: string
status_expiration_ts: number
status_emoji: string
status_emoji_display_info:
  emoji_name: string
  display_url: string
  unicode: string
entity_picture: string
huddle_state: string
huddle_state_expiration_ts: number

# Presence Info
presence: "online" or "away"
online: boolean
auto_away: boolean
manual_away: boolean
connection_count: number
last_activity: timestamp

# DND Info
dnd_enabled: boolean
next_dnd_start_ts: timestamp
next_dnd_end_ts: timestamp
snooze_enabled: boolean

Here's an example:

Example sensor

Services

slack_user.set_status

Required API scope: users.profile:write API Method: users.profle.set

Sets the user's slack status.

Field Value Necessity Description
entity_id sensor.slack_user Required Name(s) of the sensor entities
status_text Commuting Optional New status. Pass empty string ("") to clear. Don't pass anything to keep current status.
status_emoji :car: Optional New status emoji. Pass empty string ("") to clear. Don't pass anything to keep current emoji. Will throw an error if emoji doesn't exist.
expiration 2021-06-12 15:00:001 Optional Expiration date. Must be in format yyyy-mm-dd hh:mm:ss

slack_user.clear_status

Required API scope: users.profile:write API Method: users.profle.set

Clears the user's slack status.

Field Value Necessity Description
entity_id sensor.slack_user Required Name(s) of the sensor entities

slack_user.set_presence

Required API scope: users:write API Method: users.setPresence

Updates the user's presence.

Field Value Necessity Description
entity_id sensor.slack_user Required Name(s) of the sensor entities
presence auto or away Required New presence

slack_user.set_dnd

Required API scope: dnd:write API Method: dnd.setSnooze

Enables DND for the user.

Field Value Necessity Description
entity_id sensor.slack_user Required Name(s) of the sensor entities
num_minutes number Required Number of minutes to be in DND

slack_user.end_dnd

Required API scope: dnd:write API Method: dnd.endSnooze

Disables DND for the user.

Field Value Necessity Description
entity_id sensor.slack_user Required Name(s) of the sensor entities

Meta

Georgi Gardev