Skip to content

Commit

Permalink
Merge pull request ceph#11280 from ceph/wip-17440
Browse files Browse the repository at this point in the history
rgw: fixes for virtual hosting of buckets
Reviewed-by: Orit Wasserman <[email protected]>
  • Loading branch information
oritwas authored Nov 1, 2016
2 parents 7b7d098 + 2d6efe8 commit 63e86e5
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 12 deletions.
4 changes: 4 additions & 0 deletions doc/radosgw/s3/commons.rst
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@ The second method identifies the bucket via a virtual bucket host name. For exam
GET / HTTP/1.1
Host: mybucket.cname.domain.com

To configure virtual hosted buckets, you can either set ``rgw_dns_name = cname.domain.com`` in ceph.conf, or add ``cname.domain.com`` to the list of ``hostnames`` in your zonegroup configuration. See `Ceph Object Gateway - Multisite Configuration`_ for more on zonegroups.

.. tip:: We prefer the first method, because the second method requires expensive domain certification and DNS wild cards.

Common Request Headers
Expand Down Expand Up @@ -105,3 +107,5 @@ Common Response Status
+---------------+-----------------------------------+
| ``500`` | InternalError |
+---------------+-----------------------------------+

.. _`Ceph Object Gateway - Multisite Configuration`: ../../multisite
22 changes: 10 additions & 12 deletions src/rgw/rgw_rest.cc
Original file line number Diff line number Diff line change
Expand Up @@ -205,12 +205,10 @@ void rgw_rest_init(CephContext *cct, RGWRados *store, RGWZoneGroup& zone_group)
http_status_names[h->code] = h->name;
}

if (!cct->_conf->rgw_dns_name.empty()) {
hostnames_set.insert(cct->_conf->rgw_dns_name);
}
hostnames_set.insert(zone_group.hostnames.begin(), zone_group.hostnames.end());
string s;
ldout(cct, 20) << "RGW hostnames: " << std::accumulate(hostnames_set.begin(), hostnames_set.end(), s) << dendl;
hostnames_set.insert(cct->_conf->rgw_dns_name);
hostnames_set.insert(zone_group.hostnames.begin(), zone_group.hostnames.end());
hostnames_set.erase(""); // filter out empty hostnames
ldout(cct, 20) << "RGW hostnames: " << hostnames_set << dendl;
/* TODO: We should have a sanity check that no hostname matches the end of
* any other hostname, otherwise we will get ambigious results from
* rgw_find_host_in_domains.
Expand All @@ -221,12 +219,10 @@ void rgw_rest_init(CephContext *cct, RGWRados *store, RGWZoneGroup& zone_group)
* X.B.A ambigously splits to both {X, B.A} and {X.B, A}
*/

if (!cct->_conf->rgw_dns_s3website_name.empty()) {
hostnames_s3website_set.insert(cct->_conf->rgw_dns_s3website_name);
}
hostnames_s3website_set.insert(cct->_conf->rgw_dns_s3website_name);
hostnames_s3website_set.insert(zone_group.hostnames_s3website.begin(), zone_group.hostnames_s3website.end());
s.clear();
ldout(cct, 20) << "RGW S3website hostnames: " << std::accumulate(hostnames_s3website_set.begin(), hostnames_s3website_set.end(), s) << dendl;
hostnames_s3website_set.erase(""); // filter out empty hostnames
ldout(cct, 20) << "RGW S3website hostnames: " << hostnames_s3website_set << dendl;
/* TODO: we should repeat the hostnames_set sanity check here
* and ALSO decide about overlap, if any
*/
Expand Down Expand Up @@ -1836,10 +1832,12 @@ int RGWREST::preprocess(struct req_state *s, RGWClientIO* cio)
// As additional checks:
// - if the Host header is an IP, we're using path-style access without DNS
// - Also check that the Host header is a valid bucket name before using it.
// - Don't enable virtual hosting if no hostnames are configured
if (subdomain.empty()
&& (domain.empty() || domain != info.host)
&& !looks_like_ip_address(info.host.c_str())
&& RGWHandler_REST::validate_bucket_name(info.host)) {
&& RGWHandler_REST::validate_bucket_name(info.host) == 0
&& !(hostnames_set.empty() && hostnames_s3website_set.empty())) {
subdomain.append(info.host);
in_hosted_domain = 1;
}
Expand Down

0 comments on commit 63e86e5

Please sign in to comment.