const regex = new RegExp('[\\?&]' + safeName + '=([^&#]*)');
const results = regex.exec(search);
return results === null ? '' : decodeURIComponent(results[1].replace(/\+/g, ' '));
- };
+ }
componentDidMount() {
const search = this.props.location ? this.props.location.search : "";
const apiToken = ApiToken.getUrlParameter(search, 'api_token');
this.props.dispatch(authActions.SAVE_API_TOKEN(apiToken));
- this.props.dispatch(authService.getUserDetails());
- this.props.dispatch(projectService.getProjectList());
+ this.props.dispatch<any>(authService.getUserDetails()).then(() => {
+ const rootUuid = authService.getRootUuid();
+ this.props.dispatch(projectService.getProjectList(rootUuid));
+ });
}
render() {
- return <Redirect to="/"/>
+ return <Redirect to="/"/>;
}
}
export const USER_EMAIL_KEY = 'userEmail';
export const USER_FIRST_NAME_KEY = 'userFirstName';
export const USER_LAST_NAME_KEY = 'userLastName';
+ export const USER_UUID_KEY = 'userUuid';
+ export const USER_OWNER_UUID_KEY = 'userOwnerUuid';
export interface UserDetailsResponse {
email: string;
first_name: string;
last_name: string;
+ uuid: string;
+ owner_uuid: string;
is_admin: boolean;
}
return localStorage.getItem(API_TOKEN_KEY) || undefined;
}
+ public getOwnerUuid() {
+ return localStorage.getItem(USER_OWNER_UUID_KEY) || undefined;
+ }
+
public getUser(): User | undefined {
const email = localStorage.getItem(USER_EMAIL_KEY);
const firstName = localStorage.getItem(USER_FIRST_NAME_KEY);
const lastName = localStorage.getItem(USER_LAST_NAME_KEY);
- return email && firstName && lastName
- ? { email, firstName, lastName }
+ const uuid = localStorage.getItem(USER_UUID_KEY);
+ const ownerUuid = localStorage.getItem(USER_OWNER_UUID_KEY);
+
+ return email && firstName && lastName && uuid && ownerUuid
+ ? { email, firstName, lastName, uuid, ownerUuid }
: undefined;
}
localStorage.setItem(USER_EMAIL_KEY, user.email);
localStorage.setItem(USER_FIRST_NAME_KEY, user.firstName);
localStorage.setItem(USER_LAST_NAME_KEY, user.lastName);
+ localStorage.setItem(USER_UUID_KEY, user.uuid);
+ localStorage.setItem(USER_OWNER_UUID_KEY, user.ownerUuid);
}
public removeUser() {
localStorage.removeItem(USER_EMAIL_KEY);
localStorage.removeItem(USER_FIRST_NAME_KEY);
localStorage.removeItem(USER_LAST_NAME_KEY);
+ localStorage.removeItem(USER_UUID_KEY);
+ localStorage.removeItem(USER_OWNER_UUID_KEY);
}
public login() {
window.location.assign(`${API_HOST}/logout?return_to=${currentUrl}`);
}
- public getUserDetails = () => (dispatch: Dispatch) => {
+ public getUserDetails = () => (dispatch: Dispatch): Promise<void> => {
dispatch(actions.USER_DETAILS_REQUEST());
- serverApi
+ return serverApi
.get<UserDetailsResponse>('/users/current')
.then(resp => {
dispatch(actions.USER_DETAILS_SUCCESS(resp.data));
});
- // .catch(err => {
- // });
- };
++ }
+
+ public getRootUuid() {
+ const uuid = this.getOwnerUuid();
+ const uuidParts = uuid ? uuid.split('-') : [];
+ return uuidParts.length > 1 ? `${uuidParts[0]}-${uuidParts[1]}` : undefined;
}
}
export default class ProjectService {
public getProjectList = (parentUuid?: string) => (dispatch: Dispatch): Promise<Project[]> => {
dispatch(actions.PROJECTS_REQUEST());
-
- const ub = new UrlBuilder('/groups');
- const fb = new FilterBuilder();
- fb.addEqual(FilterField.OWNER_UUID, parentUuid);
- const url = ub.addParam('filters', fb.get()).get();
-
- return serverApi.get<GroupsResponse>(url).then(groups => {
- const projects = groups.data.items.map(g => ({
- name: g.name,
- createdAt: g.created_at,
- modifiedAt: g.modified_at,
- href: g.href,
- uuid: g.uuid,
- ownerUuid: g.owner_uuid
- } as Project));
- dispatch(actions.PROJECTS_SUCCESS({projects, parentItemId: parentUuid}));
- return projects;
- });
+ if (parentUuid) {
+ const fb = new FilterBuilder();
+ fb.addLike(FilterField.OWNER_UUID, parentUuid);
+ return serverApi.get<GroupsResponse>('/groups', { params: {
+ filters: fb.get()
+ }}).then(groups => {
+ const projects = groups.data.items.map(g => ({
+ name: g.name,
+ createdAt: g.created_at,
+ modifiedAt: g.modified_at,
+ href: g.href,
+ uuid: g.uuid,
+ ownerUuid: g.owner_uuid
+ } as Project));
+ dispatch(actions.PROJECTS_SUCCESS({projects, parentItemId: parentUuid}));
+ return projects;
+ });
+ } else {
+ dispatch(actions.PROJECTS_SUCCESS({projects: [], parentItemId: parentUuid}));
+ return Promise.resolve([]);
+ }
- };
+ }
}
export interface AuthState {
user?: User;
apiToken?: string;
-};
+}
const authReducer = (state: AuthState = {}, action: AuthAction) => {
return actions.match(action, {
const user = {
email: ud.email,
firstName: ud.first_name,
- lastName: ud.last_name
+ lastName: ud.last_name,
+ uuid: ud.uuid,
+ ownerUuid: ud.owner_uuid
};
authService.saveUser(user);
return {...state, user};