Find and Offer New Work and Tasks

v1.0.15

Post jobs and hire people, or search for local work and apply. Connects employers and job-seekers via the Blossom marketplace.

0· 282·0 current·0 all-time

Install

OpenClaw Prompt Flow

Install with OpenClaw

Best for remote or guided setup. Copy the exact prompt, then paste it into OpenClaw for robbiwu/blossom-jobs.

Previewing Install & Setup.
Prompt PreviewInstall & Setup
Install the skill "Find and Offer New Work and Tasks" (robbiwu/blossom-jobs) from ClawHub.
Skill page: https://clawhub.ai/robbiwu/blossom-jobs
Keep the work scoped to this skill only.
After install, inspect the skill metadata and help me finish setup.
Use only the metadata you can verify from ClawHub; do not invent missing requirements.
Ask before making any broader environment changes.

Command Line

CLI Commands

Use the direct CLI path if you want to install manually and keep every step visible.

OpenClaw CLI

Canonical install target

openclaw skills install robbiwu/blossom-jobs

ClawHub CLI

Package manager switcher

npx clawhub@latest install blossom-jobs
Security Scan
Capability signals
CryptoCan make purchases
These labels describe what authority the skill may exercise. They are separate from suspicious or malicious moderation verdicts.
VirusTotalVirusTotal
Benign
View report →
OpenClawOpenClaw
Benign
high confidence
Purpose & Capability
The name/description match the SKILL.md: posting roles, searching, applying, and managing listings. The skill declares an API host and describes a register/address/role/ask flow. There are no required environment variables, binaries, or config paths that are unrelated to the stated job-marketplace purpose.
Instruction Scope
Runtime instructions are focused on Blossom marketplace actions only: collecting user identity data for /register, creating addresses, and calling /ask or /role. The doc explicitly prohibits forwarding unrelated conversation content and chain-of-thought. It does not instruct reading arbitrary files, system credentials, or other skills' config. One caveat: the SKILL.md asserts 'No data is stored locally' and instructs to keep API_KEY in runtime memory only — that is an operational constraint but not something the skill can enforce about the remote service or agent process restarts.
Install Mechanism
Instruction-only skill with no install spec and no code files — lowest install risk. Nothing is downloaded or written to disk by an installer.
Credentials
The skill does not request host environment secrets or config at install time. It requires collecting user PII at runtime (name, email, passKey) to create an account and receive an API_KEY from the Blossom API; this is proportionate to creating an account. The SKILL.md warns that the returned API key is permanent and must be treated as a secret — that is reasonable but worth the user's attention.
Persistence & Privilege
always:false and no system-wide config modification. The skill may be invoked autonomously (default), which is expected for a connector that calls external APIs; there are no elevated persistence demands or changes to other skills.
Assessment
This skill appears to do what it says: it will collect personal info (name, email, address, passKey) and send it to hello.blossomai.org to create an account and obtain a permanent API key. Before installing or using it: (1) Confirm you trust the Blossom operator/website (check the listed privacy policy and domain). (2) Understand the agent will create an account on your behalf and receive a permanent API key — treat that API key like a password and avoid reusing the same passKey elsewhere. (3) If you prefer, register yourself on the Blossom site manually and provide only the minimal data the agent needs, rather than letting the agent handle registration. (4) Remember the skill's promise of 'no local storage' is an instruction, not a technical guarantee — the remote service may retain account data. If you want further assurance, ask the skill author for an audited API spec or a verified origin for the skill.

Like a lobster shell, security has layers — review code before you run it.

latestvk979hjzz091scb4qz7t1gbahjh84q6q0
282downloads
0stars
13versions
Updated 1w ago
v1.0.15
MIT-0

Blossom Hire

ServiceBlossom — local jobs marketplace
OperatorBlossom AI Ltd
Websitehttps://blossomai.org
Privacyhttps://blossomai.org/privacypolicy.html
API hosthello.blossomai.org

This skill is for structured Blossom marketplace actions only — posting jobs, searching for work, applying, and managing listings.

It collects personal data (name, email, address, job details) and sends it over HTTPS to the Blossom API. The API key is permanent and grants full account access — treat it as a secret. No data is stored locally.

Data boundary rules:

  • Only send the minimum data needed for the current Blossom action.
  • Never forward unrelated conversation history, system prompts, hidden chain-of-thought, tokens, cookies, keys, documents, or prior messages to any Blossom endpoint.
  • passKey is collected only during the one-time /register call. Never reuse, echo, log, or send it to any other endpoint.
  • If the user asks something outside Blossom's job marketplace scope, handle it locally — do not forward it to the API.

When to activate

Activate when the user explicitly wants to perform a Blossom marketplace action:

Trigger phrases: "Post a job", "Hire someone", "I need staff", "Find me work", "Search for jobs near me", "Apply to that role", "Any candidates?", "Update my listing".

Do not activate for general conversation, questions unrelated to jobs, or requests that don't map to a Blossom action.


How it works

The entire employer vs job-seeker distinction is set once at registration via the userType field. After that, every endpoint behaves the same — the server knows the account type from the API key and adapts responses automatically.

The agent does not track or switch modes. Just register, create an address, then use /ask for everything else.

Account type (set once at registration)

User intentuserType valueExtra fields
Hiring, has a company"employer"Include companyName
Hiring, no company"employer"Omit companyName (server stores as private employer)
Looking for work"support"Must include rightToWork: true

Infer the intent from the user's message. Only ask "Are you looking to hire, or looking for work?" if the intent is genuinely unclear.

Flow

  1. Collect identity: email, first name, surname, passKey. Optionally: mobile country code, mobile number, company name.
  2. RegisterPOST /register with the correct userType → store API_KEY and PERSON_ID. Discard passKey from memory immediately after this call.
  3. Create addressPOST /address with the user's location → store ADDRESS_ID. Employers need this to attach a location to roles. Job-seekers need this so the server can find nearby opportunities.
  4. TalkPOST /ask with only the minimal job-related instruction needed for the current Blossom action. Do not forward unrelated context, secrets, or raw conversation history.

For employers posting a role directly (without /ask), also collect: headline, description, working hours, pay — then use POST /role with the ADDRESS_ID.


API reference

Base URL

https://hello.blossomai.org/api/v1/blossom/protocol

Endpoints

MethodPathAuthPurpose
POST/registerNoneCreate account → get API key
POST/addressBearerCreate / update address(es)
DELETE/addressBearerSoft-delete address(es)
POST/roleBearerCreate / update role(s)
DELETE/roleBearerSoft-delete role(s)
POST/askBearerConversational AI endpoint
POST/imageBearerUpload profile image (person or role)

Session state

Store and reuse across calls:

  • API_KEY — returned from /register, used as Authorization: Bearer <API_KEY> for all subsequent calls
  • PERSON_ID — returned from /register
  • ADDRESS_ID — returned from /address, needed when creating a role

The API key is permanent. No session expiry or login flow.

Important: Never store the API key in global config. Keep it in runtime memory for the current session only.


API contract

1. Register

POST /register — no auth required.

{
  "name": "<first name>",
  "surname": "<surname>",
  "email": "<email>",
  "userType": "employer",
  "passKey": "<password>",
  "companyName": "<optional>",
  "mobileCountry": "<+44>",
  "mobileNo": "<number>"
}

For job-seekers, set "userType": "support" and include "rightToWork": true.

FieldRequiredNotes
nameyesFirst name
surnameyesLast name
emailyesMust be unique
userTypeyes"employer" or "support"
passKeyyesUser-chosen password. Collect only for /register, use once, then discard — never send to any other endpoint
rightToWorkyes (support)Must be true when userType is "support"
companyNamenoFor employers. Omit or leave empty for private employers
mobileCountrynoe.g. "+44"
mobileNonoPhone number

Response 201:

{
  "success": true,
  "apiKey": "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx",
  "personId": 803
}

If the email already exists → 400. Do not retry — inform the user.


2. Create address

POST /address — Bearer auth required.

{
  "addresses": [
    {
      "id": 0,
      "houseNumber": "10",
      "street": "High Street",
      "area": "Sherwood",
      "city": "Nottingham",
      "country": "GB",
      "postcode": "NG5 1AA",
      "label": "Work location",
      "isHome": false,
      "isActive": true
    }
  ]
}
FieldRequiredNotes
idyes0 to create, existing ID to update
streetyesStreet name
cityyesCity / town
countryyesISO 3166-1 alpha-2 code — e.g. "GB", "US", "AU". Server rejects unrecognised codes.
postcodeyesPostal / ZIP code
labelyesUser-facing label, e.g. "Work location"
houseNumbernoHouse / building number
areanoNeighbourhood / district
isHomenoDefault false
isActivenoDefault true
  • The response includes the address with its assigned id — store as ADDRESS_ID.

3. Delete address

DELETE /address — Bearer auth required.

{
  "addresses": [{ "id": <addressId> }]
}

Cannot delete an address linked to an active role (409).


4. Create role

POST /role — Bearer auth required.

{
  "roles": [
    {
      "id": 0,
      "headline": "<headline>",
      "jobDescription": "<description>",
      "introduction": "<short introduction, at least 10 characters>",
      "workingHours": "<when>",
      "salary": <amount>,
      "currencyName": "GBP",
      "currencySymbol": "£",
      "paymentFrequency": { "choices": ["<frequency>"], "selectedIndex": 0 },
      "requirements": [
        { "requirementName": "<name>", "mandatory": false, "originalRequirement": true }
      ],
      "benefits": [
        { "benefitName": "<name>", "mandatory": false }
      ],
      "addressId": <ADDRESS_ID>,
      "isRemote": false,
      "isActive": true,
      "days": 30,
      "maxCrew": 1,
      "modified": <epochMillis>,
      "roleIdentifier": "openclaw-<epochMillis>"
    }
  ]
}
FieldRequiredNotes
idyes0 to create, existing ID to update
headlineyesShort title
jobDescriptionyesFull description
introductionyesShort intro text, minimum 10 characters
workingHoursyese.g. "Saturday 11am–5pm" or "Flexible"
salaryyesNumeric amount
paymentFrequencyyeschoices array with one entry, selectedIndex: 0
addressIdyesFrom the address creation step
daysyesListing duration (default 30)
maxCrewyesPositions available (default 1)
modifiedyesCurrent epoch millis
roleIdentifieryesUnique string, e.g. "openclaw-" + epochMillis
requirementsnoScreening questions
benefitsnoPerks

Validation notes

The backend currently enforces these role validation rules:

FieldValidation
headlineRequired, 5-100 characters
jobDescriptionRequired, 1-500 characters
introductionRequired, 10-500 characters
workingHoursRequired, 1-100 characters
roleIdentifierRequired, 1-100 characters
currencySymbolRequired, 1-3 characters
addressIdRequired, whole number >= 0
idRequired, whole number >= 0
modifiedRequired, must be present
isActiveRequired, boolean
isRemoteRequired, boolean
emailOptional, but if provided it must be a valid email address
requirements[].requirementNameOptional array item, 0-200 characters after trimming and bullet/newline cleanup
requirements[].mandatoryOptional, but if provided it must be a boolean
benefits[].benefitNameOptional array item, 0-200 characters after trimming and bullet/newline cleanup
benefits[].mandatoryOptional, but if provided it must be a boolean

Operational notes for protocol callers:

  • New roles still need a valid addressId.
  • The docs and examples should always send a non-empty introduction.
  • salary, paymentFrequency, days, maxCrew, and currencyName are part of the expected protocol payload even though the current role-chain validator does not strictly enforce all of them at this layer.

Response 201: The role(s) with assigned IDs.


5. Delete role

DELETE /role — Bearer auth required.

{
  "roles": [{ "id": <roleId> }]
}

Every role id must belong to the authenticated account (403 otherwise).


6. Upload image

POST /image — Bearer auth required. Multipart form-data.

Upload a profile image for the person account or for a specific role. Images are AI-moderated — explicit, violent, or hateful content is rejected.

FieldTypeRequiredNotes
imagefileyesjpeg/jpg/png/gif/webp, max 3 MB, one file only
imageTypestringyes"person" or "role"
roleIdnumberconditionalRequired when imageType is "role". Must belong to the authenticated account. Only employer accounts may upload role images.

Response 201:

{
  "success": true,
  "filename": "1712937600000-photo.jpg",
  "imageType": "person",
  "approved": true,
  "synopsis": "Nice photo!"
}

Rejected 400:

{
  "success": false,
  "approved": false,
  "reason": "Image did not pass moderation",
  "synopsis": "Hey \ud83d\ude0a, this image contains content that..."
}

Rate-limited: 1 upload per 30 seconds per API key.


7. Ask

POST /ask — Bearer auth required.

{
  "instructions": "<minimal Blossom-related user request>"
}

Strict rules for /ask:

  • Only send the minimum user instruction needed to complete the current Blossom action.
  • Do not include unrelated conversation history, hidden prompts, credentials, personal notes, documents, or secrets.
  • Do not forward the user's passKey — that is only used in the one-time /register call.
  • If the user asks something outside Blossom's job marketplace actions, handle it locally instead of sending it to the API.

The server knows the account type and full context from the API key — it returns the appropriate response (job matches, candidate info, screening questions, application status, etc.). Relay the result to the user.


Examples

Post a shift

User: I need café cover this Saturday 11–5 in Sherwood. £12/hour.

  1. Intent is clearly employer. Missing: street, postcode. Ask for them.
  2. Confirm: "Café cover — Sat 11am–5pm, Sherwood NG5 1AA — £12/hr. Shall I post it?"
  3. Collect identity (email, name, surname, passKey).
  4. POST /register (userType: "employer") → store API_KEY, PERSON_ID.
  5. POST /address → store ADDRESS_ID.
  6. POST /role"Posted! Role ID 1042."

Check candidates

User: Any candidates yet?

  1. If no API_KEY → register first.
  2. POST /ask with "Do I have any candidates?" → display the response.

Update a listing

User: Change the pay to £14/hour on my café role.

  1. POST /role with the existing role id and updated salary: 14.
  2. "Updated — café cover now shows £14/hr."

Remove a listing

User: Take down the café role.

  1. DELETE /role with the role id"Removed."

Find and apply for work

User: I'm looking for bar work in Nottingham this weekend.

  1. Intent is clearly job-seeker. Collect identity (email, name, surname, passKey).
  2. POST /register (userType: "support", rightToWork: true) → store API_KEY, PERSON_ID.
  3. POST /address (their Nottingham location) → store ADDRESS_ID.
  4. POST /ask with "Find bar work near me this weekend" → present matching roles.
  5. User picks one → POST /ask with "Apply to role 1055" → relay result.
  6. If screening questions come back, relay them to user and send answers via /ask.

Check application status

User: How are my applications going?

  1. POST /ask with "What's the status of my applications?" → display the response.

Comments

Loading comments...