Skip to content

Commit

Permalink
Merge remote-tracking branch 'dataquest/dtq-dev' into HEAD
Browse files Browse the repository at this point in the history
  • Loading branch information
kosarko committed Nov 21, 2024
2 parents 08e7076 + 3d052e6 commit dced963
Show file tree
Hide file tree
Showing 36 changed files with 6,602 additions and 138 deletions.
12 changes: 8 additions & 4 deletions .github/disabled-workflows/deploy.yml
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,10 @@ jobs:
working-directory: build-scripts/run/
run: |
./start.sh dspace-$INSTANCE
cd ../..
# use customized docker-compose file for the `85` port because the server is exposed with the namespace `repository`
# `/repository/server`
docker compose --env-file $ENVFILE -p dspace-$INSTANCE -f docker/docker-compose.yml -f docker/docker-compose-rest.yml -f /opt/dspace-envs/5/docker-compose-rest.yml up -d --no-build
deploy-8:
if: inputs.INSTANCE == '*' || inputs.INSTANCE == '8'
Expand Down Expand Up @@ -147,7 +151,7 @@ jobs:
playwright-after-deploy8:
runs-on: ubuntu-latest
needs: deploy-8
timeout-minutes: 15
timeout-minutes: 45
if: '!inputs.IMPORT'
steps:
- name: run playwright
Expand Down Expand Up @@ -184,7 +188,7 @@ jobs:
rest-tests-after-deploy8:
runs-on: ubuntu-latest
needs: playwright-after-deploy8
timeout-minutes: 15
timeout-minutes: 45
steps:
- name: run rest-tests
run: |
Expand Down Expand Up @@ -219,7 +223,7 @@ jobs:
runs-on: ubuntu-latest
needs: import-8
if: inputs.IMPORT
timeout-minutes: 15
timeout-minutes: 45
steps:
- name: run playwright
run: |
Expand Down Expand Up @@ -256,7 +260,7 @@ jobs:
rest-tests-after-import8:
runs-on: ubuntu-latest
needs: playwright-after-import8
timeout-minutes: 15
timeout-minutes: 45
steps:
- name: run rest-tests
run: |
Expand Down
22 changes: 0 additions & 22 deletions cypress/e2e/submission-ui.cy.ts
Original file line number Diff line number Diff line change
Expand Up @@ -230,18 +230,6 @@ describe('Create a new submission', () => {
createItemProcess.showErrorNotSupportedLicense();
});

// Author field should consist of two input fields
it('Author field should consist of two input fields', {
retries: {
runMode: 6,
openMode: 6,
},
defaultCommandTimeout: 10000
},() => {
createItemProcess.checkAuthorFirstnameField();
createItemProcess.checkAuthorLastnameField();
});

it('The submission should not have the Notice Step', {
retries: {
runMode: 6,
Expand All @@ -261,16 +249,6 @@ describe('Create a new submission in the clariah collection', () => {
// This page is restricted, so we will be shown the login form. Fill it out & submit.
cy.loginViaForm(TEST_ADMIN_USER, TEST_ADMIN_PASSWORD);
});

it('The submission should have the Notice Step', {
retries: {
runMode: 6,
openMode: 6,
},
defaultCommandTimeout: 10000
},() => {
createItemProcess.checkClarinNoticeStep();
});
});

function addEUSponsor(euSponsorOrder) {
Expand Down
12 changes: 8 additions & 4 deletions docker/docker-compose-rest.yml
Original file line number Diff line number Diff line change
Expand Up @@ -63,11 +63,11 @@ services:
# BE server port
- published: 808${INSTANCE}
target: 8080
host_ip: 127.0.0.1
host_ip: ${HOST_IP:-127.0.0.1}
# original debug port
- published: 800${INSTANCE}
target: 8000
host_ip: 127.0.0.1
host_ip: ${HOST_IP:-127.0.0.1}
# handle binary port as per https://www.handle.net/hnr_support.html (5th paragraph)
- published: 264${INSTANCE}
target: 2641
Expand All @@ -93,6 +93,10 @@ services:
entrypoint:
- /bin/bash
- '-c'
# When customizing the namespace, add the following command to the entrypoint command below (after `while ...`):
# `pushd ../webapps && unlink server && ln -s /dspace/webapps/server/ 'repository#server' && popd`
# This will create a symlink from the webapps directory to the server directory with the custom namespace
# (e.g. /dspace/webapps/server -> /dspace/webapps/repository#server)
- |
while (!</dev/tcp/dspacedb/543${INSTANCE}) > /dev/null 2>&1; do sleep 1; done;
/dspace/bin/dspace database migrate force
Expand All @@ -112,7 +116,7 @@ services:
ports:
- published: 543${INSTANCE}
target: 543${INSTANCE}
host_ip: 127.0.0.1
host_ip: ${HOST_IP:-127.0.0.1}
stdin_open: true
tty: true
volumes:
Expand All @@ -133,7 +137,7 @@ services:
ports:
- published: 898${INSTANCE}
target: 898${INSTANCE}
host_ip: 127.0.0.1
host_ip: ${HOST_IP:-127.0.0.1}
stdin_open: true
tty: true
working_dir: /var/solr/data
Expand Down
12 changes: 7 additions & 5 deletions docker/docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -17,15 +17,17 @@ services:
TZ: ${TIMEZONE:-Europe/Bratislava}
DSPACE_UI_SSL: 'false'
DSPACE_UI_HOST: dspace-angular
# Use only `4000`, not the {UI_PORT} from the .env because in the container it is always `4000`
DSPACE_UI_PORT: 4000
DSPACE_UI_NAMESPACE: /
DSPACE_UI_NAMESPACE: ${DSPACE_UI_NAMESPACE:-/}
DSPACE_REST_SSL: ${DSPACE_SSL:-false}
DSPACE_REST_HOST: ${DSPACE_HOST:-localhost}
DSPACE_REST_PORT: ${DSPACE_REST_PORT}
DSPACE_REST_NAMESPACE: /server
DSPACE_REST_PORT: ${DSPACE_REST_PORT:-8080}
DSPACE_REST_NAMESPACE: ${DSPACE_REST_NAMESPACE:-/server}
image: ${DSPACE_UI_IMAGE:-ufal/dspace-angular:dspace-7_x}
volumes:
- ./config.prod.yml:/app/config/config.prod.yml
# - ./aai.js:/app/dist/browser/aai.js
# - ./dspace-ui.json:/app/docker/dspace-ui.json:rw
build:
context: ..
Expand All @@ -36,9 +38,9 @@ services:
ports:
- published: 400${INSTANCE}
target: 4000
host_ip: 127.0.0.1
host_ip: ${HOST_IP:-127.0.0.1}
- published: 987${INSTANCE}
target: 987${INSTANCE}
host_ip: 127.0.0.1
host_ip: ${HOST_IP:-127.0.0.1}
stdin_open: true
tty: true
33 changes: 25 additions & 8 deletions src/app/change-submitter-page/change-submitter-page.component.html
Original file line number Diff line number Diff line change
@@ -1,15 +1,32 @@
<div class="container pt-2 pb-4" *ngVar="submitter | async as sub">
<h3>{{'share.submission.page.title' | translate}}</h3>
<span>{{'change.submitter.page.message' | translate}}</span>
<span>{{getSubmitterName(sub)}}</span>
<span> ({{sub?.email}})</span>
<div class="pt-4">
<button class="btn btn-info" (click)="changeSubmitter()">
<div *ngVar="item | async as item" >
<h3>{{'share.submission.page.title' | translate}}</h3>
<div *ngIf="sub">
<span>{{'change.submitter.page.message' | translate}}</span>
<span class="font-weight-bold">{{getName(sub)}}</span>
<span class="font-weight-bold"> ({{sub?.email}})</span>
</div>
<div *ngIf="sub == null">
<span>{{'change.submitter.page.cannot.see.submitter.message' | translate}}</span>
</div>

<div>
<span>{{'change.submitter.page.items.handle.message' | translate}}</span>
<span class="font-weight-bold">{{item?.handle}}</span>
</div>
<div>
<span>{{'change.submitter.page.items.name.message' | translate}}</span>
<span class="font-weight-bold">{{getName(item)}}</span>
</div>

<div class="pt-4">
<button class="btn btn-info" (click)="changeSubmitter()">
<span *ngIf="changeSubmitterSpinner"
class="spinner-border spinner-border-sm spinner-button mr-1" role="status" aria-hidden="true">
</span>
<span>{{'change.submitter.page.button.take-it' | translate}}</span>
</button>
<span>{{'change.submitter.page.button.take-it' | translate}}</span>
</button>
</div>
</div>
</div>

Expand Down
60 changes: 48 additions & 12 deletions src/app/change-submitter-page/change-submitter-page.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,13 @@ import { isNullOrUndef } from 'chart.js/helpers';
import { HALEndpointService } from '../core/shared/hal-endpoint.service';
import { RemoteDataBuildService } from '../core/cache/builders/remote-data-build.service';
import { RequestService } from '../core/data/request.service';
import { PostRequest } from '../core/data/request.models';
import { GetRequest } from '../core/data/request.models';
import { RemoteData } from '../core/data/remote-data';
import { NotificationsService } from '../shared/notifications/notifications.service';
import { TranslateService } from '@ngx-translate/core';
import { HttpHeaders } from '@angular/common/http';
import { HttpOptions } from '../core/dspace-rest/dspace-rest.service';
import { Item } from '../core/shared/item.model';

@Component({
selector: 'ds-change-submitter-page',
Expand All @@ -34,11 +37,22 @@ export class ChangeSubmitterPageComponent implements OnInit {
*/
private shareToken = '';

/**
* WorkspaceItem id from the url.
* This id is used to get authorization rights to call REST API to change the submitter.
*/
private workspaceitemid = '';

/**
* BehaviorSubject that contains the submitter of the WorkspaceItem.
*/
submitter: BehaviorSubject<EPerson> = new BehaviorSubject(null);

/**
* BehaviorSubject that contains the Item.
*/
item: BehaviorSubject<Item> = new BehaviorSubject(null);

/**
* BehaviorSubject that contains the WorkspaceItem.
*/
Expand All @@ -61,6 +75,8 @@ export class ChangeSubmitterPageComponent implements OnInit {
ngOnInit(): void {
// Load `share_token` param value from the url
this.shareToken = this.route.snapshot.queryParams.share_token;
// Load `workspaceitem_id` param value from the url
this.workspaceitemid = this.route.snapshot.queryParams.workspaceitemid;
this.loadWorkspaceItemAndAssignSubmitter(this.shareToken);
}

Expand All @@ -70,17 +86,36 @@ export class ChangeSubmitterPageComponent implements OnInit {
loadWorkspaceItemAndAssignSubmitter(shareToken: string) {
this.findWorkspaceItemByShareToken(shareToken)?.subscribe((workspaceItem: WorkspaceItem) => {
this.workspaceItem.next(workspaceItem);
this.loadItemFromWorkspaceItem(workspaceItem);
this.loadAndAssignSubmitter(workspaceItem);
});
}

/**
* Load the Item from the WorkspaceItem and assign it to the item BehaviorSubject.
*/
loadItemFromWorkspaceItem(workspaceItem: WorkspaceItem) {
if (workspaceItem.item instanceof Observable<Item>) {
workspaceItem.item
.pipe(getFirstSucceededRemoteDataPayload())
.subscribe((item: Item) => {
this.item.next(item);
});
}
}

/**
* Find a WorkspaceItem by its shareToken.
*/
findWorkspaceItemByShareToken(shareToken: string): Observable<WorkspaceItem> {
let requestHeaders = new HttpHeaders();
const requestOptions: HttpOptions = Object.create({});
requestHeaders = requestHeaders.append('shareToken', shareToken);
requestOptions.headers = requestHeaders;

return this.workspaceItemService.searchBy('shareToken', {
searchParams: [Object.assign(new RequestParam('shareToken', shareToken))]
}, false, false, followLink('submitter')).pipe(getFirstSucceededRemoteListPayload(),
}, false, false, followLink('item'), followLink('submitter')).pipe(getFirstSucceededRemoteListPayload(),
map((workspaceItems: WorkspaceItem[]) => workspaceItems?.[0]));
}

Expand Down Expand Up @@ -112,27 +147,28 @@ export class ChangeSubmitterPageComponent implements OnInit {
}

/**
* Get the name of the submitter using the DSONameService.
* @param submitter
* Get the name of the submitter or item using the DSONameService.
*/
getSubmitterName(submitter: EPerson): string {
if (isNullOrUndef(submitter)) {
getName(object: EPerson | Item) {
if (isNullOrUndef(object)) {
return '';
}
return this.dsoNameService.getName(submitter);
return this.dsoNameService.getName(object);
}

/**
* Change the submitter of the WorkspaceItem using the shareToken. This will send a POST request to the backend when
* Change the submitter of the WorkspaceItem using the shareToken. This will send a GET request to the backend when
* the submitter of the Item is changed.
*/
changeSubmitter() {
const requestId = this.requestService.generateRequestId();

const url = this.halService.getRootHref() + '/submission/setOwner?shareToken=' + this.shareToken;
const postRequest = new PostRequest(requestId, url);
// Send POST request
this.requestService.send(postRequest);
const url = this.halService.getRootHref() + '/submission/setOwner?shareToken=' + this.shareToken +
'&workspaceitemid=' + this.workspaceitemid;

const getRequest = new GetRequest(requestId, url);
// Send GET request
this.requestService.send(getRequest);
this.changeSubmitterSpinner = true;
// Get response
const response = this.rdbService.buildFromRequestUUID(requestId);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,6 @@ export class AutoregistrationComponent implements OnInit {
* Retrieve the `ClarinVerificationToken` object by the `verificationToken` value.
*/
private loadVerificationToken() {
console.log('I am here');
this.verificationTokenService.searchBy('byToken', this.createSearchOptions(this.verificationToken))
.pipe(getFirstSucceededRemoteListPayload())
.subscribe(res => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ import { ConfigurationProperty } from '../../../core/shared/configuration-proper
import { ActivatedRoute, Router } from '@angular/router';
import { CookieService } from '../../../core/services/cookie.service';
import { CookieServiceMock } from '../../mocks/cookie.service.mock';
import { NotificationsServiceStub } from '../../testing/notifications-service.stub';
import { NotificationsService } from '../../notifications/notifications.service';

describe('LogInContainerComponent', () => {

Expand All @@ -36,6 +38,7 @@ describe('LogInContainerComponent', () => {
let hardRedirectService: HardRedirectService;
let configurationDataService: ConfigurationDataService;
let authService: any;
let notificationService: NotificationsServiceStub;

beforeEach(waitForAsync(() => {
hardRedirectService = jasmine.createSpyObj('hardRedirectService', {
Expand All @@ -55,6 +58,7 @@ describe('LogInContainerComponent', () => {
]
}))
});
notificationService = new NotificationsServiceStub();

// refine the test module by declaring the test component
TestBed.configureTestingModule({
Expand Down Expand Up @@ -85,6 +89,7 @@ describe('LogInContainerComponent', () => {
} },
{ provide: Router, useValue: new RouterMock() },
{ provide: CookieService, useClass: CookieServiceMock },
{ provide: NotificationsService, useValue: notificationService },
LogInContainerComponent
],
schemas: [
Expand Down
5 changes: 5 additions & 0 deletions src/app/shared/log-in/log-in.component.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ import { ConfigurationProperty } from '../../core/shared/configuration-property.
import { RouterStub } from '../testing/router.stub';
import { CookieService } from '../../core/services/cookie.service';
import { CookieServiceMock } from '../mocks/cookie.service.mock';
import { NotificationsService } from '../notifications/notifications.service';
import { NotificationsServiceStub } from '../testing/notifications-service.stub';

describe('LogInComponent', () => {

Expand All @@ -50,6 +52,7 @@ describe('LogInComponent', () => {
let authorizationService: AuthorizationDataService;
let authService: any;
let configurationDataService: ConfigurationDataService;
let notificationService: NotificationsServiceStub;

beforeEach(waitForAsync(() => {
hardRedirectService = jasmine.createSpyObj('hardRedirectService', {
Expand All @@ -72,6 +75,7 @@ describe('LogInComponent', () => {
]
}))
});
notificationService = new NotificationsServiceStub();

// refine the test module by declaring the test component
void TestBed.configureTestingModule({
Expand Down Expand Up @@ -102,6 +106,7 @@ describe('LogInComponent', () => {
provideMockStore({ initialState }),
{ provide: ThemeService, useValue: getMockThemeService() },
{ provide: CookieService, useClass: CookieServiceMock },
{ provide: NotificationsService, useValue: notificationService },
LogInComponent
],
schemas: [
Expand Down
Loading

0 comments on commit dced963

Please sign in to comment.