export default class FilterBuilder {
private filters = "";
- private addCondition(field: FilterField, cond: string, value?: string) {
+ private addCondition(field: FilterField, cond: string, value?: string, prefix: string = "", postfix: string = "") {
if (value) {
- this.filters += `["${field}","${cond}","${value}"]`;
+ this.filters += `["${field}","${cond}","${prefix}${value}${postfix}"]`;
}
return this;
}
}
public addLike(field: FilterField, value?: string) {
- return this.addCondition(field, "like", value);
+ return this.addCondition(field, "like", value, "", "%");
}
public addILike(field: FilterField, value?: string) {
- return this.addCondition(field, "ilike", value);
+ return this.addCondition(field, "ilike", value, "", "%");
}
public get() {
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="/"/>
import { ConnectedRouter } from "react-router-redux";
import ApiToken from "./components/api-token/api-token";
import authActions from "./store/auth/auth-action";
-import { projectService } from "./services/services";
+import { authService, projectService } from "./services/services";
const history = createBrowserHistory();
}, history);
store.dispatch(authActions.INIT());
-store.dispatch<any>(projectService.getProjectList());
+const rootUuid = authService.getRootUuid();
+store.dispatch<any>(projectService.getProjectList(rootUuid));
const App = () =>
<Provider store={store}>
email: string;
firstName: string;
lastName: string;
+ uuid: string;
+ ownerUuid: string;
}
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([]);
+ }
};
}
API_TOKEN_KEY,
USER_EMAIL_KEY,
USER_FIRST_NAME_KEY,
- USER_LAST_NAME_KEY
+ USER_LAST_NAME_KEY,
+ USER_OWNER_UUID_KEY,
+ USER_UUID_KEY
} from "../../services/auth-service/auth-service";
import { API_HOST } from "../../common/api/server-api";
localStorage.setItem(USER_EMAIL_KEY, "test@test.com");
localStorage.setItem(USER_FIRST_NAME_KEY, "John");
localStorage.setItem(USER_LAST_NAME_KEY, "Doe");
+ localStorage.setItem(USER_UUID_KEY, "uuid");
+ localStorage.setItem(USER_OWNER_UUID_KEY, "ownerUuid");
const state = authReducer(initialState, actions.INIT());
expect(state).toEqual({
user: {
email: "test@test.com",
firstName: "John",
- lastName: "Doe"
+ lastName: "Doe",
+ uuid: "uuid",
+ ownerUuid: "ownerUuid"
}
});
});
email: "test@test.com",
first_name: "John",
last_name: "Doe",
+ uuid: "uuid",
+ owner_uuid: "ownerUuid",
is_admin: true
};
user: {
email: "test@test.com",
firstName: "John",
- lastName: "Doe"
+ lastName: "Doe",
+ uuid: "uuid",
+ ownerUuid: "ownerUuid",
}
});
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};