SWoto commented on issue #3083: Automatically create users from csv file URL: https://github.com/apache/incubator-superset/issues/3083#issuecomment-536656071 @JulieRossi, @yqylovy Could you please help me? I'm trying to ryn the code bellow: ``` import requests from flask_jwt_extended.utils import get_csrf_token class UseSupersetApi: def __init__(self, username=None, password=None): self.s = requests.Session() self.base_url = "http://123.45.67.890:8088/" self._csrf = get_csrf_token(self.s.get(self.url('login/'))) self.headers = {'X-CSRFToken': self._csrf, 'Referer': self.url('login/')} # note: does not use headers because of flask_wtf.csrf.validate_csrf # if data is dict it is used as form and ends up empty but flask_wtf checks if data ... self.s.post(self.url('login/'), data={'username': username, 'password': password, 'csrf_token': self._csrf}) def url(self, url_path): return self.base_url + url_path def get(self, url_path): return self.s.get(self.url(url_path), headers=self.headers) def post(self, url_path, data=None, json_data=None, **kwargs): kwargs.update({'url': self.url(url_path), 'headers': self.headers}) if data: data['csrf_token'] = self._csrf kwargs['data'] = data if json_data: kwargs['json'] = json_data return self.s.post(**kwargs) superset = UseSupersetApi('admin', 'passoword') users = [] #some user dicts inside for user in users: payload = {'first_name': user['first_name'], 'last_name': user['last_name'], 'username': user['username'], 'email': user['email'], 'active': True, 'conf_password': user['password'], 'password': user['password']} print(superset.post(url_path='users/api/create', json=payload)) users_by_role = _group_users_by_role(users) for role in users_by_role: payload = {'users': users_by_role[role], 'role_name': role} superset.post(url_path='superset/update_role/', json=payload) ``` But i always get the same error. Doesn't matter if i run inside the container, the server or in my PC... ``` RuntimeError: Working outside of application context. This typically means that you attempted to use functionality that needed to interface with the current application object in some way. To solve this, set up an application context with app.app_context(). See the documentation for more information. ``` Tried to remove the get_csrf_token but than i get error 400.
---------------------------------------------------------------- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. For queries about this service, please contact Infrastructure at: [email protected] With regards, Apache Git Services --------------------------------------------------------------------- To unsubscribe, e-mail: [email protected] For additional commands, e-mail: [email protected]
