Metadata-Version: 2.1
Name: pyisim
Version: 0.1.1
Summary: Easy to use Python client for IBM Security Identity Manager (ISIM/ITIM) web services (SOAP and REST APIs) 
Home-page: https://github.com/cazdlt/pyisim
Author: Andrés Zamora
Author-email: cazdlt@gmail.com
License: MIT
Download-URL: https://github.com/cazdlt/pyisim/archive/v0.1.1.tar.gz
Description: 
        # isim
        [![PyPI version shields.io](https://img.shields.io/pypi/v/pyisim)](https://pypi.python.org/pypi/pyisim/)
        [![PyPI status](https://img.shields.io/pypi/status/pyisim)](https://pypi.python.org/pypi/pyisim/)
        [![PyPI license](https://img.shields.io/pypi/l/pyisim)](https://pypi.python.org/pypi/pyisim/)
        [![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
        <!-- https://img.shields.io/pypi/l/pyisim -->
        
        Python client for IBM Security Identity Manager (ISIM/ITIM) web services (SOAP and REST APIs) <br>
        Tested on ISIM 7.0.1 FP13 and ISIM 7.0.2 FP2
        Due to API limitations some functionalities are served through ISIM's REST API and some other through ISIM SOAP Web Services. <br>
        
        This is my first package, and still on development, but I've been using it for months by now so I wanted to share.
        
        
        Usage example:
        
        - Login
        ```py
        from pyisim.auth import Session
        user="itim manager"
        password="secret"
        cert="./my_certificate.cer"
        url="isim.deltaits.com"
        sess=Session(url,user,password,cert)
        ```
        
        *Every example after assumes you have already a valid Session object named sess*
        - Creating people
        ```py
        from pyisim.entities import Person
        info_persona={
            "employeenumber": "1015463230",
            "correo": "cazdlt@gmail.com",
            "title": "Especialista de producto",
            "departmentnumber":"IBM",
        }
        persona = Person(sess, person_attrs=info_persona)
        persona.add(sess,"my org","my justification")
        ```
        - Modifying people
        ```py
        from pyisim import search
        persona = search.people(sess,Person,"employeenumber","1015463230",limit=1)[0]
        persona.title="CEO"
        persona.modify(sess,"my justification")
        ```
        
        - Custom Person/BPPerson entities
        ```py
        from pyisim import Person
        from pyisim import search
        
        class MyBPPerson(Person):
            
            profile_name="BPPerson"
        
            def __init__(self,info,first_name=None):
                if first_name is None:
                        first_name = "Andrés"
                info["givenname"] = first_name
        
                super().__init__(person_attrs=info)
        
        MyBPPerson({"sn":"Zamora"}).add(sess,"my org","New BPPerson")  
        ```
        
        - Access request 
        ```py
        from pyisim import search
        accesses=search.access(sess,filter="*Consulta*",limit=5)
        person=search.people(session,by="givenname",filter="Juan",limit=1)[0]
        person.request_access(session,accesses,"justification")
        ```
        
        - Approve activity
        ```py
        request_id="9585474949338"
        actividad=search.activities(session,by="requestId",filter=request_id,limit=1)[0]
        actividad.complete(sess,"approve","justification")
        ```
        
        - Fulfill RFI
        ```py
        request_id="123483274614"
        form=[
            {
                "name":"description",
                "value":[dn_rol],
            },
            ...
        ]
        actividad=search.activities(session,by="requestId",filter=request_id)[0]
        actividad.complete(sess,form,"justification")
        ```
        
        - Update property files (ISIM VA)
        ```py
        from pyisim.va.auth import Session
        from pyisim.va.configure import update_property
        
        
        u="admin@local"
        p="secret"
        url="isimva.deltaits.com"
        cert="./mycert.cer"
        
        s=Session(u,p,url,cert)
        
        property_file="CustomLabels.properties"
        property_name="scriptframework.properties"
        property_value="ITIM.java.access.util"
        update_property.create_or_update_property(session,property_file,property_name,property_value)
        ```
        
        - Functionalities
            - TLS Client
            - Authentication
            - People
                - Add
                - Modify
                - Search
                - Lookup
                - Request access (and search/lookup)
                - Create custom Person entities (BPPerson, etc..)
                - Suspend
                - Restore
                - Delete
            - Activities
                - Search
                - Lookup
                - Complete
                    - Approvals
                    - Work Orders
                    - RFIs
            - Static roles
                - Search
                - Lookup
                - Add
                - Modify
                - Delete
            - Provisioning policies
                - Add
                - Modify
                - Search
                - Delete
            - Services
                - Search
            - ISIM VA Utilities:
                - Create/Search/Update property files
        
        - TODO:
            - Improve documentation
                - Basic usage
                - Requirements
            - Improve activity search by request id (does not work with the default methods)
            - Add operations to services
            - Normalize request responses
            - Translate docstrings and exceptions into english
                - And, if it's in spanish, everything else in the high level API (entities/search/auth)
        
        
        
Keywords: isim,ibm-security,iam,itim
Platform: UNKNOWN
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Topic :: Software Development
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3.8
Requires-Python: >=3.8.0
Description-Content-Type: text/markdown
