aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/origin.rs
blob: 096ffbbd6fb16a1a33b952ffe8db3afe67fcd019 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

use std::cell::RefCell;
use std::rc::Rc;
use url::{OpaqueOrigin, Origin as UrlOrigin};
use url::{Url, Host};

/// A representation of an [origin](https://html.spec.whatwg.org/multipage/#origin-2).
#[derive(HeapSizeOf)]
pub struct Origin {
    #[ignore_heap_size_of = "Rc<T> has unclear ownership semantics"]
    inner: Rc<RefCell<UrlOrigin>>,
}

// We can't use RefCell inside JSTraceable, but Origin doesn't contain JS values and
// DOMRefCell makes it much harder to write unit tests (due to setting up required TLS).
no_jsmanaged_fields!(Origin);

impl Origin {
    /// Create a new origin comprising a unique, opaque identifier.
    pub fn opaque_identifier() -> Origin {
        let opaque = UrlOrigin::UID(OpaqueOrigin::new());
        Origin {
            inner: Rc::new(RefCell::new(opaque)),
        }
    }

    /// Create a new origin for the given URL.
    pub fn new(url: &Url) -> Origin {
        Origin {
            inner: Rc::new(RefCell::new(url.origin())),
        }
    }

    pub fn set(&self, origin: UrlOrigin) {
        *self.inner.borrow_mut() = origin;
    }

    /// Does this origin represent a host/scheme/port tuple?
    pub fn is_scheme_host_port_tuple(&self) -> bool {
        match *self.inner.borrow() {
            UrlOrigin::Tuple(..) => true,
            UrlOrigin::UID(..) => false,
        }
    }

    /// Return the host associated with this origin.
    pub fn host(&self) -> Option<Host> {
        match *self.inner.borrow() {
            UrlOrigin::Tuple(_, ref host, _) => Some(host.clone()),
            UrlOrigin::UID(..) => None,
        }
    }

    /// https://html.spec.whatwg.org/multipage/#same-origin
    pub fn same_origin(&self, other: &Origin) -> bool {
        *self.inner.borrow() == *other.inner.borrow()
    }

    pub fn copy(&self) -> Origin {
        Origin {
            inner: Rc::new(RefCell::new(self.inner.borrow().clone())),
        }
    }

    pub fn alias(&self) -> Origin {
        Origin {
            inner: self.inner.clone(),
        }
    }
}