/*
* Copyright (c) 2010-2013 Evolveum
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.evolveum.midpoint.web.util;
import org.apache.wicket.request.Url;
import org.apache.wicket.request.mapper.parameter.IPageParametersEncoder;
import org.apache.wicket.request.mapper.parameter.PageParameters;
import java.util.List;
/**
* This encoder with encode/decode {@link OnePageParameterEncoder#PARAMETER} to path
* and all other parameters as query parameters.
* <p>
* Example: /mountPoint/pathParameterValue?param2=value2¶m3=value3
*
* @author lazyman
*/
public class OnePageParameterEncoder implements IPageParametersEncoder {
public static final String PARAMETER = "pathParameter";
@Override
public PageParameters decodePageParameters(Url url) {
PageParameters parameters = new PageParameters();
List<String> segments = url.getSegments();
if (!segments.isEmpty()) {
String value = segments.get(0);
parameters.add(PARAMETER, value);
}
if (url.getQueryParameters() != null) {
for (Url.QueryParameter qp : url.getQueryParameters()) {
parameters.add(qp.getName(), qp.getValue());
}
}
return parameters.isEmpty() ? null : parameters;
}
@Override
public Url encodePageParameters(PageParameters pageParameters) {
Url url = new Url();
for (PageParameters.NamedPair pair : pageParameters.getAllNamed()) {
if (PARAMETER.equals(pair.getKey())) {
url.getSegments().add(pair.getValue());
continue;
}
url.addQueryParameter(pair.getKey(), pair.getValue());
}
return url;
}
}