mirror of
https://github.com/token2/snapd.git
synced 2026-03-13 11:15:47 -07:00
just forget it if already disconnected. In the latter case disconnect hooks are not created/run.
92 lines
3.4 KiB
Go
92 lines
3.4 KiB
Go
// -*- Mode: Go; indent-tabs-mode: t -*-
|
|
|
|
/*
|
|
* Copyright (C) 2016-2018 Canonical Ltd
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 3 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
|
|
package daemon
|
|
|
|
import (
|
|
"github.com/snapcore/snapd/interfaces"
|
|
)
|
|
|
|
// plugJSON aids in marshaling snap.PlugInfo into JSON.
|
|
type plugJSON struct {
|
|
Snap string `json:"snap"`
|
|
Name string `json:"plug"`
|
|
Interface string `json:"interface,omitempty"`
|
|
Attrs map[string]interface{} `json:"attrs,omitempty"`
|
|
Apps []string `json:"apps,omitempty"`
|
|
Label string `json:"label,omitempty"`
|
|
// Connections are synthesized, they are not on the original type.
|
|
Connections []interfaces.SlotRef `json:"connections,omitempty"`
|
|
}
|
|
|
|
// slotJSON aids in marshaling snap.SlotInfo into JSON.
|
|
type slotJSON struct {
|
|
Snap string `json:"snap"`
|
|
Name string `json:"slot"`
|
|
Interface string `json:"interface,omitempty"`
|
|
Attrs map[string]interface{} `json:"attrs,omitempty"`
|
|
Apps []string `json:"apps,omitempty"`
|
|
Label string `json:"label,omitempty"`
|
|
// Connections are synthesized, they are not on the original type.
|
|
Connections []interfaces.PlugRef `json:"connections,omitempty"`
|
|
}
|
|
|
|
// interfaceJSON aids in marshaling interfaces.Info into JSON.
|
|
type interfaceJSON struct {
|
|
Name string `json:"name,omitempty"`
|
|
Summary string `json:"summary,omitempty"`
|
|
DocURL string `json:"doc-url,omitempty"`
|
|
Plugs []*plugJSON `json:"plugs,omitempty"`
|
|
Slots []*slotJSON `json:"slots,omitempty"`
|
|
}
|
|
|
|
// interfaceAction is an action performed on the interface system.
|
|
type interfaceAction struct {
|
|
Action string `json:"action"`
|
|
Forget bool `json:"forget,omitempty"`
|
|
Plugs []plugJSON `json:"plugs,omitempty"`
|
|
Slots []slotJSON `json:"slots,omitempty"`
|
|
}
|
|
|
|
// connectionsJSON aids in marshalling information about a single connection
|
|
// into JSON
|
|
type connectionJSON struct {
|
|
Slot interfaces.SlotRef `json:"slot"`
|
|
Plug interfaces.PlugRef `json:"plug"`
|
|
Interface string `json:"interface"`
|
|
Manual bool `json:"manual,omitempty"`
|
|
Gadget bool `json:"gadget,omitempty"`
|
|
SlotAttrs map[string]interface{} `json:"slot-attrs,omitempty"`
|
|
PlugAttrs map[string]interface{} `json:"plug-attrs,omitempty"`
|
|
}
|
|
|
|
// legacyConnectionsJSON aids in marshaling legacy connections into JSON.
|
|
type legacyConnectionsJSON struct {
|
|
Plugs []*plugJSON `json:"plugs,omitempty"`
|
|
Slots []*slotJSON `json:"slots,omitempty"`
|
|
}
|
|
|
|
// connectionsJSON aids in marshaling connections into JSON.
|
|
type connectionsJSON struct {
|
|
Established []connectionJSON `json:"established"`
|
|
Undesired []connectionJSON `json:"undesired,omitempty"`
|
|
Plugs []*plugJSON `json:"plugs"`
|
|
Slots []*slotJSON `json:"slots"`
|
|
}
|