-
Notifications
You must be signed in to change notification settings - Fork 33
/
cookies.go
76 lines (63 loc) · 2.42 KB
/
cookies.go
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
74
75
76
package chrome
import "github.com/gopherjs/gopherjs/js"
type Cookies struct {
o *js.Object
}
/*
* Types
*/
type Cookie struct {
*js.Object
Name string `js:"name"`
Value string `js:"value"`
Domain string `js:"domain"`
HostOnly bool `js:"hostOnly"`
Path string `js:"path"`
Secure bool `js:"secure"`
HttpOnly bool `js:"httpOnly"`
Session bool `js:"session"`
ExpirationDate int64 `js:"expirationDate"`
StoreId string `js:"storeId"`
}
type CookieStore struct {
*js.Object
Id string `js:"id"`
TabIds []int `js:"tabIds"`
}
/*
* Methods:
*/
// Get retrieves information about a single cookie. If more than one cookie of the same name
// exists for the given URL, the one with the longest path will be returned. For cookies with
// the same path length, the cookie with the earliest creation time will be returned.
func (c *Cookies) Get(details Object, callback func(cookie Cookie)) {
c.o.Call("get", details, callback)
}
// GetAll retrieves all cookies from a single cookie store that match the given information.
// The cookies returned will be sorted, with those with the longest path first. If multiple cookies
// have the same path length, those with the earliest creation time will be first.
func (c *Cookies) GetAll(details Object, callback func(cookies []Cookie)) {
c.o.Call("getAll", details, callback)
}
// Set sets a cookie with the given cookie data; may overwrite equivalent cookies if they exist.
func (c *Cookies) Set(details Object, callback func(cookie Cookie)) {
c.o.Call("set", details, callback)
}
// Remove deletes a cookie by name.
func (c *Cookies) Remove(details Object, callback func(details Object)) {
c.o.Call("remove", details, callback)
}
// GetAllCookieStores lists all existing cookie stores.
func (c *Cookies) GetAllCookieStores(callback func(cookieStores []CookieStore)) {
c.o.Call("getAllCookieStores", callback)
}
/*
* Events
*/
// OnChanged fired when a cookie is set or removed. As a special case, note that updating a cookie's properties
// is implemented as a two step process: the cookie to be updated is first removed entirely, generating a
// notification with "cause" of "overwrite" . Afterwards, a new cookie is written with the updated values,
// generating a second notification with "cause" "explicit".
func (c *Cookies) OnChanged(callback func(changeInfo Object)) {
c.o.Get("onChanged").Call("addListener", callback)
}