Project

adminish

0.0
No commit activity in last 3 years
No release in over 3 years
check README.md for more info
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Runtime

~> 4.2.6
 Project Readme

Adminish

An easy way to describe how to interface with your ActiveRecord models so that interfaces can dynamicly interact with them

Instructions

  • add the gem to your Gemfile
gem 'adminish'
  • create an admin controller that you would like to use to serve the information, i suggest the following generator
rails generate controller admin
  • added a function to handle the rendering
# app/controllers/admin_controller.rb
  def models
  # the array is an array of activerecord classes you want to have managed for you
    render json: Adminish::Admin.new([Post, Category])
  end
  • test out your endpoint by first
rails server

then open a browser to whatever route services your newly made endpoint the output will look similar to this

{
  "models": [{
    "title": "Post",
    "tag": "posts",
    "crud": {
      "index": "/posts/",
      "show": "/posts/:id",
      "create": "/posts/",
      "update": "/posts/:id",
      "delete": "/posts/:id"
    },
    "attributes": [{
      "tag": "id",
      "title": "id",
      "type": "integer"
    }, {
      "tag": "title",
      "title": "title",
      "type": "string"
    }, {
      "tag": "body",
      "title": "body",
      "type": "text"
    }, {
      "tag": "created_at",
      "title": "created at",
      "type": "datetime"
    }, {
      "tag": "updated_at",
      "title": "updated at",
      "type": "datetime"
    }]
  }, {
    "title": "Category",
    "tag": "categories",
    "crud": {
      "index": "/categories/",
      "show": "/categories/:id",
      "create": "/categories/",
      "update": "/categories/:id",
      "delete": "/categories/:id"
    },
    "attributes": [{
      "tag": "id",
      "title": "id",
      "type": "integer"
    }, {
      "tag": "title",
      "title": "title",
      "type": "string"
    }, {
      "tag": "created_at",
      "title": "created at",
      "type": "datetime"
    }, {
      "tag": "updated_at",
      "title": "updated at",
      "type": "datetime"
    }]
  }]
}

Gotchas

the gem assumes you are using the conventional CRUD uri strategies

POST /model/ # creates a model
GET /model/ # gets all of the models
PUT /model/:id # updates a model with id of :id
DELETE /model/:id # deletes a model with id of :id