Page MenuHomePhabricator

Give AlmanacServices a service type
ClosedPublic

Authored by epriestley on Dec 15 2014, 9:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 21, 3:33 PM
Unknown Object (File)
Tue, Jan 21, 11:51 AM
Unknown Object (File)
Sat, Jan 18, 6:22 AM
Unknown Object (File)
Fri, Jan 17, 6:03 PM
Unknown Object (File)
Thu, Jan 2, 11:10 AM
Unknown Object (File)
Mon, Dec 30, 12:17 AM
Unknown Object (File)
Fri, Dec 27, 9:27 PM
Unknown Object (File)
Dec 21 2024, 2:33 AM
Subscribers

Details

Summary

Ref T5833. This allows services to be typed, to distinguish between different kinds of services. This makes a few things easier:

  • It's easier for clients to select the services they're interested in (see note in T5873 about Phacility). This isn't a full-power solution, but gets is some of the way there.
  • It's easier to set appropriate permissions around when modifications to the Phabricator cluster are allowed. These service nodes need to be demarcated as special in some way no matter what (see T6741). This also defines a new policy for users who are permitted to create services.
  • It's easier to browse/review/understand services.
  • Future diffs will allow ServiceTypes to specify more service structure (for example, default properties) to make it easier to configure services correctly. Instead of a free-for-all, you'll get a useful list of things that consumers of the service expect to read.

The "custom" service type allows unstructured/freeform services to be created.

Test Plan
  • Created a new service (and hit error cases).
  • Edited an existing service.
  • Saw service types on list and detail views.
  • Poked around new permission stuff.
  • Ran almanac.queryservices with service class specification.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Give AlmanacServices a service type.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: btrahan.
  • Only accept ClusterRepository services as valid cluster nodes in Diffusion.
btrahan edited edge metadata.
This revision is now accepted and ready to land.Dec 16 2014, 12:57 AM
This revision was automatically updated to reflect the committed changes.