Skip to content

Commit

Permalink
Merge pull request #23 from eduNEXT/and/refactor_rocketchat
Browse files Browse the repository at this point in the history
And/refactor rocketchat
  • Loading branch information
jfavellar90 authored May 15, 2018
2 parents 8c48844 + 3066989 commit 9631a6b
Show file tree
Hide file tree
Showing 9 changed files with 896 additions and 466 deletions.
199 changes: 199 additions & 0 deletions rocketc/api_rocket_chat.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,199 @@
"""
This file contains the class with the necessary methos to use rocketchat
"""
import hashlib
import logging
import requests

LOG = logging.getLogger(__name__)


class ApiRocketChat(object):

headers = {"Content-type": "application/json"}
API_PATH = 'api/v1'
salt = "HarryPotter_and_thePrisoner_of _Azkaban"

def __init__(self, user, password, server_url="http://127.0.0.1:3000"):
"""Creates a RocketChat object and does login on the specified server"""
self.server_url = server_url
self._login(user, password)

def _login(self, user, password):
"""This method defines the headers with the authToken and userId"""
url = "/".join([self.server_url, self.API_PATH, "login"])
data = {"user": user, "password": password}
response = requests.post(url=url, json=data, headers=self.headers)
if response.status_code == 200:
response = response.json()["data"]
self.headers["X-Auth-Token"] = response["authToken"]
self.headers["X-User-Id"] = response["userId"]

LOG.info("Auth_token: %s, User_id: %s ", self.headers[
"X-Auth-Token"], self.headers["X-User-Id"])

def _request_rocket_chat(self, method, url_path, data=None, payload=None):
"""
This method generates a call to the RocketChat API and returns a json with the response
"""
url = "/".join([self.server_url, self.API_PATH, url_path])
if method == "post":
response = requests.post(url=url, json=data, headers=self.headers)
LOG.info("Request rocketChat status code = %s", response.status_code)
else:
response = requests.get(url=url, headers=self.headers, params=payload)
LOG.info("Request rocketChat status code = %s", response.status_code)
return response.json()

def add_user_to_group(self, user_id, room_id):
"""
This method add any user to any group
"""
url_path = "groups.invite"
data = {"roomId": room_id, "userId": user_id}
response = self._request_rocket_chat("post", url_path, data)
LOG.info("Method Add to Group: %s with this data: %s", response, data)
return response

def change_user_role(self, user_id, role):
"""
This method allows to change the user's role
"""
url_path = "users.update"
data = {"userId": user_id, "data": {"roles": [role]}}
response = self._request_rocket_chat(
"post", url_path, data)
if response["success"]:
return role

def create_group(self, name, username=""):
"""
This method creates a group with a specific name.
"""
url_path = "groups.create"
data = {"name": name, "members": [username]}
response = self._request_rocket_chat("post", url_path, data)
LOG.info("Method Create Group: %s with this data: %s", response, data)
return response

def create_token(self, username):
"""
This method generates a token that allows to login
"""
url_path = "users.createToken"
data = {'username': username}
response = self._request_rocket_chat("post", url_path, data)
LOG.info("Method Create Token: %s with this data: %s", response, data)
return response

def create_user(self, name, email, username):
"""
This method creates a user with a specific name, username, email and password.
The password is a result from a SHA1 function with the name and salt.
"""
url_path = "users.create"
password = "{}{}".format(name, self.salt)
password = hashlib.sha1(password).hexdigest()
data = {"name": name, "email": email,
"password": password, "username": username}
response = self._request_rocket_chat("post", url_path, data)
LOG.info("Method Create User: %s with this data: %s", response, data)
return response

def get_groups(self):
"""
This method lists the existing groups
"""
url_path = "groups.list"
method = "get"
response = self._request_rocket_chat(method, url_path)
list_groups = []

if "groups" in response:
for group in response["groups"]:
list_groups.append(group["name"])

return list_groups

def convert_to_private_channel(self, room_name):
"""
This method changes channels from public to private
the channel's type is define as t, when t = c is a public channel
and when t = p is a private channel
"""
url_path = "channels.info"
payload = {"roomName": room_name}
channel = self._request_rocket_chat("get", url_path, payload=payload)

if "channel" in channel and channel["channel"]["t"] == "c":
channel_id = channel["channel"]["_id"]
url_path = "channels.setType"
data = {"roomId": channel_id, "type": "p"}
self._request_rocket_chat("post", url_path, data)

def search_rocket_chat_group(self, room_name):
"""
This method gets a group with a specific name and returns a json with group's info
"""
url_path = "groups.info"
payload = {"roomName": room_name}
return self._request_rocket_chat("get", url_path, payload=payload)

def search_rocket_chat_user(self, username):
"""
This method allows to get a user from RocketChat data base
"""
url_path = "users.info"
payload = {"username": username}

return self._request_rocket_chat("get", url_path, payload=payload)

def set_avatar(self, username, image_url):
"""
This method allows to set the profile photo/avatar
"""
url_path = "users.setAvatar"
data = {"username": username, "avatarUrl": image_url}
response = self._request_rocket_chat("post", url_path, data)
LOG.info("Method set avatar: %s with this data: %s", response, data)

def set_group_description(self, group_id, description):
"""
This method allows to set a description's group
"""
if description == "" or description is None:
return

url_path = "groups.setDescription"
data = {"roomId": group_id, "description": description}
method = "post"

response = self._request_rocket_chat(method, url_path, data)

LOG.info("Method Set Description %s with this data: %s", response, data)

def set_group_topic(self, group_id, topic):
"""
This method allows to set a topic's group
"""
if topic == "" or topic is None:
return

url_path = "groups.setTopic"
data = {"roomId": group_id, "topic": topic}
method = "post"

response = self._request_rocket_chat(method, url_path, data)

LOG.info("Method Set Topic: %s with this data: %s", response, data)

def update_user(self, user_id, email):
"""
This method allows to update The user data
"""
url_path = "users.update"
data = {"userId": user_id, "data": {"email": email}}
response = self._request_rocket_chat("post", url_path, data)
LOG.info("Method Update User: %s with this data: %s", response, data)
if response["success"]:
return email
21 changes: 9 additions & 12 deletions rocketc/api_teams.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,34 +29,31 @@ def __init__(self, username, password, client_id, client_secret, # pylint: disa

def _get_token(self, server_url):
"""This method get the Authorization token"""
client_id = self.client_id
client_secret = self.client_secret

oauth = OAuth2Session(
client=LegacyApplicationClient(client_id=client_id))
client=LegacyApplicationClient(client_id=self.client_id))
token_url = "/".join([server_url, "oauth2/access_token/"])

token = oauth.fetch_token(token_url=token_url,
client_id=client_id,
client_secret=client_secret,
client_id=self.client_id,
client_secret=self.client_secret,
username=self.username,
password=self.password)

LOG.info("The acces token is: %s", token["access_token"])

return token['access_token']

def _call_api_get(self, url_path):
def _call_api_get(self, url_path, payload=None):
"""This method return the response"""
url = "/".join([self.server_url, self.API_PATH, url_path])
return requests.get(url, headers=self.headers)
return requests.get(url, headers=self.headers, params=payload)

def get_user_team(self, course_id, username):
"""Get the user's team"""
course_id = course_id.to_deprecated_string().replace("+", "%2B")
url_path = "teams/?course_id={}&username={}".format(
course_id, username)
team_request = self._call_api_get(url_path)
course_id = course_id.to_deprecated_string()
url_path = "teams"
payload = {"course_id": course_id, "username": username}
team_request = self._call_api_get(url_path, payload)

if team_request.status_code == 200:
return team_request.json()["results"]
Expand Down
1 change: 0 additions & 1 deletion rocketc/openedx_dependencies.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,5 +4,4 @@
# pylint: disable=import-error
# pylint: disable=unused-import
from openedx.core.djangoapps.user_api.accounts.image_helpers import get_profile_image_urls_for_user
from lms.djangoapps.teams.models import CourseTeam, CourseTeamMembership
from xmodule.modulestore.django import modulestore
Loading

0 comments on commit 9631a6b

Please sign in to comment.